Styles Overview
Styles are optional modifiers that you can put on any primitive. Each style does a specific thing and some only affect certain primitives.
There is a fixed list of primitive styles which are understood by the drivers. Some Components may introduce their own optional styles, but the only ones sent down to the drivers for rendering are contained in the list below.
In general, the primitive styles are each defined in their own module, but you apply them as options in a primitive's option list.
For example, to use the style defined in the module Scenic.Primitive.Style.Font you would define an option on a text primitive like this:
graph =
Graph.build
|> text( "Styled Text", font: :roboto_mono )
|> text( "Custom Text", font: "fonts/my_font.ttf" )
Primitive Styles
Cap
sets how to draw the end of a line.Fill
fills in a primitive with a paint style.Font
sets the font to use to draw text.FontSize
sets the point size text.Hidden
a flag that sets if a primitive is drawn at all.Input
send cursor related input to your scene when the cursor is over the primitve.Join
sets how to render the intersection of two lines. Works on the intersections of other primitives as well.LineHeight
adjust the vertical distance between lines of text. Works similar to line height in css.MiterLimit
sets whether or not to miter a joint if the intersection of two lines is very sharp.Scissor
defines a rectangle that drawing will be clipped to.Stroke
defines how to draw the edge of a primitive. Specifies both a width and a paint style.TextAlign
sets the horizontal alignment of text relative to the starting point. Examples: :left, :center, or :rightTextBase
sets the vertical alignment of text relative to the starting point. Examples: :top, :middle, :alphabetic, or :bottomTheme
a collection of default colors. Usually passed to components, telling them how to draw in your preferred color scheme.
Primitive Paint Styles
The Fill
and Stroke
styles accept a paint type. This describes what to fill or stroke the primitive with.
There is a fixed set of paint types that the drivers know how to render.
Color
fills a primitive with a solid color.Image
fills a primitive with an image that is loaded intoScenic.Cache
.LinearGradient
fills a primitive with a linear gradient.RadialGradient
fills a primitive with a radial gradient.Stream
fills a primitive with a streaming image.
Specifying Paint
When you use either the Fill
and Stroke
you specify the paint in a tuple like this.
graph =
Graph.build
|> circle( 100, fill: {:color, :green}, stroke: {2, {:color, :blue}} )
Each paint type has specific values it expects in order to draw. See the documentation for that paint type for details.
Color Paint
Specifying a solid color to paint is very common, so has a shortcut. If you simply set a valid color as the paint type, it is assumed that you mean Color
.
graph =
Graph.build
|> circle( 100, fill: :green, stroke: {2, :blue} ) # simple color
|> rect( {100, 200}, fill: {:green, 128} ) # color with alpha
|> rect( {100, 100}, fill: {10, 20, 30, 40} ) # red, green, blue, alpha
What to read next?
If you are exploring Scenic, then you should read the Transforms Overview next.