Commit 9568c957 authored by Ian Hickson's avatar Ian Hickson

Merge pull request #2775 from Hixie/textPainter-docs

More dart docs for text painter
parents c23e968f f5a00d8e
...@@ -25,7 +25,23 @@ bool _deepEquals(List<Object> a, List<Object> b) { ...@@ -25,7 +25,23 @@ bool _deepEquals(List<Object> a, List<Object> b) {
} }
/// An immutable span of text. /// An immutable span of text.
///
/// A [TextSpan] object can be styled using its [style] property.
/// The style will be applied to the [text] and the [children].
///
/// A [TextSpan] object can just have plain text, or it can have
/// children [TextSpan] objects with their own styles that (possibly
/// only partially) override the [style] of this object. If a
/// [TextSpan] has both [text] and [children], then the [text] is
/// treated as if it was an unstyled [TextSpan] at the start of the
/// [children] list.
///
/// To paint a [TextSpan] on a [Canvas], use a [TextPainter].
class TextSpan { class TextSpan {
/// Creates a [TextSpan] with the given values.
///
/// For the object to be useful, at least one of [text] or
/// [children] should be set.
const TextSpan({ const TextSpan({
this.style, this.style,
this.text, this.text,
...@@ -33,24 +49,42 @@ class TextSpan { ...@@ -33,24 +49,42 @@ class TextSpan {
this.recognizer this.recognizer
}); });
/// The style to apply to the text and the children. /// The style to apply to the [text] and the [children].
final TextStyle style; final TextStyle style;
/// The text contained in the span. /// The text contained in the span.
/// ///
/// If both text and children are non-null, the text will preceed the /// If both [text] and [children] are non-null, the text will preceed the
/// children. /// children.
final String text; final String text;
/// Additional spans to include as children. /// Additional spans to include as children.
/// ///
/// If both text and children are non-null, the text will preceed the /// If both [text] and [children] are non-null, the text will preceed the
/// children. /// children.
///
/// Modifying the list after the [TextSpan] has been created is not
/// supported and may have unexpected results.
///
/// The list must not contain any nulls.
final List<TextSpan> children; final List<TextSpan> children;
/// If non-null, will receive events that hit this text span. /// A gesture recognizer that will receive events that hit this text span.
///
/// [TextSpan] itself does not implement hit testing or event
/// dispatch. The owner of the [TextSpan] tree to which the object
/// belongs is responsible for dispatching events.
///
/// For an example, see [RenderParagraph] in the Flutter rendering library.
final GestureRecognizer recognizer; final GestureRecognizer recognizer;
/// Apply the [style], [text], and [children] of this object to the
/// given [ParagraphBuilder], from which a [Paragraph] can be obtained.
/// [Paragraph] objects can be drawn on [Canvas] objects.
///
/// Rather than using this directly, it's simpler to use the
/// [TextPainter] class to paint [TextSpan] objects onto [Canvas]
/// objects.
void build(ui.ParagraphBuilder builder) { void build(ui.ParagraphBuilder builder) {
assert(debugAssertValid()); assert(debugAssertValid());
final bool hasStyle = style != null; final bool hasStyle = style != null;
...@@ -103,6 +137,9 @@ class TextSpan { ...@@ -103,6 +137,9 @@ class TextSpan {
return result; return result;
} }
/// Flattens the [TextSpan] tree into a single string.
///
/// Styles are not honored in this process.
String toPlainText() { String toPlainText() {
assert(debugAssertValid()); assert(debugAssertValid());
StringBuffer buffer = new StringBuffer(); StringBuffer buffer = new StringBuffer();
...@@ -136,6 +173,13 @@ class TextSpan { ...@@ -136,6 +173,13 @@ class TextSpan {
return buffer.toString(); return buffer.toString();
} }
/// In checked mode, throws an exception if the object is not in a
/// valid configuration. Otherwise, returns true.
///
/// This is intended to be used as follows:
/// ```dart
/// assert(myTextSpan.debugAssertValid());
/// ```
bool debugAssertValid() { bool debugAssertValid() {
assert(() { assert(() {
if (!visitTextSpan((TextSpan span) { if (!visitTextSpan((TextSpan span) {
...@@ -176,7 +220,7 @@ class TextSpan { ...@@ -176,7 +220,7 @@ class TextSpan {
int get hashCode => hashValues(style, text, recognizer, hashList(children)); int get hashCode => hashValues(style, text, recognizer, hashList(children));
} }
/// An object that paints a [TextSpan] into a canvas. /// An object that paints a [TextSpan] tree into a [Canvas].
class TextPainter { class TextPainter {
TextPainter([ TextSpan text ]) { TextPainter([ TextSpan text ]) {
this.text = text; this.text = text;
......
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