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
f4750a7d
Commit
f4750a7d
authored
Jul 28, 2015
by
Adam Barth
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #328 from abarth/schedule_build
Move build() off microtasks
parents
2ed083d2
5d15bb51
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
21 additions
and
9 deletions
+21
-9
sky_binding.dart
packages/flutter/lib/rendering/sky_binding.dart
+2
-2
widget.dart
packages/flutter/lib/widgets/widget.dart
+19
-7
No files found.
packages/flutter/lib/rendering/sky_binding.dart
View file @
f4750a7d
...
...
@@ -47,7 +47,7 @@ class SkyBinding {
_renderView
=
renderViewOverride
;
}
assert
(
_renderView
!=
null
);
scheduler
.
addPersistentFrameCallback
(
_
beginFrame
);
scheduler
.
addPersistentFrameCallback
(
beginFrame
);
assert
(
_instance
==
this
);
}
...
...
@@ -69,7 +69,7 @@ class SkyBinding {
void
set
root
(
RenderBox
value
)
{
_renderView
.
child
=
value
;
}
void
_
beginFrame
(
double
timeStamp
)
{
void
beginFrame
(
double
timeStamp
)
{
RenderObject
.
flushLayout
();
RenderObject
.
flushPaint
();
_renderView
.
paintFrame
();
...
...
packages/flutter/lib/widgets/widget.dart
View file @
f4750a7d
...
...
@@ -7,6 +7,7 @@ import 'dart:collection';
import
'dart:sky'
as
sky
;
import
'package:sky/base/hit_test.dart'
;
import
'package:sky/base/scheduler.dart'
as
scheduler
;
import
'package:sky/mojo/activity.dart'
as
activity
;
import
'package:sky/rendering/box.dart'
;
import
'package:sky/rendering/object.dart'
;
...
...
@@ -651,6 +652,11 @@ abstract class Component extends Widget {
_scheduleComponentForRender
(
this
);
}
static
void
flushBuild
()
{
if
(!
_dirtyComponents
.
isEmpty
)
_buildDirtyComponents
();
}
Widget
build
();
}
...
...
@@ -759,13 +765,15 @@ void _absorbDirtyComponents(List<Component> list) {
}
void
_buildDirtyComponents
(
)
{
assert
(!
_dirtyComponents
.
isEmpty
);
Stopwatch
sw
;
if
(
_shouldLogRenderDuration
)
sw
=
new
Stopwatch
()..
start
();
_inRenderDirtyComponents
=
true
;
try
{
sky
.
tracing
.
begin
(
'
Widgets._buildDirtyComponents
'
);
sky
.
tracing
.
begin
(
'
Component.flushBuild
'
);
List
<
Component
>
sortedDirtyComponents
=
new
List
<
Component
>();
_absorbDirtyComponents
(
sortedDirtyComponents
);
int
index
=
0
;
...
...
@@ -784,7 +792,7 @@ void _buildDirtyComponents() {
}
finally
{
_buildScheduled
=
false
;
_inRenderDirtyComponents
=
false
;
sky
.
tracing
.
end
(
'
Widgets._buildDirtyComponents
'
);
sky
.
tracing
.
end
(
'
Component.flushBuild
'
);
}
Widget
.
_notifyMountStatusChanged
();
...
...
@@ -795,21 +803,20 @@ void _buildDirtyComponents() {
if
(
_debugFrameTimes
.
length
>=
1000
)
{
_debugFrameTimes
.
sort
();
const
int
i
=
99
;
print
(
'
_buildDirtyComponents
:
${i+1}
th fastest frame out of the last
${_debugFrameTimes.length}
:
${_debugFrameTimes[i]}
microseconds'
);
print
(
'
Component.flushBuild
:
${i+1}
th fastest frame out of the last
${_debugFrameTimes.length}
:
${_debugFrameTimes[i]}
microseconds'
);
_debugFrameTimes
.
clear
();
}
}
}
void
_scheduleComponentForRender
(
Component
c
)
{
_dirtyComponents
.
add
(
c
);
void
_scheduleComponentForRender
(
Component
c
omponent
)
{
_dirtyComponents
.
add
(
c
omponent
);
if
(!
_buildScheduled
)
{
_buildScheduled
=
true
;
new
Future
.
microtask
(
_buildDirtyComponents
);
scheduler
.
ensureVisualUpdate
(
);
}
}
// RenderObjectWrappers correspond to a desired state of a RenderObject.
// They are fully immutable, with one exception: A Widget which is a
// Component which lives within an MultiChildRenderObjectWrapper's
...
...
@@ -1178,6 +1185,11 @@ class WidgetSkyBinding extends SkyBinding {
}
}
void
beginFrame
(
double
timeStamp
)
{
Component
.
flushBuild
();
super
.
beginFrame
(
timeStamp
);
}
}
abstract
class
App
extends
StatefulComponent
{
...
...
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