Parameter and Category are two most important objects in the Revit API and they are related to each other. There are hundreds of BuiltInParameter enumerator values and many times we need to narrow down them to some sub sets based on some criteria, for example, one or a few categories. We are going to take about these in this article.
The help class ParameterFilterUtilities in the Revit API can help us achieve the goal, and the key method is GetFilterableParametersInCommon().
Supposing we’d like to find all applicable parameters both built-in and custom to the wall category, what shall we do?
The following code does so:
public static object[] GetApplicableParametersOfWalls(RvtDocument doc)
{
List<ElementId> catList = new List<ElementId>();
catList.Add(doc.Settings.Categories.get_Item(BuiltInCategory.OST_Walls).Id);
List<ElementId> paramList = ParameterFilterUtilities.GetFilterableParametersInCommon(doc, catList).ToList();
List<BuiltInParameter> list1 = new List<BuiltInParameter>();
List<string> list2 = new List<string>();
foreach (ElementId id in paramList)
{
if (id.IntegerValue < 0)
{
list1.Add((BuiltInParameter)id.IntegerValue);
}
else
{
list2.Add(doc.get_Element(id).Name);
}
}
return new object[] { list1, list2 };
}
The following test code writes the information to a CSV file:
…
object[] appParams1 = GetApplicableParametersOfWalls(CachedDoc);
using (StreamWriter sw = new StreamWriter(@"c:\temp\AppParamsOfWalls.csv"))
{
List<BuiltInParameter> list1 = appParams1[0] as List<BuiltInParameter>;
List<string> list2 = appParams1[1] as List<string>;
foreach (BuiltInParameter p in list1)
{
sw.WriteLine(p.ToString());
}
sw.WriteLine();
foreach (string s in list2)
{
sw.WriteLine(s);
}
}
…
Here is the content of the CSV file:
KEYNOTE_PARAM
REIN_EST_BAR_VOLUME
HOST_VOLUME_COMPUTED
HOST_AREA_COMPUTED
ALL_MODEL_MODEL
ALL_MODEL_MANUFACTURER
ALL_MODEL_INSTANCE_COMMENTS
ALL_MODEL_TYPE_COMMENTS
ALL_MODEL_URL
ALL_MODEL_DESCRIPTION
CURVE_ELEM_LENGTH
UNIFORMAT_DESCRIPTION
UNIFORMAT_CODE
SYMBOL_FAMILY_NAME_PARAM
ALL_MODEL_TYPE_NAME
WINDOW_TYPE_ID
DOOR_FIRE_RATING
DOOR_COST
ALL_MODEL_MARK
WALL_STRUCTURAL_USAGE_PARAM
FUNCTION_PARAM
WALL_ATTR_WIDTH_PARAM
ExistingParameter1
NewParameter1
TemporarySharedParameter
Volume41
Volume42
PrjParameter
Let us have a look at another example, finding all applicable parameters both built-in and custom to the window and door category, what shall we do?
The following code does so:
public static object[] GetApplicableParametersOfWindowsDoors(RvtDocument doc)
{
List<ElementId> catList = new List<ElementId>();
catList.Add(doc.Settings.Categories.get_Item(BuiltInCategory.OST_Windows).Id);
catList.Add(doc.Settings.Categories.get_Item(BuiltInCategory.OST_Doors).Id);
List<ElementId> paramList = ParameterFilterUtilities.GetFilterableParametersInCommon(doc, catList).ToList();
List<BuiltInParameter> list1 = new List<BuiltInParameter>();
List<string> list2 = new List<string>();
foreach (ElementId id in paramList)
{
if (id.IntegerValue < 0)
{
list1.Add((BuiltInParameter)id.IntegerValue);
}
else
{
list2.Add(doc.get_Element(id).Name);
}
}
return new object[] { list1, list2 };
}
Again, the following test code writes the information to a CSV file:
…
object[] appParams2 = GetApplicableParametersOfWindowsDoors(CachedDoc);
using (StreamWriter sw = new StreamWriter(@"c:\temp\AppParamsOfWindowsDoors.csv"))
{
List<BuiltInParameter> list1 = appParams1[0] as List<BuiltInParameter>;
List<string> list2 = appParams1[1] as List<string>;
foreach (BuiltInParameter p in list1)
{
sw.WriteLine(p.ToString());
}
sw.WriteLine();
foreach (string s in list2)
{
sw.WriteLine(s);
}
}
…
Here is the output:
KEYNOTE_PARAM
ALL_MODEL_MODEL
ALL_MODEL_MANUFACTURER
ALL_MODEL_INSTANCE_COMMENTS
ALL_MODEL_TYPE_COMMENTS
ALL_MODEL_URL
ALL_MODEL_DESCRIPTION
OMNICLASS_DESCRIPTION
OMNICLASS_CODE
UNIFORMAT_DESCRIPTION
UNIFORMAT_CODE
SCHEDULE_LEVEL_PARAM
SYMBOL_FAMILY_NAME_PARAM
ALL_MODEL_TYPE_NAME
WINDOW_TYPE_ID
INSTANCE_HEAD_HEIGHT_PARAM
INSTANCE_SILL_HEIGHT_PARAM
FAMILY_ROUGH_WIDTH_PARAM
FAMILY_ROUGH_HEIGHT_PARAM
GENERIC_WIDTH
DOOR_HEIGHT
DOOR_OPERATION_TYPE
GENERIC_CONSTRUCTION_TYPE
DOOR_COST
ALL_MODEL_MARK
Parameter Categorizer of RevitAddinWizard can create the code automatically in no time.
Recent Comments