Skip to content

arup-group/OasysGH

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OasysGH

Downloads Install plugin

A library with shared content for Oasys Grasshopper plugins.

Latest CI Pipeline Deployment Dependencies
GitHub release (latest by date including pre-releases)
Yak
Nuget
Azure DevOps builds GitHub Workflow Status
GitHub Workflow Status
Libraries.io dependency status for GitHub repo
Dependents (via libraries.io)

Contents

  1. Introduction
  2. How to use
    1. Shared units
  3. Content overview
    1. Units
    2. Component Attributes
    3. Abstract component classes
    4. Abstract parameter classes
    5. Input helpers
    6. Output helpers

Introduction

OasysGH is a library with shared content for Oasys Grasshopper plugins.

You can use this library for:

  • Units shared by multiple plugins, with form to set defaults.
  • GH_UnitNumber parameter to pass OasysUnits (fork of UnitsNet) based objects around between components.
  • Custom component UI (dropdown, sliders, buttons, etc), also known s "Component Attributes".
  • Abstract classes for parameters to help handle wrapping an object oriented API.
  • Abstract classes for components to help implement custom component UI.
  • Helper methods for input/output of various custom parameters

How to use

Reference this library as a NuGet package in your project.

Setup a OasysPluginInfo PluginInfo singleton like this for your plugin:

internal sealed class PluginInfo
{
  private static readonly Lazy<OasysPluginInfo> lazy =
      new Lazy<OasysPluginInfo>(() => new OasysPluginInfo(
        "Oasys Shared Grasshopper", "OasysGH", "1.0.0.0", false, "phc_alOp3OccDM3D18xJTWDoW44Y1cJvbEScm5LJSX8qnhs"
        ));
   public static OasysPluginInfo Instance { get { return lazy.Value; } }
   private PluginInfo()
  {
  }
}

Shared units

To initialise shared default units along with the Windows Form to allow user to set their default units, simply call the method:

OasysGH.Utility.InitialiseMainMenuAndDefaultUnits();

DefaultUnits This will also automatically download the latest version of the UnitNumber plugin, which is a separate project in this repository.

Content overview

Units

This library contains:

  • A shared class with default units for typical engineering units.
  • Filters to get relevant engineering units (UnitsNet contains many units unrelated to engineering, for instance lengths in lightyears or printer points)
  • Helper methods to get for instance a moment unit from length and force units.
  • A custom grasshopper parameter called GH_UnitNumber which wraps OasysUnits.IQuantity which will allow you to pass numbers with units around between components.
  • Input helpers for GH_UnitNumber which will allow users to input:
    • another GH_UnitNumber,
    • a number (for instance from a slider) which will be converted into a Quantity with the selected unit (can be combined with dropdown UI component to allow users to select the unit)
    • a text string, for instance 15 kNm which will be parsed into a OasysUnits.Moment.

Component Attributes

Attributes for components is a custom way to override the drawing methods creating the UI of a component on the Grasshopper canvas.

It is used to set the m_attributes field in a Grasshopper component:

public override void CreateAttributes()
{
  m_attributes = new UI.DropDownComponentAttributes(this, SetSelected, _dropDownItems, _selectedItems, _spacerDescriptions);
}

OasysGH contains component Attribute methods to create:

  • Bool6 component (six check boxes)
  • Button component (single button for 'Open' components)
  • Dropdown(s) with check boxes
  • Dropdown(s) component
  • Dropdown(s) with slider (for scaling results)
  • Releases component (12 check boxes)
  • Support component (three buttons with six check boxes)
  • Three button component (for 'Save' components, buttons for 'Save', 'Save As' and 'Open in X')

Feel free to add your own custom components UI.

Abstract component classes

Inherit from GH_OasysComponent, GH_OasysDropDownComponent or GH_OasysTaskCapableComponent<T> to:

  • Track usage with posthog
  • Use simple scaffolding code to create, for instance, complex dropdown menus components. The abstract base classes take care of most things for you.
  • By default, the GH_OasysDropDownComponent will use DropDownComponentAttributes so you do not have to override the CreateAttributes() method unless you want to use one of the other component attributes.

GH_OasysComponent

Inherit from this class if you have a simple, normal component with nothing fancy happening. This will simply add posthog tracking to your components.

GH_OasysDropDownComponent

Inherit from this class to use the custom UI. As mentioned above, the default behaviour is for GH_OasysDropDownComponent to use DropDownComponentAttributes but if you want to use one of the other attributes just override the CreateAttributes() method.

A good example for simple implementation of the abstract/virtual methods in GH_OasysDropDownComponent is shown below, this is taken from the ComposGH repo

This example will create a component with a dropdown menu to set a length unit. It will take the initial unit from the default units, but then afterwards save the selected unit in the component so that the settings is stored when users reopen their Grasshopper document.

First, we need to initialise the dropdown lists

private LengthUnit LengthUnit = DefaultUnits.LengthUnitSection; // get default length unit

public override void InitialiseDropdowns()
{
  _spacerDescriptions = new List<string>(new string[] { "Unit" });

  _dropDownItems = new List<List<string>>();
  _selectedItems = new List<string>();

  // add length
  _dropDownItems.Add(Units.FilteredLengthUnits);
  _selectedItems.Add(LengthUnit.ToString());

  _isInitialised = true;
}

Secondly, we need to implement what happens when users make a selection in the dropdown:

public override void SetSelected(int i, int j)
{
  // change selected item
  _selectedItems[i] = _dropDownItems[i][j];
  if (LengthUnit.ToString() == _selectedItems[i])
    return;

  LengthUnit = (LengthUnit)Enum.Parse(typeof(LengthUnit), _selectedItems[i]);

  base.UpdateUI();
}

Then we need to handle what happens when the component is recreated when a saved document is opened again (or when the component is copied). The contents of _selectedItems and _dropDownItems are both stored and recreated automatically by GH_OasysDropDownComponent base.

public override void UpdateUIFromSelectedItems()
{
  LengthUnit = (LengthUnit)Enum.Parse(typeof(LengthUnit), _selectedItems[0]);

  base.UpdateUIFromSelectedItems();
}

Finally, and optionally, we may want to change the name of the input parameters to display the selected unit on for instance sliders:

public override void VariableParameterMaintenance()
{
  string unitAbbreviation = Length.GetAbbreviation(LengthUnit);
  Params.Input[0].Name = "Pos x [" + unitAbbreviation + "]";
  Params.Input[3].Name = "Spacing [" + unitAbbreviation + "]";
}

ChangeDropdown

Abstract parameter classes

The abstract parameter classes makes it easy to implement a custom Grasshopper parameter by wrapping another API object.

GH_OasysGoo

An example of how easy it is to inherit from GH_OasysGoo<T> is the GH_UnitNumber Goo wrapper class, that makes sure s OasysUnits IQuantity can be used in Grasshopper and passed around between components.

public class GH_UnitNumber : GH_OasysGoo<IQuantity>
{
  public static string Name => "UnitNumber";
  public static string NickName => "UN";
  public static string Description => "A value with a unit measure";
  public override OasysPluginInfo PluginInfo => GH_UnitNumberPluginInfo.Instance;

  public GH_UnitNumber(IQuantity item) : base(item) { }
  public override IGH_Goo Duplicate() => new GH_UnitNumber(Value);  
}

GH_OasysGeometryGoo

This class is still to be implemented, but is in the making...

Input helpers

OasysGH provides helper methods to get generic input parameters. This enables a single line of code in SolveInstance to retreive custom input parameters in a coherent way that will act similar to how Grasshopper acts to build-in parameters (same type of errors/warnings). For instance a UnitNumber length input can be retrieved like this:

Length inputLength = (Length)Input.UnitNumber(this, DA, 0, _lengthUnit);

The helpers include methods for getting:

  • GenericGoo<T> (item input)
  • List<GenericGoo<T>> (list input)
  • UnitNumber (item input)
  • List<UnitNumber> (list input)

The UnitNumber inputs are special in the sense that they include additional helpers to cast from string (text) and double (number) inputs, allowing users to input IQuanity as either a:

  • UnitNumber
  • Number (unit will be taken from the dropdown or you can implement a static unit like Hertz for FrequencyUnit)
  • Text (for instance 15 kNm or 130mm)

image

In the image above, the unit for the Height input (cm) is taken from dropdown. Note that the text inputs can be either with or without space between value and unit. Not shown is the example of inputting another UnitNumber.

Output helpers

In order to prevent the dropdown components to continuously expire downstream components, OasysGH provides helper functions to set outputs as item, list or tree which will only expire the output if the output has actually been changed. This allows the user to toggle the dropdown lists without the entire Grasshopper script having to recalculate.

License

License: MIT