Dynamic Shapes
PaintCode has a great feature called dynamic shapes. With dynamic shapes, you can define how shapes should behave when they are resized. This dynamic behavior is then baked in the generated code.
data:image/s3,"s3://crabby-images/4d350/4d350b4f1cd2aa327a105b3393928deb1dd07fd7" alt="Dynamic Shapes"
Frames and constraints have much wider range of uses than just a resizing. You can use them to change the shapes in many interesting and useful ways:
data:image/s3,"s3://crabby-images/60fb5/60fb599e7f56159fb1be606aa3aed6a3334bd677" alt="Another dynamic bezier example"
To make a shape dynamic:
- draw a frame around the shape
- define how the shape should behave when the enclosing frame is resized
Of course, a single frame may contain many shapes.
Frames
data:image/s3,"s3://crabby-images/8e07d/8e07d862cc2321aefdf4cb815209b7c8fc5afeef" alt="Bezier"
To create a Frame, simply select the “Frame” tool from the toolbar, then click and drag in the canvas.
Frames are not shapes. By themselves, they do not draw anything. However, they affect the generated code. Frames also affect the dynamic behavior of shapes inside them.
In the generated code, a frame corresponds to a method parameter:
data:image/s3,"s3://crabby-images/6d2e1/6d2e1623dca39d984d28e37f5987a2ea3df3a4c2" alt="Frame's rectangle variable"
Dynamic shapes derive their sizes and coordinates from their enclosing frames.
When you resize a frame in the canvas, all derived shapes are resized/moved around, too. To suppress this behavior, hold down the COMMAND key while resizing the frame.