aboutsummaryrefslogtreecommitdiff
path: root/src/addons/rmsmartshape/documentation/Quickstart.md
blob: bd1523ad772011b05b67d776a03e092497bc8c70 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
SmartShape2D - QuickStart
---
![Finished Image]( ./imgs/Inpsector-EdgeMaterialsNormalRange.png )

If you feel like your workflow with SmartShape2D is a little bit slow, try reading [Controls and Hotkeys](./Controls.md). The hotkeys may help you work with the tool more effectively.

# Creating a Shape
- First, instance a node of either:
  - SS2D_Shape_Open
  - **SS2D_Shape_Closed**
    - **We'll use a closed shape for this Quickstart demo**
- SS2D_Shape_Base cannot be instanced directly
- SS2D_Shape_Anchor is a node that attaches to a shape
- The following Nodes are legacy nodes and are deprecated:
  - RMSmartShape2D
  - RMSmartShape2DAnchor

![Nodes]( ./imgs/NewNode-SS2D_Nodes.png )

# Editing the Shape
- After creating the shape node, make sure it's selected and the toolbar appears and is in Point Edit mode
  - ![Toolbar Default State](./imgs/Toolbar-PointEdit.png)
- Hold ALT and Left Click on the viewport to add points
  - If this is a closed shape, the polygon will close after adding the 3rd point
- You should now have a shape consisting of a few points and lines:

![Toolbar Default State](./imgs/ShapeClosed-Untextured.png)

# Setting the Fill Texture of the Shape (Closed Shape only)
- To give it some life, we'll want to edit the "Shape Material" in the Inspector
- Under "Shape Material" Expand "Fill Textures" and you'll see an empty array
- Set the Array's size to '1'
- Assign a texture to the newly created slot in the array
- After assigning the shape should now have a valid texture
  - If nothing happens after setting the texture, try to force the shape to update by adjusting one of the points
- **Note that "Fill Textures" does not affect SS2D_Shape_Open Nodes at all**
- If you want to add a normal_texture, you would add it using the "Fill Texture Normals" property

![Fill Texture Set](./imgs/ShapeClosed-FillTextured.png)

# Texturing the Edges
- This where the rubber hits the road, the real meat of the tool
- Under "Shape Material" add an element to the "Edge Meta Materials" property
  - Shape Material -> Edge Meta Materials
- Set the resource of the newly created element to "SS2D_Material_Edge_Metadata"
  - Unfortunately, due to Godot limitations, every avaiable resource will offered to you instead of the one you want
  - The options are alphabetized though, which helps in finding the resource you want
- Expand the first element of the "Edge Meta Materials" that you just set
  - Shape Material -> Edge Meta Materials -> element 1
- Set the value of the "Edge Material" property to a new resource of type "SS2D_Material_Edge"
  - Shape Material -> Edge Meta Materials -> element 1 -> Edge Material
- Expand "Edge Material" that you just set
- Add an element to "Textures" and assign the texture to one that you want to use as an edge
- The shape's edges should now update using the texture you set
  - If nothing happens after setting the texture, try to force the shape to update by adjusting one of the points
- If you want to add a normal_texture, you would add it using the "Texture Normals" property
- Godot should now look something like this:

![Inspector](./imgs/Inpsector-EdgeMaterial.png)

## Corners
- If your shape has sharp 90-degree corners, the texture can look a bit warped in those places
- You can specify a unique texture to use for inner and outer corners for each Edge Material
- The following Edge Material properties are used for corners
  - Textures Corner Inner
  - Texture Normals Corner Inner
  - Textures Corner Outer
  - Texture Normals Corner Outer
- See how the addition of outer corner textures improves the square created earlier

![Inspector](./imgs/Inpsector-EdgeMaterialCornerOuter.png)

## Multiple Edge Materials in One Edge
- You can add as many Edge Meta Materials as you want to a Shape Material, each with their own Edge Material
- For instance, you can add an additional egde with a rock texture (and its own set of corner textures) and have it render behind the grass
  - To have it render behind the grass, Set the Z index of the meta material

![Inspector](./imgs/Inpsector-EdgeMaterials2.png)

## Normal Range
- Each Meta material has a Normal Range
- The Normal Range indicates when a texture should be rendered
  - If the normal range is 0 - 360 or 0 - 0, then any angle is considered in range and the edge will always render
  - Angle "0" is Facing directly Right
  - Angle "90" is Facing directly Up
  - Angle "180" is Facing directly Left
  - Angle "270" is Facing directly Down

- If you wanted to, for example:
  - Have rocks display on the bottom part of the shape only
  - Have grass display on the sides and top of the shape only
- You could:
  - Set the grass Normal Range to 0 - 180
  - Set the rock Normal Range to 181 - 359

![Inspector](./imgs/Inpsector-EdgeMaterialsNormalRange.png)

## Material Overrides
- Using Material Overrides will allow you to change how specific edges are rendered
- For Example, to prevent the left edge from rendering, we'll do the following:
  - Select the edge edit button from the toolbar ![]( ./imgs/icon_edge.png )
  - Right Click the left edge of the shape
  - Press the "Material Override" Button
  - Uncheck the "Render" Checkbox

![Edge NoRender]( ./imgs/EdgeEdit-NoRender.png )

- You can use material overrrides to also specify a specific material for a single edge
- For example, Checking Render and choosing the "Rock" Edge Material will cause the edge to render as rocks, even though the NormalRange configuration would otherwise have it render as grass

## Multiple Textures
- If more than one texture is specified for an Edge Material, you can specify which texture should be used
- Enter Point Edit mode, mouseover a point, and scroll up or down to change the texture index

# Anchoring Nodes to the Shape
- To anchor nodes directly to the SmartShape2D node, use SmartSahpeAnchor2D
- You can then make nodes children to the anchor