I am traveling to Gothenburg for the Forge accelerator.
On the way, I noticed another update to the interesting thread in the Revit API discussion forum by Allan Seidel, @aksaks and @akseidel, sharing his 3D Aimer, just because.
Later, I noticed that he shared a second, related project that also looks very useful and exciting, the mysteriously-named family plunk:
- WTA FireP 3D Aimer tools
- GitHub repository and YouTube video
- Source code documentation
- WTA Elec – another family plunk and concept share
WTA FireP 3D Aimer Tools
Says Allan about 3D Aimer, just because:
If a picture is worth a thousand words then maybe a video is at least that, well maybe not.
Words for this might be,"What for?".
The answer is, "Just because." Sorry for the file size. The guts to how this is done have been previously posted.
- AIM3D_DOWNSIZED.mp4, 21 MB
The overall intent is to share ideas and show what has been used using information learned from The Building Coder site.
The 3d Aimer is a proof of concept.
It has roots in something similar made in AutoCAD VBA 11 years ago that was part of a technical lighting design, but in Revit it is a curiosity. Perhaps someone might see that it performs a needed task.
The other things going on in the video are just as much part of the show for sharing.
Like what those rounded status windows are and how they come into being and change during the workflow or how a selection swipe across everything only selected the items that would be rotated. The whole megillah, from ribbon start to end, is best for seeing so that one starting from scratch can see the implementation, for good or for bad example.
GitHub Repository and YouTube Video
The 3d Aimer, which rotates a family in many directions, is part of a larger project.
I have created a public GitHub repository and a YouTube posting for it:
Source Code Documentation
Revit Add-in in C# : Creates a custom ribbon Tab with discipline related tools. The tools at this writing are for placing specific Revit family types with some families requiring parameter settings made on the fly.
Included is the 3dAimer example that "aims" a special Revit family to a target. The enclosed Revit project is for demonstrating the 3dAimer.
This repository is provided for sharing and learning purposes. Perhaps someone might provide improvements or education. Perhaps it will help to boost someone further up the steep learning curve needed to create Revit task add-ins. Hopefully it does not show too much of the wrong way.
Used by the tools in this ribbon are classes intended to provide a Revit family instance placement without the Revit use interface overhead normally required by Revit. The classes are intended to provide a universal mechanism for placing some types of Revit families. This includes tags, which is a task not in this discipline Tab but is in other discipline add-ins. The custom tab employs menu methods not commonly explained, for example a split button sets a family placement mode that is exposed to the functions called by command picks. Other tools use Add-in application settings as a way to persist settings or communicate to code that runs subsequent within a command that provides a task workflow.
What goes on in this add-in is much of the typical tasks required for providing a Tab menu interface involving family placement tasks and for implementing those tasks. This means things like:
- Creating a ribbon tab populated with some controls
- Tool tips
- Image file to Button image
- Communication between controls and commands the controls execute
- Establishing the family type for placement
- Determine if the correct pairing exists in the current file
- Automatically discovering and loading the family if it does not exist in the current file but does exist somewhere staring from some set directory
- Providing the family type placement interface
- In multiple mode or one shot mode
- With a heads-up status/instruction interface form
- As WPF with independent behavior
- Sending focus back to the Revit view
- Returning the family instance placement for further processing after the instance has been placed
- Managing an escape out from the process
- Handling correct view type context
- Changing family parameter values
Much of the code is by others. Its mangling and ignorant misuse is my ongoing doing. Much thanks to the professionals like Jeremy Tammik who provided the means directly or by mention one way or another for probably all the code needed.
Many thanks to Allan for sharing this!
WTA Elec – Another Family Plunk and Concept Share
Allan shared a second, related project related to electrical fixtures in his thread on another family plunk, concept share:
Blurring the line between Revit API and Revit to visualize an abstraction, here is a video and code share. Perhaps it has value. One add-in picks ceilings and reports information about the lighting in the room that cannot be scheduled because Revit schedules lighting power by what it learns through the light fixture connector, which is apparent power, not dissipated power. Dissipated power is needed for some purposes. The second add-in picks ceilings to get the ceiling height and passes that information to a family plunk. The family's purpose is to visualize a detection field. The detection field geometry depends on the device hight. That gets passes to the family instance. The floating window seen in the video in both add-in examples is the same UI device concept.
- WTA_Elec GitHub repo
- Revit add-in, occupancy sensor, room lighting information 55-second YouTube video
One task demonstrates rooms being selected with lighting information for that room being shown in a floating WPF. The information contains data not passed through light fixture load connectors and therefore cannot be seen via schedules.
Another task places a non-face based family instance at a ceiling. Therefore the ceiling is selected and its height is passed to the family instance as its Revit level offset and also as a family parameter that controls the family's geometry. This family models the detection pattern for a specific manufacturer's lighting control occupancy sensor. In this example, the manufacturer's published detection pattern data is contradictory and incomplete, so this family needs to be corrected. The concept here is to provide a design tool that allows the lighting control engineer to make an informed decision regarding sensor selection and placement. The family instance is not the sensor but is the detection pattern. It would be disposed or retained. It is placed on a unique workset regardless of the current workset.
The floating heads-up WPF status device seen during the task is actually the same device used in every instance it is seen. WPF's ability to handle itself makes this possible.
The last sequence shows the family in the family editor. Every "blade" in the family is the same nested family. There are about five levels of nesting. In the last level, there are three polar arrays. Without the arrays you would see three blades, each a different size. Parameters control each of the three ways the blades can rotate. One way to describe this is to say the blades can flap up and down like an umbrella, sweep side to side like windshield wipers or twist on their long axis like the pitch to a propeller. Since all of the angles are constant for the sensor detection data the only geometry change this family does is calculate the blade length so that the major blade touches the floor.
Read the full description in the WTA_Elec GitHub repository documentation.
Thanks again, Allan, great job!