1.3.4. Domains & Color
Example files that accompany this section: http://grasshopperprimer.com/appendix/A-2/1_gh-files.html
The color wheel is a model for organizing colors based on their hue. In Grasshopper, colors can be defined by their hue value in a range of 0.0 to 1.0. Domains are used to define a range of all possible values between a set of numbers between a lower limit(A) and an upper limit (B).
data:image/s3,"s3://crabby-images/84c93/84c93f43619c5814377e7b14fbea35fb5da15e3b" alt=""
In the color wheel, hue corresponds to the angle. Grasshopper has taken this 0-360 domainand remapped it between zero and one.
By dividing the Hue domain (0.0 to 1.0) by the number of segments desired, we can assign a hue value to each segment to create a color wheel.
data:image/s3,"s3://crabby-images/3f79a/3f79a4f212696bf29be9710fe1d97dc462a57a77" alt=""
In this example, we will use Grasshopper’s domain and color components to create a color wheel with a variable amount of segments.
|
|
|
01. |
Type Ctrl+N (in Grasshopper) to start a new definition |
|
02. |
Curve/Primitive/Polygon – Drag and drop a Polygon component onto the canvas |
data:image/s3,"s3://crabby-images/cc093/cc0933936af121da19b8ced0db480f4fc7d8f9a5" alt="" |
03. |
Params/Geometry/Point – Drag and drop a Point Parameter onto the canvas |
data:image/s3,"s3://crabby-images/6554a/6554a06645612792cd438faab2479d1c8657ced4" alt="" |
04. |
Right-Click on the Point Component and select set one point |
|
05. |
Set a point in the model space. |
|
06. |
Connect the Point Parameter (Base Point) to the Plane (P) input of the Polygon component |
|
07. |
Params/Input/Number Sliders – Drag and drop two Number Sliders onto the canvas |
|
08. |
Double-click on the first Number Sliders and set the following:Rounding: Integers Lower Limit: 0 Upper Limit: 10 Value: 10 |
|
09. |
Double-click on the second Number Sliders and set the following:Rounding: Integers Lower Limit: 0 Upper Limit: 100 Value: 37 |
|
10. |
Connect the Number Slider (Radius) to the Radius (R) input of the Polygon component When you connect a number slider to a component in will automatically change its name to the name of input that it is connecting to. |
|
11. |
Connect the Number Slider (Segments) to the Segments (S) input of the Polygon component |
|
data:image/s3,"s3://crabby-images/940d6/940d6ed9f023845b4630a4c9ce11321f25b95083" alt=""
|
|
|
12. |
Curve/Util/Explode – Drag and drop an Explode component onto the canvas. |
data:image/s3,"s3://crabby-images/c4cdc/c4cdcb50efa6bd7f6644ee5847fe0050b4724ffe" alt="IMAGE" |
13. |
Connect the Polygon (P) output of the Polygon component to the Curve (C) input of the Explode component |
|
14. |
Surface/Freeform/Extrude Point – Drag and drop the Extrude Point component onto the canvas |
data:image/s3,"s3://crabby-images/16be0/16be084a177a92a052f45dba68bb459db5765570" alt="" |
15. |
Connect the Segments (S) output of the Explode component to the Base (B) input of the Extrude Point |
|
16. |
Connect the Point Parameter (Base Point) to the Extrusion Tip (P) of the Extrude Point component |
|
17. |
Surface/Analysis/Deconstruct Brep – Drag and drop the Deconstruct Brep component on to the canvas |
data:image/s3,"s3://crabby-images/f0196/f0196415f3dca9e6a69dd4956f905fa32f93291e" alt="" |
18. |
Connect the Extrusion (E) output of the Extrude Point component to the Deconstruct Brep (B) component |
|
data:image/s3,"s3://crabby-images/8d76b/8d76beac82046dc56ae1b31bf845dfaa68dd4433" alt="IMAGE"
|
|
|
19. |
Maths/Domain/Divide Domain – Drag and drop the Divide Domain componentThe Base Domain (I) is automatically set between 0.0-1.0 which is what we need for this exercise |
data:image/s3,"s3://crabby-images/960c0/960c0f83fccc27b15b91126c4b31d3491f41e549" alt="" |
20. |
Connect the Number Slider (Segments) to the Count (C) input of the Divide Domain component |
|
21. |
Math/Domain/Deconstruct Domain – Drag and drop the Deconstruct Domain component |
data:image/s3,"s3://crabby-images/cf5cf/cf5cfe40d6331be4286a86980bfa0a66ead97491" alt="IMAGE" |
22. |
Connect the Segments (S) output of the Divide Domain component to the Domain (I) input of the Deconstruct Domain component |
|
23. |
Display/Colour/Colour HSL – Drag and drop the Colour HSL component |
data:image/s3,"s3://crabby-images/6b27d/6b27df3cc86925cecd5fca07d42cb6deb464de2c" alt="IMAGE" |
24. |
Connect the Start (S) output of the Deconstruct Domain component to the Hue (H) input of the Colour HSL components |
|
25. |
Display/Preview/Custom Preview – Drag and drop the Custom Preview component |
data:image/s3,"s3://crabby-images/ce49d/ce49d62437ebdb40a6a8a241140480a55482eb20" alt="" |
26. |
Right click on the Geometry (G) input of the Custom Preview component and select FlattenSee 1-4 Designing with Data Trees for details about flattening |
|
27. |
Connect the Faces (F) output of the Deconstruct Brep component to the Geometry (G) input of the Custom Preview component |
|
28. |
Connect the Colour (C) output of the Colour HSL component to the Shade (S) input of the Custom Preview component |
|
data:image/s3,"s3://crabby-images/e5414/e5414552fa8385ebcdb9232c55fbb5a0a7ec8d47" alt=""
data:image/s3,"s3://crabby-images/4d556/4d5561392acf74a55ca44e66cd24afc0806d066d" alt=""
For different color effects, try connecting the Deconstruct Domain component to the saturation (S) or Luminance (L) inputs of the Colour HSL component.
data:image/s3,"s3://crabby-images/9bc92/9bc92ca5d10eff0716ea338ba586a0af5d94a505" alt=""
data:image/s3,"s3://crabby-images/355d6/355d692e07bba9d65aed18262cad19a5df4804fb" alt=""