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
020e0ef5
Unverified
Commit
020e0ef5
authored
Jun 14, 2018
by
xster
Committed by
GitHub
Jun 14, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Add some more dart doc to RepaintBoundary (#17183)
parent
e593dc70
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
64 additions
and
11 deletions
+64
-11
diagnostics.dart
packages/flutter/lib/src/foundation/diagnostics.dart
+1
-1
debug.dart
packages/flutter/lib/src/rendering/debug.dart
+7
-2
object.dart
packages/flutter/lib/src/rendering/object.dart
+6
-0
basic.dart
packages/flutter/lib/src/widgets/basic.dart
+47
-5
media_query.dart
packages/flutter/lib/src/widgets/media_query.dart
+3
-3
No files found.
packages/flutter/lib/src/foundation/diagnostics.dart
View file @
020e0ef5
...
@@ -743,7 +743,7 @@ abstract class DiagnosticsNode {
...
@@ -743,7 +743,7 @@ abstract class DiagnosticsNode {
String
get
_separator
=>
showSeparator
?
':'
:
''
;
String
get
_separator
=>
showSeparator
?
':'
:
''
;
/// Serialize the node excluding its descend
e
nts to a JSON map.
/// Serialize the node excluding its descend
a
nts to a JSON map.
///
///
/// Subclasses should override if they have additional properties that are
/// Subclasses should override if they have additional properties that are
/// useful for the GUI tools that consume this JSON.
/// useful for the GUI tools that consume this JSON.
...
...
packages/flutter/lib/src/rendering/debug.dart
View file @
020e0ef5
...
@@ -38,6 +38,11 @@ bool debugPaintLayerBordersEnabled = false;
...
@@ -38,6 +38,11 @@ bool debugPaintLayerBordersEnabled = false;
bool
debugPaintPointersEnabled
=
false
;
bool
debugPaintPointersEnabled
=
false
;
/// Overlay a rotating set of colors when repainting layers in checked mode.
/// Overlay a rotating set of colors when repainting layers in checked mode.
///
/// See also:
///
/// * [RepaintBoundary], which can be used to contain repaints when unchanged
/// areas are being excessively repainted.
bool
debugRepaintRainbowEnabled
=
false
;
bool
debugRepaintRainbowEnabled
=
false
;
/// Overlay a rotating set of colors when repainting text in checked mode.
/// Overlay a rotating set of colors when repainting text in checked mode.
...
@@ -103,12 +108,12 @@ bool debugCheckIntrinsicSizes = false;
...
@@ -103,12 +108,12 @@ bool debugCheckIntrinsicSizes = false;
///
///
/// * [debugPrintLayouts], which does something similar for layout but using
/// * [debugPrintLayouts], which does something similar for layout but using
/// console output.
/// console output.
///
/// * [debugProfileBuildsEnabled], which does something similar for widgets
/// * [debugProfileBuildsEnabled], which does something similar for widgets
/// being rebuilt, and [debugPrintRebuildDirtyWidgets], its console
/// being rebuilt, and [debugPrintRebuildDirtyWidgets], its console
/// equivalent.
/// equivalent.
///
/// * The discussion at [RendererBinding.drawFrame].
/// * The discussion at [RendererBinding.drawFrame].
/// * [RepaintBoundary], which can be used to contain repaints when unchanged
/// areas are being excessively repainted.
bool
debugProfilePaintsEnabled
=
false
;
bool
debugProfilePaintsEnabled
=
false
;
/// Setting to true will cause all clipping effects from the layer tree to be
/// Setting to true will cause all clipping effects from the layer tree to be
...
...
packages/flutter/lib/src/rendering/object.dart
View file @
020e0ef5
...
@@ -1871,6 +1871,12 @@ abstract class RenderObject extends AbstractNode with DiagnosticableTreeMixin im
...
@@ -1871,6 +1871,12 @@ abstract class RenderObject extends AbstractNode with DiagnosticableTreeMixin im
/// Once [markNeedsPaint] has been called on a render object,
/// Once [markNeedsPaint] has been called on a render object,
/// [debugNeedsPaint] returns true for that render object until just after
/// [debugNeedsPaint] returns true for that render object until just after
/// the pipeline owner has called [paint] on the render object.
/// the pipeline owner has called [paint] on the render object.
///
/// See also:
///
/// * [RepaintBoundary], to scope a subtree of render objects to their own
/// layer, thus limiting the number of nodes that [markNeedsPaint] must mark
/// dirty.
void
markNeedsPaint
()
{
void
markNeedsPaint
()
{
assert
(
owner
==
null
||
!
owner
.
debugDoingPaint
);
assert
(
owner
==
null
||
!
owner
.
debugDoingPaint
);
if
(
_needsPaint
)
if
(
_needsPaint
)
...
...
packages/flutter/lib/src/widgets/basic.dart
View file @
020e0ef5
...
@@ -4774,11 +4774,53 @@ class Listener extends SingleChildRenderObjectWidget {
...
@@ -4774,11 +4774,53 @@ class Listener extends SingleChildRenderObjectWidget {
///
///
/// This widget creates a separate display list for its child, which
/// This widget creates a separate display list for its child, which
/// can improve performance if the subtree repaints at different times than
/// can improve performance if the subtree repaints at different times than
/// the surrounding parts of the tree. Specifically, when the child does not
/// the surrounding parts of the tree.
/// repaint but its parent does, we can re-use the display list we recorded
///
/// previously. Similarly, when the child repaints but the surround tree does
/// This is useful since [RenderObject.paint] may be triggered even if its
/// not, we can re-record its display list without re-recording the display list
/// associated [Widget] instances did not change or rebuild. A [RenderObject]
/// for the surround tree.
/// will repaint whenever any [RenderObject] that shares the same [Layer] is
/// marked as being dirty and needing paint (see [RenderObject.markNeedsPaint]),
/// such as when an ancestor scrolls or when an ancestor or descendant animates.
///
/// Containing [RenderObject.paint] to parts of the render subtree that are
/// actually visually changing using [RepaintBoundary] explicitly or implicitly
/// is therefore critical to minimizing redundant work and improving the app's
/// performance.
///
/// When a [RenderObject] is flagged as needing to paint via
/// [RenderObject.markNeedsPaint], the nearest ancestor [RenderObject] with
/// [RenderObject.isRepaintBoundary], up to possibly the root of the application,
/// is requested to repaint. That nearest ancestor's [RenderObject.paint] method
/// will cause _all_ of its descendant [RenderObject]s to repaint in the same
/// layer.
///
/// [RepaintBoundary] is therefore used, both while propagating the
/// `markNeedsPaint` flag up the render tree and while traversing down the
/// render tree via [RenderObject.paintChild], to strategically contain repaints
/// to the render subtree that visually changed for performance. This is done
/// because the [RepaintBoundary] widget creates a [RenderObject] that always
/// has a [Layer], decoupling ancestor render objects from the descendant
/// render objects.
///
/// [RepaintBoundary] has the further side-effect of possibly hinting to the
/// engine that it should further optimize animation performance if the render
/// subtree behind the [RepaintBoundary] is sufficiently complex and is static
/// while the surrounding tree changes frequently. In those cases, the engine
/// may choose to pay a one time cost of rasterizing and caching the pixel
/// values of the subtree for faster future GPU re-rendering speed.
///
/// Several framework widgets insert [RepaintBoundary] widgets to mark natural
/// separation points in applications. For instance, contents in Material Design
/// drawers typically don't change while the drawer opens and closes, so
/// repaints are automatically contained to regions inside or outside the drawer
/// when using the [Drawer] widget during transitions.
///
/// See also:
///
/// * [debugRepaintRainbowEnabled], a debugging flag to help visually monitor
/// render tree repaints in a running app.
/// * [debugProfilePaintsEnabled], a debugging flag to show render tree
/// repaints in the observatory's timeline view.
class
RepaintBoundary
extends
SingleChildRenderObjectWidget
{
class
RepaintBoundary
extends
SingleChildRenderObjectWidget
{
/// Creates a widget that isolates repaints.
/// Creates a widget that isolates repaints.
const
RepaintBoundary
({
Key
key
,
Widget
child
})
:
super
(
key:
key
,
child:
child
);
const
RepaintBoundary
({
Key
key
,
Widget
child
})
:
super
(
key:
key
,
child:
child
);
...
...
packages/flutter/lib/src/widgets/media_query.dart
View file @
020e0ef5
...
@@ -98,7 +98,7 @@ class MediaQueryData {
...
@@ -98,7 +98,7 @@ class MediaQueryData {
/// If you consumed this padding (e.g. by building a widget that envelops or
/// If you consumed this padding (e.g. by building a widget that envelops or
/// accounts for this padding in its layout in such a way that children are
/// accounts for this padding in its layout in such a way that children are
/// no longer exposed to this padding), you should remove this padding
/// no longer exposed to this padding), you should remove this padding
/// for subsequent descend
e
nts in the widget tree by inserting a new
/// for subsequent descend
a
nts in the widget tree by inserting a new
/// [MediaQuery] widget using the [MediaQuery.removePadding] factory.
/// [MediaQuery] widget using the [MediaQuery.removePadding] factory.
///
///
/// See also:
/// See also:
...
@@ -283,7 +283,7 @@ class MediaQuery extends InheritedWidget {
...
@@ -283,7 +283,7 @@ class MediaQuery extends InheritedWidget {
///
///
/// This should be inserted into the widget tree when the [MediaQuery] padding
/// This should be inserted into the widget tree when the [MediaQuery] padding
/// is consumed by a widget in such a way that the padding is no longer
/// is consumed by a widget in such a way that the padding is no longer
/// exposed to the widget's descend
e
nts or siblings.
/// exposed to the widget's descend
a
nts or siblings.
///
///
/// The [context] argument is required, must not be null, and must have a
/// The [context] argument is required, must not be null, and must have a
/// [MediaQuery] in scope.
/// [MediaQuery] in scope.
...
@@ -327,7 +327,7 @@ class MediaQuery extends InheritedWidget {
...
@@ -327,7 +327,7 @@ class MediaQuery extends InheritedWidget {
///
///
/// This should be inserted into the widget tree when the [MediaQuery] view
/// This should be inserted into the widget tree when the [MediaQuery] view
/// insets are consumed by a widget in such a way that the view insets are no
/// insets are consumed by a widget in such a way that the view insets are no
/// longer exposed to the widget's descend
e
nts or siblings.
/// longer exposed to the widget's descend
a
nts or siblings.
///
///
/// The [context] argument is required, must not be null, and must have a
/// The [context] argument is required, must not be null, and must have a
/// [MediaQuery] in scope.
/// [MediaQuery] in scope.
...
...
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