Commit 2b825dc3 authored by Ian Hickson's avatar Ian Hickson

Merge pull request #2742 from Hixie/rendering-docs

Flesh out rendering library top-level docs
parents 0e743b62 a4ee70c0
...@@ -3,6 +3,20 @@ ...@@ -3,6 +3,20 @@
// found in the LICENSE file. // found in the LICENSE file.
/// The Flutter rendering tree. /// The Flutter rendering tree.
///
/// The [RenderObject] hierarchy is used by the Flutter Widgets
/// library to implement its layout and painting back-end. Generally,
/// while you may use custom [RenderBox] classes for specific effects
/// in your applications, most of the time your only interaction with
/// the [RenderObject] hierarchy will be in debugging layout issues.
///
/// If you are developing your own library or application directly on
/// top of the rendering library, then you will want to have a binding
/// (see [BindingBase]). You can use [RenderingFlutterBinding], or you
/// can create your own binding. If you create your own binding, it
/// needs to import at least [Scheduler], [Gesturer], [Services], and
/// [Renderer]. The rendering library does not automatically create a
/// binding, but relies on one being initialized with those features.
library rendering; library rendering;
export 'src/rendering/auto_layout.dart'; export 'src/rendering/auto_layout.dart';
......
...@@ -662,8 +662,27 @@ class _ForkingSemanticsFragment extends _SemanticsFragment { ...@@ -662,8 +662,27 @@ class _ForkingSemanticsFragment extends _SemanticsFragment {
/// An object in the render tree. /// An object in the render tree.
/// ///
/// Render objects have a reference to their parent but do not commit to a model /// The [RenderObject] class hierarchy is the core of the rendering
/// for their children. /// library's reason for being.
///
/// [RenderObject]s have a [parent], and have a slot called
/// [parentData] in which the parent [RenderObject] can store
/// child-specific data, for example, the child position. The
/// [RenderObject] class also implements the basic layout and paint
/// protocols.
///
/// The [RenderObject] class, however, does not define a child model
/// (e.g. whether a node has zero, one, or more children). It also
/// doesn't define a coordinate system (e.g. whether children are
/// positioned in cartesian coordinates, in polar coordinates, etc) or
/// a specific layout protocol (e.g. whether the layout is
/// width-in-height-out, or constraint-in-size-out, or whether the
/// parent sets the size and position of the child before or after the
/// child lays out, etc; or indeed whether the children are allowed to
/// read their parent's [parentData] slot).
///
/// The [RenderBox] subclass introduces the opinion that the layout
/// system uses cartesian coordinates.
abstract class RenderObject extends AbstractNode implements HitTestTarget { abstract class RenderObject extends AbstractNode implements HitTestTarget {
RenderObject() { RenderObject() {
......
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