The Layout-O-Matic slices and dices your viewport in 2 easy steps. With the Layout-O-Matic getting web-like layouts is such a breeze.
Layout Engine for Scenic Framework (documentation).
{:scenic_layout_o_matic, "~> 0.4.0"}
https://github.com/BWheatie/layout_demo
Layouts are hard. Layouts with CSS are hard. Layouts without CSS can be both freeing and frustrating. While Scenic is intended for fixed resolution displays, not everyone is comfortable coding fixed {x,y}. What the Layout-O-Matic aims to do is bring familiarity of CSS grid to Scenic to make layouts as comfortable and semantic as possible.
defmodule LayoutDemo.Scene.Home do
use Scenic.Scene
alias Scenic.Graph
alias LayoutOMatic.Layouts.Components.Layout, as: Components.Layout
alias LayoutOMatic.Layouts.Grid
@viewport Application.get_env(:my_app, :viewport)
|> Map.get(:size)
@graph Graph.build()
|> add_specs_to_graph(Grid.simple({0, 0}, @viewport_size, [:top, :right, :bottom, :left, :center])),
id: :root_grid
)
def init(_, opts) do
id_list = [
:this_button,
:that_button,
:other_button,
:another_button
]
graph =
Enum.reduce(id_list, @graph, fn id, graph ->
graph
|> Scenic.Components.button("Button", id: id, styles: %{width: 80, height: 40})
end)
{:ok, new_graph} = AutoLayout.auto_layout(graph, :left_group_grid, id_list)
{:ok, opts, push: new_graph}
end
end
Components.Layout.auto_layout/3
and Primitives.Layout.auto_layout/3
are the two functions you will use. They each take a graph, the group_id
you want to apply the objects to, and a list of ids(which can be used later to easily access those objects). Simply replace your list of ids and the component or primitive you want generated and watch the Layout-O-Matic do all the work for you.
A more thorough walkthrough is available.
- Circle
- Rectangle
- RoundedRectangle
All but RadioGroups. Still need to figure those out.
Currently if an object is rotated, the Layout-O-Matic will not respect that as it will likely impact the size of the object.
Scenic is a very exciting framework for the Elixir community especially for embedded applications. The motivation for this project is not to bring the web to Scenic but rather to bring some of the familiar layout apis to Scenic. When I started a project I was quickly frustrated in dynamically placing buttons in a view. This library is to bring some familiar tooling for layouts to Scenic.
Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change. If there is a CSS-like property you believe would be a useful addition please first use the library to make sure it isn't already possible. After, open an issue to discuss it's purpose and why it would be valueable for Scenic development. As Scenic is not for web development, ideally this library would only include the most valuable tools to build great applications.
Please make sure to update tests as appropriate.