Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Sign in
Toggle navigation
F
Front-End
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
abdullh.alsoleman
Front-End
Commits
9568c957
Commit
9568c957
authored
Mar 18, 2016
by
Ian Hickson
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #2775 from Hixie/textPainter-docs
More dart docs for text painter
parents
c23e968f
f5a00d8e
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
49 additions
and
5 deletions
+49
-5
text_painter.dart
packages/flutter/lib/src/painting/text_painter.dart
+49
-5
No files found.
packages/flutter/lib/src/painting/text_painter.dart
View file @
9568c957
...
@@ -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
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment