Group
Group objects are used for organizational purposes and to group related parameters or other logically related objects together. This allows for better organization and management of the objects within a project.
Additionally, applications that use ParamML and OpenBrIM objects can also utilize Group objects to store custom data. Group objects can be nested within all types of objects, providing a flexible and organized way to manage data within a project.
Syntax
<O T="Group">
.....
.....
.....
</O>
Example: Simple group object.
We can group various objects created as volumes under a single title called "volume" using the Group object. This allows us to move or manipulate all of the volumes at the same time, such as by shifting their position or placing them on the same route in a single move. This can be useful in situations where multiple similar objects need to be managed or manipulated together.
<O N="Volume_Group" T="Project" Category="Core Objects">
<!-- created by ParamML Examples on 26.01.2023 -->
<O N="Volume Object" T="Group" X="80" Alingment="Straight" AlignH="None" AlignT="None" AlignV="None">
<O N="Volume1" T="Volume">
<P N="Opacity" V="0.5" />
<O T="Surface">
<O T="Point" Y="-5" Z="0" />
<O T="Point" Y="5" Z="0" />
<O T="Point" Y="5" Z="10" />
<O T="Point" Y="-5" Z="10" />
</O>
<O T="Surface" X="100">
<O T="Point" Y="-5" Z="0" />
<O T="Point" Y="5" Z="0" />
<O T="Point" Y="5" Z="10" />
<O T="Point" Y="-5" Z="10" />
</O>
</O>
<O N="Volume2" T="Volume">
<P N="Opacity" V="0.7" />
<O T="Surface" X="150">
<O T="Point" Y="-5" Z="0" />
<O T="Point" Y="5" Z="0" />
<O T="Point" Y="5" Z="10" />
<O T="Point" Y="-5" Z="10" />
</O>
<O T="Surface" X="250">
<O T="Point" Y="-5" Z="0" />
<O T="Point" Y="5" Z="0" />
<O T="Point" Y="5" Z="10" />
<O T="Point" Y="-5" Z="10" />
</O>
</O>
</O>
</O> |
3D View |
To view this example in the library, see (https://openbrim.org/platform/?application=inc&author=ParamML_Examples_OpenBrIM+Platform&folder=Core+Objects&obj=objidjvbl1f51lproyl9yftagn)
Example: In this case, the parameters are organized and grouped under the Groups object
<O N="Group_Example1" T="Project" Category="Core Objects">
<!-- created by ParamML Examples on 26.01.2023 -->
<O N="Parameters" T="Group">
<P N="height" V="20" />
<P N="width" V="1" />
<P N="depth" V="2" />
</O>
<O N="Column3D" T="Surface">
<P N="Thickness" V="height" />
<O T="Point" X="0" Y="0" Z="0" />
<O T="Point" X="width" Y="0" Z="0" />
<O T="Point" X="width" Y="depth" Z="0" />
<O T="Point" X="0" Y="depth" Z="0" />
</O>
</O> |
As demonstrated in the code, the parameters are organized and grouped together under a "Group" object. This allows for better organization and management of the parameters within the project, making it easier to access and manipulate the parameters as needed. |
3D View |
To view this example in the library, see (https://openbrim.org/platform/?application=inc&author=ParamML_Examples_OpenBrIM+Platform&folder=Core+Objects&obj=objid28h88drjowaj081pbecbkcfw)
Example: Group object with User “Input” parameter.
You can see the component of the Group Object indicated by the red arrow under "Debug Trace” |
To view this example in the library, see (https://openbrim.org/platform/?application=inc&author=ParamML_Examples_OpenBrIM+Platform&folder=Core+Objects&obj=objidzng76y465jk6989dis4w)
Example: Group Object with Guard Parameter.
To view this example in the library, see (https://openbrim.org/platform/?application=inc&author=ParamML_Examples_OpenBrIM+Platform&folder=Core+Objects&obj=objid5wmpv2algs8awxwy0kxaa)
Example: Group Object with Enumeration
To view this example in the library, see (https://openbrim.org/platform/?application=inc&author=ParamML_Examples_OpenBrIM+Platform&folder=Core+Objects&obj=objidsc7ube8d137drl5yzmoum)