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
3a15841d
Unverified
Commit
3a15841d
authored
Jun 23, 2020
by
chunhtai
Committed by
GitHub
Jun 23, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
reland "fix the widget span layout when text scale factor != 1" and h… (#60021)
parent
ca32668b
Changes
4
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
104 additions
and
3 deletions
+104
-3
paragraph.dart
packages/flutter/lib/src/rendering/paragraph.dart
+17
-3
basic.dart
packages/flutter/lib/src/widgets/basic.dart
+11
-0
text.dart
packages/flutter/lib/src/widgets/text.dart
+12
-0
text_test.dart
packages/flutter/test/widgets/text_test.dart
+64
-0
No files found.
packages/flutter/lib/src/rendering/paragraph.dart
View file @
3a15841d
...
@@ -79,6 +79,13 @@ class RenderParagraph extends RenderBox
...
@@ -79,6 +79,13 @@ class RenderParagraph extends RenderBox
StrutStyle
strutStyle
,
StrutStyle
strutStyle
,
TextWidthBasis
textWidthBasis
=
TextWidthBasis
.
parent
,
TextWidthBasis
textWidthBasis
=
TextWidthBasis
.
parent
,
ui
.
TextHeightBehavior
textHeightBehavior
,
ui
.
TextHeightBehavior
textHeightBehavior
,
@Deprecated
(
'This parameter is a temporary flag to migrate the internal tests and '
'should not be used in other contexts. For more details, please check '
'https://github.com/flutter/flutter/issues/59316. '
'This feature was deprecated after v1.19.0.'
)
bool
applyTextScaleFactorToWidgetSpan
=
false
,
List
<
RenderBox
>
children
,
List
<
RenderBox
>
children
,
})
:
assert
(
text
!=
null
),
})
:
assert
(
text
!=
null
),
assert
(
text
.
debugAssertIsValid
()),
assert
(
text
.
debugAssertIsValid
()),
...
@@ -91,6 +98,7 @@ class RenderParagraph extends RenderBox
...
@@ -91,6 +98,7 @@ class RenderParagraph extends RenderBox
assert
(
textWidthBasis
!=
null
),
assert
(
textWidthBasis
!=
null
),
_softWrap
=
softWrap
,
_softWrap
=
softWrap
,
_overflow
=
overflow
,
_overflow
=
overflow
,
_applyTextScaleFactorToWidgetSpan
=
applyTextScaleFactorToWidgetSpan
,
_textPainter
=
TextPainter
(
_textPainter
=
TextPainter
(
text:
text
,
text:
text
,
textAlign:
textAlign
,
textAlign:
textAlign
,
...
@@ -290,6 +298,8 @@ class RenderParagraph extends RenderBox
...
@@ -290,6 +298,8 @@ class RenderParagraph extends RenderBox
markNeedsLayout
();
markNeedsLayout
();
}
}
final
bool
_applyTextScaleFactorToWidgetSpan
;
@override
@override
double
computeMinIntrinsicWidth
(
double
height
)
{
double
computeMinIntrinsicWidth
(
double
height
)
{
if
(!
_canComputeIntrinsics
())
{
if
(!
_canComputeIntrinsics
())
{
...
@@ -526,13 +536,17 @@ class RenderParagraph extends RenderBox
...
@@ -526,13 +536,17 @@ class RenderParagraph extends RenderBox
RenderBox
child
=
firstChild
;
RenderBox
child
=
firstChild
;
_placeholderDimensions
=
List
<
PlaceholderDimensions
>(
childCount
);
_placeholderDimensions
=
List
<
PlaceholderDimensions
>(
childCount
);
int
childIndex
=
0
;
int
childIndex
=
0
;
BoxConstraints
boxConstraints
=
BoxConstraints
(
maxWidth:
constraints
.
maxWidth
);
// The content will be enlarged by textScaleFactor during painting phase.
// We reduce constraint by textScaleFactor so that the content will fit
// into the box once it is enlarged.
if
(
_applyTextScaleFactorToWidgetSpan
)
boxConstraints
=
boxConstraints
/
textScaleFactor
;
while
(
child
!=
null
)
{
while
(
child
!=
null
)
{
// Only constrain the width to the maximum width of the paragraph.
// Only constrain the width to the maximum width of the paragraph.
// Leave height unconstrained, which will overflow if expanded past.
// Leave height unconstrained, which will overflow if expanded past.
child
.
layout
(
child
.
layout
(
BoxConstraints
(
boxConstraints
,
maxWidth:
constraints
.
maxWidth
,
),
parentUsesSize:
true
,
parentUsesSize:
true
,
);
);
double
baselineOffset
;
double
baselineOffset
;
...
...
packages/flutter/lib/src/widgets/basic.dart
View file @
3a15841d
...
@@ -5144,6 +5144,13 @@ class RichText extends MultiChildRenderObjectWidget {
...
@@ -5144,6 +5144,13 @@ class RichText extends MultiChildRenderObjectWidget {
this
.
strutStyle
,
this
.
strutStyle
,
this
.
textWidthBasis
=
TextWidthBasis
.
parent
,
this
.
textWidthBasis
=
TextWidthBasis
.
parent
,
this
.
textHeightBehavior
,
this
.
textHeightBehavior
,
@Deprecated
(
'This parameter is a temporary flag to migrate the internal tests and '
'should not be used in other contexts. For more details, see '
'https://github.com/flutter/flutter/issues/59316. '
'This feature was deprecated after v1.19.0.'
)
bool
applyTextScaleFactorToWidgetSpan
=
false
,
})
:
assert
(
text
!=
null
),
})
:
assert
(
text
!=
null
),
assert
(
textAlign
!=
null
),
assert
(
textAlign
!=
null
),
assert
(
softWrap
!=
null
),
assert
(
softWrap
!=
null
),
...
@@ -5151,6 +5158,7 @@ class RichText extends MultiChildRenderObjectWidget {
...
@@ -5151,6 +5158,7 @@ class RichText extends MultiChildRenderObjectWidget {
assert
(
textScaleFactor
!=
null
),
assert
(
textScaleFactor
!=
null
),
assert
(
maxLines
==
null
||
maxLines
>
0
),
assert
(
maxLines
==
null
||
maxLines
>
0
),
assert
(
textWidthBasis
!=
null
),
assert
(
textWidthBasis
!=
null
),
_applyTextScaleFactorToWidgetSpan
=
applyTextScaleFactorToWidgetSpan
,
super
(
key:
key
,
children:
_extractChildren
(
text
));
super
(
key:
key
,
children:
_extractChildren
(
text
));
// Traverses the InlineSpan tree and depth-first collects the list of
// Traverses the InlineSpan tree and depth-first collects the list of
...
@@ -5228,6 +5236,8 @@ class RichText extends MultiChildRenderObjectWidget {
...
@@ -5228,6 +5236,8 @@ class RichText extends MultiChildRenderObjectWidget {
/// {@macro flutter.dart:ui.textHeightBehavior}
/// {@macro flutter.dart:ui.textHeightBehavior}
final
ui
.
TextHeightBehavior
textHeightBehavior
;
final
ui
.
TextHeightBehavior
textHeightBehavior
;
final
bool
_applyTextScaleFactorToWidgetSpan
;
@override
@override
RenderParagraph
createRenderObject
(
BuildContext
context
)
{
RenderParagraph
createRenderObject
(
BuildContext
context
)
{
assert
(
textDirection
!=
null
||
debugCheckHasDirectionality
(
context
));
assert
(
textDirection
!=
null
||
debugCheckHasDirectionality
(
context
));
...
@@ -5241,6 +5251,7 @@ class RichText extends MultiChildRenderObjectWidget {
...
@@ -5241,6 +5251,7 @@ class RichText extends MultiChildRenderObjectWidget {
strutStyle:
strutStyle
,
strutStyle:
strutStyle
,
textWidthBasis:
textWidthBasis
,
textWidthBasis:
textWidthBasis
,
textHeightBehavior:
textHeightBehavior
,
textHeightBehavior:
textHeightBehavior
,
applyTextScaleFactorToWidgetSpan:
_applyTextScaleFactorToWidgetSpan
,
locale:
locale
??
Localizations
.
localeOf
(
context
,
nullOk:
true
),
locale:
locale
??
Localizations
.
localeOf
(
context
,
nullOk:
true
),
);
);
}
}
...
...
packages/flutter/lib/src/widgets/text.dart
View file @
3a15841d
...
@@ -361,6 +361,7 @@ class Text extends StatelessWidget {
...
@@ -361,6 +361,7 @@ class Text extends StatelessWidget {
'A non-null String must be provided to a Text widget.'
,
'A non-null String must be provided to a Text widget.'
,
),
),
textSpan
=
null
,
textSpan
=
null
,
_applyTextScaleFactorToWidgetSpan
=
true
,
super
(
key:
key
);
super
(
key:
key
);
/// Creates a text widget with a [InlineSpan].
/// Creates a text widget with a [InlineSpan].
...
@@ -388,11 +389,19 @@ class Text extends StatelessWidget {
...
@@ -388,11 +389,19 @@ class Text extends StatelessWidget {
this
.
semanticsLabel
,
this
.
semanticsLabel
,
this
.
textWidthBasis
,
this
.
textWidthBasis
,
this
.
textHeightBehavior
,
this
.
textHeightBehavior
,
@Deprecated
(
'This parameter is a temporary flag to migrate the internal tests and '
'should not be used in other contexts. For more details, please check '
'https://github.com/flutter/flutter/issues/59316. '
'This feature was deprecated after v1.19.0.'
)
bool
applyTextScaleFactorToWidgetSpan
=
false
,
})
:
assert
(
})
:
assert
(
textSpan
!=
null
,
textSpan
!=
null
,
'A non-null TextSpan must be provided to a Text.rich widget.'
,
'A non-null TextSpan must be provided to a Text.rich widget.'
,
),
),
data
=
null
,
data
=
null
,
_applyTextScaleFactorToWidgetSpan
=
applyTextScaleFactorToWidgetSpan
,
super
(
key:
key
);
super
(
key:
key
);
/// The text to display.
/// The text to display.
...
@@ -493,6 +502,8 @@ class Text extends StatelessWidget {
...
@@ -493,6 +502,8 @@ class Text extends StatelessWidget {
/// {@macro flutter.dart:ui.textHeightBehavior}
/// {@macro flutter.dart:ui.textHeightBehavior}
final
ui
.
TextHeightBehavior
textHeightBehavior
;
final
ui
.
TextHeightBehavior
textHeightBehavior
;
final
bool
_applyTextScaleFactorToWidgetSpan
;
@override
@override
Widget
build
(
BuildContext
context
)
{
Widget
build
(
BuildContext
context
)
{
final
DefaultTextStyle
defaultTextStyle
=
DefaultTextStyle
.
of
(
context
);
final
DefaultTextStyle
defaultTextStyle
=
DefaultTextStyle
.
of
(
context
);
...
@@ -512,6 +523,7 @@ class Text extends StatelessWidget {
...
@@ -512,6 +523,7 @@ class Text extends StatelessWidget {
strutStyle:
strutStyle
,
strutStyle:
strutStyle
,
textWidthBasis:
textWidthBasis
??
defaultTextStyle
.
textWidthBasis
,
textWidthBasis:
textWidthBasis
??
defaultTextStyle
.
textWidthBasis
,
textHeightBehavior:
textHeightBehavior
??
defaultTextStyle
.
textHeightBehavior
??
DefaultTextHeightBehavior
.
of
(
context
),
textHeightBehavior:
textHeightBehavior
??
defaultTextStyle
.
textHeightBehavior
??
DefaultTextHeightBehavior
.
of
(
context
),
applyTextScaleFactorToWidgetSpan:
_applyTextScaleFactorToWidgetSpan
,
text:
TextSpan
(
text:
TextSpan
(
style:
effectiveTextStyle
,
style:
effectiveTextStyle
,
text:
data
,
text:
data
,
...
...
packages/flutter/test/widgets/text_test.dart
View file @
3a15841d
...
@@ -163,6 +163,70 @@ void main() {
...
@@ -163,6 +163,70 @@ void main() {
expect
(
tester
.
takeException
(),
null
);
expect
(
tester
.
takeException
(),
null
);
},
skip:
isBrowser
);
// TODO(yjbanov): https://github.com/flutter/flutter/issues/42086
},
skip:
isBrowser
);
// TODO(yjbanov): https://github.com/flutter/flutter/issues/42086
testWidgets
(
'inline widgets works with textScaleFactor'
,
(
WidgetTester
tester
)
async
{
// Regression test for https://github.com/flutter/flutter/issues/59316
final
UniqueKey
key
=
UniqueKey
();
double
textScaleFactor
=
1.0
;
await
tester
.
pumpWidget
(
MaterialApp
(
home:
Scaffold
(
appBar:
AppBar
(
title:
const
Text
(
'title'
)),
body:
Center
(
child:
Text
.
rich
(
TextSpan
(
children:
<
InlineSpan
>[
WidgetSpan
(
child:
RichText
(
text:
const
TextSpan
(
text:
'widget should be truncated'
),
textDirection:
TextDirection
.
ltr
,
),
),
],
),
key:
key
,
textDirection:
TextDirection
.
ltr
,
textScaleFactor:
textScaleFactor
,
applyTextScaleFactorToWidgetSpan:
true
,
),
),
),
),
);
RenderBox
renderText
=
tester
.
renderObject
(
find
.
byKey
(
key
));
final
double
singleLineHeight
=
renderText
.
size
.
height
;
// Now, increases the text scale factor by 5 times.
textScaleFactor
=
textScaleFactor
*
5
;
await
tester
.
pumpWidget
(
MaterialApp
(
home:
Scaffold
(
appBar:
AppBar
(
title:
const
Text
(
'title'
)),
body:
Center
(
child:
Text
.
rich
(
TextSpan
(
children:
<
InlineSpan
>[
WidgetSpan
(
child:
RichText
(
text:
const
TextSpan
(
text:
'widget should be truncated'
),
textDirection:
TextDirection
.
ltr
,
),
),
],
),
key:
key
,
textDirection:
TextDirection
.
ltr
,
textScaleFactor:
textScaleFactor
,
applyTextScaleFactorToWidgetSpan:
true
,
),
),
),
),
);
renderText
=
tester
.
renderObject
(
find
.
byKey
(
key
));
// The RichText in the widget span should wrap into three lines.
expect
(
renderText
.
size
.
height
,
singleLineHeight
*
textScaleFactor
*
3
);
},
skip:
isBrowser
);
// TODO(yjbanov): https://github.com/flutter/flutter/issues/42086
testWidgets
(
'semanticsLabel can override text label'
,
(
WidgetTester
tester
)
async
{
testWidgets
(
'semanticsLabel can override text label'
,
(
WidgetTester
tester
)
async
{
final
SemanticsTester
semantics
=
SemanticsTester
(
tester
);
final
SemanticsTester
semantics
=
SemanticsTester
(
tester
);
await
tester
.
pumpWidget
(
await
tester
.
pumpWidget
(
...
...
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