Scenic.Primitive.Path (Scenic v0.11.0-beta.0) View Source
Draw a complex path on the screen described by a list of actions.
Data
list_of_commands
The data for a path is a list of commands. They are interpreted in order when the path is drawn. See below for the commands it will accept.
Styles
This primitive recognizes the following styles
hidden
- show or hide the primitivefill
- fill in the area of the primitivestroke
- stroke the outline of the primitive. In this case, only the curvy part.cap
- says how to draw the ends of the line.join
- control how segments are joined.miter_limit
- control how segments are joined.
Commands
:begin
- start a new path segment:close_path
- draw a line back to the start of the current segment{:move_to, x, y}
- move the current draw position{:line_to, x, y}
- draw a line from the current position to a new location.{:bezier_to, c1x, c1y, c2x, c2y, x, y}
- draw a bezier curve from the current position to a new location.{:quadratic_to, cx, cy, x, y}
- draw a quadratic curve from the current position to a new location.{:arc_to, x1, y1, x2, y2, radius}
- draw an arc from the current position to a new location.
Path
vs. Script
Both the Path
and the Script
primitives use the Scenic.Script
to create scripts
are sent to the drivers for drawing. The difference is that a Path is far more limited
in what it can do, and is inserted inline with the compiled graph that created it.
The script primitive, on the other hand, has full access to the API set of
Scenic.Script
and accesses scripts by reference.
The inline vs. reference difference is important. A simple path will be consume fewer resources. BUT it will cause the entire graph to be recompile and resent to the drivers if you change it.
A script primitive references a script that you create separately from the the graph. This means that any changes to the graph (such as an animation) will NOT need to recompile or resend the script.
Usage
You should add/modify primitives via the helper functions in
Scenic.Primitives
graph
|> path( [
:begin,
{:move_to, 0, 0},
{:bezier_to, 0, 20, 0, 50, 40, 50},
{:line_to, 30, 60},
:close_path
],
fill: :blue
)
Link to this section Summary
Functions
Compile the data for this primitive into a mini script. This can be combined with others to generate a larger script and is called when a graph is compiled.
Returns a list of styles recognized by this primitive.
Link to this section Types
Specs
cmd() :: :begin | :close_path | {:move_to, x :: number(), y :: number()} | {:line_to, x :: number(), y :: number()} | {:bezier_to, c1x :: number(), c1y :: number(), c2x :: number(), c2y :: number(), x :: number(), y :: number()} | {:quadratic_to, cx :: number(), cy :: number(), x :: number(), y :: number()} | {:arc_to, x1 :: number(), y1 :: number(), x2 :: number(), y2 :: number(), radius :: number()}
Specs
styles_t() :: [ :hidden | :scissor | :fill | :stroke_width | :stroke_fill | :cap | :join | :miter_limit ]
Specs
t() :: [cmd()]
Link to this section Functions
Specs
compile(primitive :: Scenic.Primitive.t(), styles :: Scenic.Primitive.Style.t()) :: Scenic.Script.t()
Compile the data for this primitive into a mini script. This can be combined with others to generate a larger script and is called when a graph is compiled.
Note: Path is a "Meta" primitive. It isn't really a primitive that is represented in a draw script. Instead, it generates it's own mini-script, which is included inline to the graph it is contained in.
Note: The compiled script is backwards. This is an inline script, which means it is inserted into a larger script as part of the graph compile process and Script.finish() will be called on that later.
Specs
valid_styles() :: styles_t()
Returns a list of styles recognized by this primitive.