LearnRevitAPI
👉 Improve User Selection with ISelectionFilter in Revit API
Nov 1, 2024
👉 Advanced Selection
One of the easiest ways to provide a better experience during selection is to limit what can be selected.
And it can be easily achieved by using ISelectionFilter. Let me show you what it is and how to use it.
Here is example on how to allow only furniture selection:
ISelectionFilter
ISelectionFilter Interface
provides the ability to filter objects during a selection operation.
💡Interface means that it's a blueprint with certain functionality that you can inherit in your own classes. It might sound confusing to beginners, but it's actually simple to use.
So you would need to:
Create your own Class
Inherit
ISelectionFilter
Override Pre-Filter method
Provide as argument to
Selection
methods.
In the documentation we can see what methods that we need to override to make it work.
Selection Methods
If you wonder what methods can take ISelectionFilter you need to look at the arguments in Selection methods.
You will notice that nearly all have this option.
So not, let's look at how to use it
Example #1 - Filter by Class
Here is the first example, where we will allow only Walls to be selected by checking the class.
Here is what's going on:
Import
UI.Selection
classesCreate custom filter Class
Inherit
ISelectionFilter
Override
AllowElement
method
Use custom filter in
PickObjects
Display Results
Example #2 - By Category
Here is another example, but this time I want to filter based on Category. Let's limit selection to OST_Furniture
.
Everything is the same as before.
I've only changed the logic in AllowElement
method.
💡Keep in mind that Category.BuiltInCategory
is only available from Revit 2022. So it's better to use Category.Id
to find the match.
Example #3 - 'Beton' in type name
Let's make it more interesting.
I want to filter selection to only walls that have 'beton' in their Type Names.
Again I only modified logic in AllowElement Method.
Conclusion
And that's how you can improve user experience during selection.
It definitely looks overwhelming for the first time. But as I said many times : Revit API is very repetitive!
And it's not so hard after you've seen multiple examples. We just need to adjust a few lines of code to make it work for different classes, categories or even read parameters.
Testimonial Highlight
Want to Learn Revit API?
I can help you save months in Learning Revit API by providing a step by step roadmap and everything you might need.
Click here to learn more.
Hundreds of people have already gone through this training and they are automating their boring work in Revit. You can be one of them.
Join Newsletter
📩 You will be added to Revit API Newsletter
Join Us!
which is already read by 7500+ people!