Commit 64c9b3dd authored by Adam Barth's avatar Adam Barth

Add some documentation for the basic widgets

parent 4f5164b1
Sky Widgets: Basic
==================
This document describes the basic widgets available in Sky. These widgets are
general-purpose and don't offer an opinion about the visual style of your app.
Container
---------
`Container` is a general-purpose widget that combines several basic widgets in
order to make them easier to use.
- `BoxDecoration decoration` Draw the given decoration around this container.
- `double width` Forces the container to have the given width.
- `double height` Force the container to have the given height.
- `EdgeDims margin` Surrounds the container (i.e., outside the container's
decoration) on the top, right, bottom, and left with the given amount of
space.
- `EdgeDims padding` Surrounds the container's child (i.e., inside the
container's decoration) on the top, right, bottom, and left with the given
amount of space.
- `Matrix4 transform` Apply the given matrix before painting the container.
- `BoxConstraints constraints` Force the width and height of the container to
respect the given constraints.
Layout models
-------------
- `Flex` Layout a list of child widgets along either a horizontal or vertical
axis.
- `Flexible` Mark this child of a `Flex` layout as being flexible.
- `Stack` Layout a list of child widgets on top of each other from back to
front.
- `Positioned`
- `Block` Layout a list of child widgets in a vertical line. Each child's width
is set to the widget of the block, and each child is positioned directly
below the previous child. The block's height is set to the total height of
all of its children. A block can be used only in locations that offer an
unbounded amount of vertical space (e.g., inside a `Viewport`). Rather than
using `Block` directly, most client should use `ScrollableBlock`, which
combines `Block` with `Viewport` and scrolling physics.
Positioning and sizing
----------------------
- `Padding` Surround the child with empty space on the top, right, bottom, and
left according to the given `EdgeDims`.
- `Center` Center the child widget within the space occupied by this widget.
- `SizedBox` Force the child widget to have a particular `width` or `height`
(or both).
- `ConstrainedBox` Apply the given `BoxConstraints` to the child widget as
additional constraints during layout. This widget is a generalization of
`SizedBox`.
- `AspectRatio` Force the child widget's width and height to have the given
`aspectRatio`, expressed as a ratio of width to height.
- `Transform` Apply the given matrix to the child before painting the child.
This widget is useful for adjusting the visual size and position of a widget
without affecting layout.
- `Viewport` Layout the child widget at a larger size than fits in this widget
and render only the portion of the child that is visually contained by this
widget. When rendering, add `offset` to the child's vertical position to
control which part of the child is visible through the viewport.
TODO(abarth): Add support for horizontal viewporting.
- `SizeObserver` Whenever the child widget changes size, this widget calls the
`callback`. Warning: If the callback changes state that affects the size of
the child widget, it is possible to create an infinite loop.
- `ShrinkWrapWidth` Force the child widget to have a width equal to its max
intrinsic width. TODO(abarth): Add a link to the definition of max intrinsic
width. Optionally, round up the child widget's width or height (or both) to
a multiple of `stepWidth` or `stepHeight`, respectively. Note: The layout
performed by `ShrinkWrapWidth` is relatively expensive and should be used
sparingly.
- `Baseline` If the child widget has a `TextBaseline` of the given
`baselineType`, position the child such that its baseline is at `baseline`
layout units from the top of this widget.
Painting effects
----------------
- `Opacity` Adjusts the opacity of the child widget, making the child partially
transparent. The amount of transparency is controlled by `opacity`, with 0.0
0.0 is fully transparent and 1.0 is fully opaque.
- `ClipRect` Apply a rectangular clip to the child widget. The dimensions of
the clip match the dimensions of the child.
- `ClipRRect` Apply a rounded-rect clip the child widget. The bounds of the
clip match the bounds of the child widget with `xRadius` and `yRadius`
controlling the x and y radius of the rounded corner, respectively.
- `ClipOval` Apply an oval clip to the child widget. The oval will be
axis-aligned, with its horizontal and vertical bounds matching the bounds of
the child widget.
- `DecoratedBox` Draw the given `BoxDecoration` surrounding the child widget.
- `CustomPaint` TODO(abarth): Document this widget.
- `ColorFilter` Applies a color filter to the child widget, for example to
tint the child a given color.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment