|  | // Copyright 2014 The Flutter Authors. All rights reserved. | 
|  | // Use of this source code is governed by a BSD-style license that can be | 
|  | // found in the LICENSE file. | 
|  |  | 
|  | // This example shows how to use flex layout directly in the underlying render | 
|  | // tree. | 
|  |  | 
|  | import 'package:flutter/rendering.dart'; | 
|  |  | 
|  | import 'src/solid_color_box.dart'; | 
|  |  | 
|  | void main() { | 
|  | final RenderFlex table = RenderFlex(direction: Axis.vertical, textDirection: TextDirection.ltr); | 
|  |  | 
|  | void addAlignmentRow(CrossAxisAlignment crossAxisAlignment) { | 
|  | TextStyle style = const TextStyle(color: Color(0xFF000000)); | 
|  | final RenderParagraph paragraph = RenderParagraph( | 
|  | TextSpan(style: style, text: '$crossAxisAlignment'), | 
|  | textDirection: TextDirection.ltr, | 
|  | ); | 
|  | table.add(RenderPadding(child: paragraph, padding: const EdgeInsets.only(top: 20.0))); | 
|  | final RenderFlex row = RenderFlex(crossAxisAlignment: crossAxisAlignment, textBaseline: TextBaseline.alphabetic, textDirection: TextDirection.ltr); | 
|  | style = const TextStyle(fontSize: 15.0, color: Color(0xFF000000)); | 
|  | row.add(RenderDecoratedBox( | 
|  | decoration: const BoxDecoration(color: Color(0x7FFFCCCC)), | 
|  | child: RenderParagraph( | 
|  | TextSpan(style: style, text: 'foo foo foo'), | 
|  | textDirection: TextDirection.ltr, | 
|  | ), | 
|  | )); | 
|  | style = const TextStyle(fontSize: 10.0, color: Color(0xFF000000)); | 
|  | row.add(RenderDecoratedBox( | 
|  | decoration: const BoxDecoration(color: Color(0x7FCCFFCC)), | 
|  | child: RenderParagraph( | 
|  | TextSpan(style: style, text: 'foo foo foo'), | 
|  | textDirection: TextDirection.ltr, | 
|  | ), | 
|  | )); | 
|  | final RenderFlex subrow = RenderFlex(crossAxisAlignment: crossAxisAlignment, textBaseline: TextBaseline.alphabetic, textDirection: TextDirection.ltr); | 
|  | style = const TextStyle(fontSize: 25.0, color: Color(0xFF000000)); | 
|  | subrow.add(RenderDecoratedBox( | 
|  | decoration: const BoxDecoration(color: Color(0x7FCCCCFF)), | 
|  | child: RenderParagraph( | 
|  | TextSpan(style: style, text: 'foo foo foo foo'), | 
|  | textDirection: TextDirection.ltr, | 
|  | ), | 
|  | )); | 
|  | subrow.add(RenderSolidColorBox(const Color(0x7FCCFFFF), desiredSize: const Size(30.0, 40.0))); | 
|  | row.add(subrow); | 
|  | table.add(row); | 
|  | final FlexParentData rowParentData = row.parentData as FlexParentData; | 
|  | rowParentData.flex = 1; | 
|  | } | 
|  |  | 
|  | addAlignmentRow(CrossAxisAlignment.start); | 
|  | addAlignmentRow(CrossAxisAlignment.end); | 
|  | addAlignmentRow(CrossAxisAlignment.center); | 
|  | addAlignmentRow(CrossAxisAlignment.stretch); | 
|  | addAlignmentRow(CrossAxisAlignment.baseline); | 
|  |  | 
|  | void addJustificationRow(MainAxisAlignment justify) { | 
|  | const TextStyle style = TextStyle(color: Color(0xFF000000)); | 
|  | final RenderParagraph paragraph = RenderParagraph( | 
|  | TextSpan(style: style, text: '$justify'), | 
|  | textDirection: TextDirection.ltr, | 
|  | ); | 
|  | table.add(RenderPadding(child: paragraph, padding: const EdgeInsets.only(top: 20.0))); | 
|  | final RenderFlex row = RenderFlex(direction: Axis.horizontal, textDirection: TextDirection.ltr); | 
|  | row.add(RenderSolidColorBox(const Color(0xFFFFCCCC), desiredSize: const Size(80.0, 60.0))); | 
|  | row.add(RenderSolidColorBox(const Color(0xFFCCFFCC), desiredSize: const Size(64.0, 60.0))); | 
|  | row.add(RenderSolidColorBox(const Color(0xFFCCCCFF), desiredSize: const Size(160.0, 60.0))); | 
|  | row.mainAxisAlignment = justify; | 
|  | table.add(row); | 
|  | final FlexParentData rowParentData = row.parentData as FlexParentData; | 
|  | rowParentData.flex = 1; | 
|  | } | 
|  |  | 
|  | addJustificationRow(MainAxisAlignment.start); | 
|  | addJustificationRow(MainAxisAlignment.end); | 
|  | addJustificationRow(MainAxisAlignment.center); | 
|  | addJustificationRow(MainAxisAlignment.spaceBetween); | 
|  | addJustificationRow(MainAxisAlignment.spaceAround); | 
|  |  | 
|  | final RenderDecoratedBox root = RenderDecoratedBox( | 
|  | decoration: const BoxDecoration(color: Color(0xFFFFFFFF)), | 
|  | child: RenderPadding(child: table, padding: const EdgeInsets.symmetric(vertical: 50.0)), | 
|  | ); | 
|  |  | 
|  | RenderingFlutterBinding(root: root); | 
|  | } |