Development and Updates for the Medeek Truss Plugin

Started by Medeek, November 07, 2015, 03:06:39 AM

Previous topic - Next topic

0 Members and 31 Guests are viewing this topic.

Medeek

Even the most convoluted shapes will generate a roof so long as they are closed polygons:



However, I currently don't have a way to create a roof with inner polygons (holes), for example a donut shaped roof.  I don't think this is critical right now but I will put this on my todo list.

Just fixed a major performance bug/flaw in the plugin not only for this module but actually for all the plugins.  I will be releasing updates for each plugin including the Truss plugin that resolve this issue.

Currently working on the roof plane edit tool.
Nathaniel P. Wilkerson, P.E.

Medeek

Version 2.5.0 - 09.28.2019
- Fixed a critical performance bug that affects all the modules within the extension.
- Added the Complex Roofs toolbar.

*** CRITICAL PERFORMANCE UPDATE ***

If you are noticing a slowdown of the plugin performance after multiple edits to a roof or floor assembly, this fix will resolve that issue. This issue affects all previous versions of the plugin.

***

Also note that the complex roof toolbar is now active and will allow you to create a complex roof primitive (edit, move edge, edit outline and regen).  The "Edit Roof Plane" tool is currently not yet available.

The roof primitive and roof outline are placed on separate layers, I will get into that more with a  future tutorial video.  I primarily released this update tonight because of the performance issue I discovered this afternoon with all of the plugins, but it also allows some of you more adventurous designers the ability to test out the new complex roof tools.  Granted a lot remains to be done but at least I've got a start into it now.  I will be focused on it until it is complete.  After that I will attack the secondary roof module. 
Nathaniel P. Wilkerson, P.E.

Medeek

An example of a roof primitive:



(Note, that I've assigned the material of the primitive to a different material and edited it so that it is transparent.)

View model here:

https://3dwarehouse.sketchup.com/model/d9ecec46-8283-478f-91df-24fbd06530d5/Complex-Roof-Primitive-Test-2

The roof outline is a separate group within the assembly, on its own "outline" layer.  I've taken great care to make sure that the primitive is a "solid" so that the user will be able to use SketchUp's boolean (solid) tools to further manipulate these roof primitives if required.
Nathaniel P. Wilkerson, P.E.

Medeek

All the magic happens here:



Nothing elaborate with my office or setup.  The most critical is a somewhat decent computer that works well and the two monitors which allows me to open multiple ruby files at once when I need to.

So busy with the code that I still have not fixed the light fixture base (in the stairwell) that got knocked out of place a few months ago, I guess it all comes down to priorities.
Nathaniel P. Wilkerson, P.E.

Medeek

Every roof plane will be able to be customized (or have the customization removed and return to its default state where it uses the global settings of the roof assembly). 

The first and most important parameter is the Roof Plane Type:  Hip or Gable

Not all roof planes will be able to convert to a gable configuration.  If you look at a complex roof you should only be able to turn the roof planes that form a triangle (defined by three vertices) into a gable configuration.  All other roof panes are going to be inclined or "hip".  The other constraint is that the angle between the roof plane in question and its adjacent roof planes on either side must be orthogonal (90 degrees), otherwise you could potentially try and gable a roof plane on a octagon shaped roof, which would not make any sense.  I think these two constraints will successfully limit a roof plane, as to whether it can become a gable end.

If a roof plane is customized and it is a hip its parameters are:

- pitch
- birdcut
- rafter depth
- overhang
- delta height

If a roof plane is customized and it is a gable end its parameters become:

- gable rafter option
- gable rafter depth
- gable overhang
- rake option
- rake width
- rake depth
- outlooker option
- outlooker spacing
- outlooker size
- outlooker orientation
- outlooker structural: Yes/No
- outlooker @ peak: Yes/No

P.S.  A certain situation exists where the roof plane has 4 vertices might also be able to be a gable end, I will study this further.
Nathaniel P. Wilkerson, P.E.

Medeek

Customizing roof planes gets a little complicated when combined with the roof edge move tool.  The problem is that as you move roof edges you potentially change up the shape of roof, eliminating certain roof planes entirely and also changing some roof planes that potentially could be gable ends back to a hip configuration and vice versa.

With custom roof planes the move tool is going to have to get a bit more elaborate (more logic) so that a number of checks can be run to make sure that we are not trying to turn certain roof planes into gable ends that physically cannot be this configuration and also checking to see if certain roof planes were deleted.

The outline edit tool is even a larger problem in my opinion.  How do you know which edges were retained after an outline edit?  I think the default behavior should be to erase all roof plane customizations after the outline edit tool is used.  I will need to give this some further thought.

Somehow I always knew that complex roofs was going to be a bit of a Pandora's box. 
Nathaniel P. Wilkerson, P.E.

Medeek

Lots of little details when it comes to editing roof planes.  First of all let's introduce an updated  menu:



Notice that the roof plane status will tell you whether the selected roof plane is inheriting its parameters from the main roof or it has its own custom settings.

I've also added a "Clear Custom Settings" at the bottom of the menu so that one can return the roof plane to the default/global settings of the roof assembly.

Setting up all of this supporting infrastructure is somewhat tedious and certainly time consuming, however I do believe that a solid user interface that is both efficient and intuitive will make or break this module.

I intend for the edit plane tool to be persistent, provided that it does not affect stability.  In other words you can keep clicking on roof planes and updating them without having to restart the tool by clicking on the icon in the toolbar.
Nathaniel P. Wilkerson, P.E.

Medeek

After struggling with the code for almost 8 hours I give you a fully parametric, asymmetric complex roof (primitive):



View model here:

https://3dwarehouse.sketchup.com/model/5229b7c9-3ad3-46c1-bcd0-a670abe7aee3/Asymmetric-Complex-Roof-Primitive

I will now need to spend a day or two just trying to break it and I also need to enable the gable end option.

All of the menus and tools are working correctly now and seem to be quite robust.  I will spend the next couple of days finishing up the roof primitive geometry (and testing).  After that I would like to enable sheathing and cladding along with the roof labels and then I will probably release an update so everyone can test it out further and help me unearth any bugs I may have missed.
Nathaniel P. Wilkerson, P.E.

Medeek

If you take a look at these two roofs you will notice that in the second case the lower ridge has degenerated into the steeper roof plane:





I didn't think it was possible but there are certain configurations where a standard straight skeleton will not generate the expected roof.  This is a good example of that.

The complex roof module will not be able to automatically handle these types of situations.

This is where the secondary roof module will need to come in.
Nathaniel P. Wilkerson, P.E.

Medeek

Throwing all sorts of curve balls at this module to see if I can break it.  Ultimately one can always break anything if you try hard enough, especially with something as complex as some of these roofs get. 

Overall I'm pretty happy with it, I've addressed the issue with inside corners and now all is working as expected.  Here is a recent test example of a roof with planes and pitches all over the place:



View model here:

https://3dwarehouse.sketchup.com/model/1f7e4e9c-e727-4053-956c-c71b57d4241d/Asymmetric-Complex-Roof-3

That being said there is always further testing that can be done.  I'm sure there is some state I have not thought of that someone will get the plugin into that will break it.

I think it is time to move on to the gable end option.  Once I get that working I think the utility of this new module will start to become apparent.
Nathaniel P. Wilkerson, P.E.

Medeek

I haven't quite started into the framing geometry just yet but I'm already one step ahead thinking about how certain junctions are going to need to be framed up.

Two hip rafters meeting at a ridge is pretty standard and I think I have that one handled however the junction where a valley rafter meets a flying hip and ridge is a little more uncertain.  Any information on how some of these framing junctions should be made would be very helpful.
Nathaniel P. Wilkerson, P.E.

Medeek

Gable End option (within the edit roof panel menu) is now providing stable results:



View model here:

https://3dwarehouse.sketchup.com/model/b10e6638-5dea-4da2-8a60-dea543978109/Assymetric-Complex-Hip-and-Gable-Roof

The roof primitive module for asymmetric complex roofs with gable and hip ends is now complete.  Granted there is still room for additional options like dutch gable and half hips but I will leave those for another day.

I will now turn my attention to sheathing and cladding as well as the roof plane labels (name and sqft). 

One thing I forgot to add into the overall roof parameters/options is anything for battens and cross battens.  I can add it in if I receive some positive feedback on that feature, otherwise I will move on and start into the sheathing module first thing tomorrow.
Nathaniel P. Wilkerson, P.E.

Medeek

Version 2.5.1 - 10.02.2019
- Enabled the "Edit Roof Plane" tool, allowing for customized roof planes within complex roof assemblies.
- Added the gable end option for complex roofs within the "Edit Roof Panel" tool/menu.
Nathaniel P. Wilkerson, P.E.

Medeek

Version 2.5.1b - 10.03.2019
- Added logic so that customized roof planes can co-exist with the "Move Roof Edge" and "Edit Roof Outline" tools of the complex roof module.

Previously, moving roof edges would potentially shift the customized roof planes if certain roof edges were removed or consolidated.  I think we have now achieved a fully parametric status with the various tools all working together.
Nathaniel P. Wilkerson, P.E.

Medeek

After giving it some further consideration I've decided to enable dutch gable and half hip options for custom roof planes rather than leave it for later. If I include these options now it will force me to keep my other more specific algorithms general enough to handle all cases. The geometry calcs required to generate the roof primitive for these two other configurations is really not that difficult and actually provides a rather intriguing challenge.
Nathaniel P. Wilkerson, P.E.