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
dc7137b0
Commit
dc7137b0
authored
Aug 22, 2015
by
Adam Barth
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #763 from abarth/scroll_gravity
Cleanup how we manage scrollOffset in Scrollable
parents
ca42e886
d3eaff27
Changes
3
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
73 additions
and
77 deletions
+73
-77
scroll_behavior.dart
packages/flutter/lib/animation/scroll_behavior.dart
+23
-22
scrollable.dart
packages/flutter/lib/widgets/scrollable.dart
+46
-52
tabs.dart
packages/flutter/lib/widgets/tabs.dart
+4
-3
No files found.
packages/flutter/lib/animation/scroll_behavior.dart
View file @
dc7137b0
...
...
@@ -17,32 +17,33 @@ abstract class ScrollBehavior {
class
BoundedBehavior
extends
ScrollBehavior
{
BoundedBehavior
({
double
contentsSize:
0.0
,
double
containerSize:
0.0
})
:
_contentsSize
=
contentsSize
,
_containerSize
=
containerSize
;
double
_contentsSize
;
double
get
contentsSize
=>
_contentsSize
;
void
set
contentsSize
(
double
value
)
{
if
(
_contentsSize
!=
value
)
{
_contentsSize
=
value
;
// TODO(ianh) now what? what if we have a simulation ongoing?
}
}
double
_containerSize
;
double
get
containerSize
=>
_containerSize
;
void
set
containerSize
(
double
value
)
{
if
(
_containerSize
!=
value
)
{
_containerSize
=
value
;
// TODO(ianh) now what? what if we have a simulation ongoing?
}
:
_contentsExtents
=
contentsSize
,
_containerExtents
=
containerSize
;
double
_contentsExtents
;
double
get
contentsExtents
=>
_contentsExtents
;
double
_containerExtents
;
double
get
containerExtents
=>
_containerExtents
;
/// Returns the new scrollOffset.
double
updateExtents
({
double
contentsExtents
,
double
containerExtents
,
double
scrollOffset:
0.0
})
{
if
(
contentsExtents
!=
null
)
_contentsExtents
=
contentsExtents
;
if
(
containerExtents
!=
null
)
_containerExtents
=
containerExtents
;
return
scrollOffset
.
clamp
(
minScrollOffset
,
maxScrollOffset
);
}
final
double
minScrollOffset
=
0.0
;
double
get
maxScrollOffset
=>
math
.
max
(
0.0
,
_contents
Size
-
_containerSize
);
double
get
maxScrollOffset
=>
math
.
max
(
0.0
,
_contents
Extents
-
_containerExtents
);
double
applyCurve
(
double
scrollOffset
,
double
scrollDelta
)
{
return
(
scrollOffset
+
scrollDelta
).
clamp
(
0.0
,
maxScrollOffset
);
return
(
scrollOffset
+
scrollDelta
).
clamp
(
minScrollOffset
,
maxScrollOffset
);
}
}
...
...
@@ -80,7 +81,7 @@ class OverscrollBehavior extends BoundedBehavior {
}
class
OverscrollWhenScrollableBehavior
extends
OverscrollBehavior
{
bool
get
isScrollable
=>
contents
Size
>
containerSize
;
bool
get
isScrollable
=>
contents
Extents
>
containerExtents
;
Simulation
release
(
double
position
,
double
velocity
)
{
if
(
isScrollable
||
position
<
minScrollOffset
||
position
>
maxScrollOffset
)
...
...
packages/flutter/lib/widgets/scrollable.dart
View file @
dc7137b0
...
...
@@ -22,7 +22,6 @@ import 'package:sky/widgets/scrollable.dart';
export
'package:sky/widgets/mixed_viewport.dart'
show
MixedViewportLayoutState
;
// The GestureEvent velocity properties are pixels/second, config min,max limits are pixels/ms
const
double
_kMillisecondsPerSecond
=
1000.0
;
const
double
_kMinFlingVelocity
=
-
config
.
kMaxFlingVelocity
*
_kMillisecondsPerSecond
;
...
...
@@ -48,11 +47,11 @@ abstract class Scrollable extends StatefulComponent {
ValueAnimation
<
double
>
_toOffsetAnimation
;
// Started by scrollTo()
void
initState
()
{
_toEndAnimation
=
new
AnimatedSimulation
(
_
tick
ScrollOffset
);
_toEndAnimation
=
new
AnimatedSimulation
(
_
set
ScrollOffset
);
_toOffsetAnimation
=
new
ValueAnimation
<
double
>()
..
addListener
(()
{
AnimatedValue
<
double
>
offset
=
_toOffsetAnimation
.
variable
;
scrollTo
(
offset
.
value
);
_setScrollOffset
(
offset
.
value
);
});
}
...
...
@@ -93,8 +92,7 @@ abstract class Scrollable extends StatefulComponent {
}
Future
_startToOffsetAnimation
(
double
newScrollOffset
,
Duration
duration
,
Curve
curve
)
{
_stopToEndAnimation
();
_stopToOffsetAnimation
();
_stopAnimations
();
_toOffsetAnimation
..
variable
=
new
AnimatedValue
<
double
>(
scrollOffset
,
end:
newScrollOffset
,
...
...
@@ -105,47 +103,46 @@ abstract class Scrollable extends StatefulComponent {
return
_toOffsetAnimation
.
play
();
}
void
_stop
ToOffsetAnimation
()
{
void
_stop
Animations
()
{
if
(
_toOffsetAnimation
.
isAnimating
)
_toOffsetAnimation
.
stop
();
if
(
_toEndAnimation
.
isAnimating
)
_toEndAnimation
.
stop
();
}
void
_startToEndAnimation
({
double
velocity:
0.0
})
{
_stopToEndAnimation
();
_stopToOffsetAnimation
();
_stopAnimations
();
Simulation
simulation
=
scrollBehavior
.
release
(
scrollOffset
,
velocity
);
if
(
simulation
!=
null
)
_toEndAnimation
.
start
(
simulation
);
}
void
_stopToEndAnimation
()
{
_toEndAnimation
.
stop
();
}
void
didUnmount
()
{
_stopToEndAnimation
();
_stopToOffsetAnimation
();
_stopAnimations
();
super
.
didUnmount
();
}
void
_setScrollOffset
(
double
newScrollOffset
)
{
if
(
_scrollOffset
==
newScrollOffset
)
return
;
setState
(()
{
_scrollOffset
=
newScrollOffset
;
});
if
(
_listeners
.
length
>
0
)
_notifyListeners
();
}
Future
scrollTo
(
double
newScrollOffset
,
{
Duration
duration
,
Curve
curve:
ease
})
{
if
(
newScrollOffset
==
_scrollOffset
)
return
new
Future
.
value
();
Future
result
;
if
(
duration
==
null
)
{
setState
(()
{
_scrollOffset
=
newScrollOffset
;
});
result
=
new
Future
.
value
();
}
else
{
result
=
_startToOffsetAnimation
(
newScrollOffset
,
duration
,
curve
);
_stopAnimations
();
_setScrollOffset
(
newScrollOffset
);
return
new
Future
.
value
();
}
if
(
_listeners
.
length
>
0
)
_notifyListeners
();
return
result
;
return
_startToOffsetAnimation
(
newScrollOffset
,
duration
,
curve
);
}
Future
scrollBy
(
double
scrollDelta
,
{
Duration
duration
,
Curve
curve
})
{
...
...
@@ -157,10 +154,6 @@ abstract class Scrollable extends StatefulComponent {
_startToEndAnimation
();
}
void
_tickScrollOffset
(
double
value
)
{
scrollTo
(
value
);
}
// Return the event's velocity in pixels/second.
double
_eventVelocity
(
sky
.
GestureEvent
event
)
{
double
velocity
=
scrollDirection
==
ScrollDirection
.
horizontal
...
...
@@ -170,8 +163,7 @@ abstract class Scrollable extends StatefulComponent {
}
EventDisposition
_handlePointerDown
(
_
)
{
_stopToEndAnimation
();
_stopToOffsetAnimation
();
_stopAnimations
();
return
EventDisposition
.
processed
;
}
...
...
@@ -293,10 +285,10 @@ class ScrollableViewport extends Scrollable {
_updateScrollBehaviour
();
}
void
_updateScrollBehaviour
()
{
scroll
Behavior
.
contentsSize
=
_childSize
;
scrollBehavior
.
containerSize
=
_viewportSize
;
if
(
scrollOffset
>
scrollBehavior
.
maxScrollOffset
)
s
ettleScrollOffset
(
);
scroll
To
(
scrollBehavior
.
updateExtents
(
contentsExtents:
_childSize
,
containerExtents:
_viewportSize
,
s
crollOffset:
scrollOffset
)
);
}
Widget
buildContent
()
{
...
...
@@ -375,6 +367,11 @@ abstract class ScrollableWidgetList extends Scrollable {
itemExtent
=
source
.
itemExtent
;
super
.
syncFields
(
source
);
// update scrollDirection
if
(
itemCount
!=
_previousItemCount
)
{
scrollBehaviorUpdateNeeded
=
true
;
_previousItemCount
=
itemCount
;
}
if
(
scrollBehaviorUpdateNeeded
)
_updateScrollBehavior
();
}
...
...
@@ -416,17 +413,14 @@ abstract class ScrollableWidgetList extends Scrollable {
}
void
_updateScrollBehavior
()
{
scrollBehavior
.
containerSize
=
_containerExtent
;
double
contentsExtent
=
itemExtent
*
itemCount
;
if
(
padding
!=
null
)
contentsExtent
+=
_leadingPadding
+
_trailingPadding
;
scrollBehavior
.
contentsSize
=
contentsExtent
;
}
void
_updateScrollOffset
()
{
if
(
scrollOffset
>
scrollBehavior
.
maxScrollOffset
)
settleScrollOffset
();
scrollTo
(
scrollBehavior
.
updateExtents
(
contentsExtents:
contentsExtent
,
containerExtents:
_containerExtent
,
scrollOffset:
scrollOffset
));
}
Offset
_toOffset
(
double
value
)
{
...
...
@@ -439,7 +433,6 @@ abstract class ScrollableWidgetList extends Scrollable {
if
(
itemCount
!=
_previousItemCount
)
{
_previousItemCount
=
itemCount
;
_updateScrollBehavior
();
_updateScrollOffset
();
}
double
paddedScrollOffset
=
scrollOffset
;
...
...
@@ -643,18 +636,19 @@ class ScrollableMixedWidgetList extends Scrollable {
OverscrollBehavior
get
scrollBehavior
=>
super
.
scrollBehavior
;
void
_handleSizeChanged
(
Size
newSize
)
{
scrollBehavior
.
containerSize
=
newSize
.
height
;
scrollBy
(
scrollBehavior
.
updateExtents
(
containerExtents:
newSize
.
height
,
scrollOffset:
scrollOffset
));
}
void
_handleLayoutChanged
()
{
if
(
layoutState
.
didReachLastChild
)
{
scrollBehavior
.
contentsSize
=
layoutState
.
contentsSize
;
if
(
_contentsChanged
&&
scrollOffset
>
scrollBehavior
.
maxScrollOffset
)
{
_contentsChanged
=
false
;
settleScrollOffset
();
}
}
else
{
scrollBehavior
.
contentsSize
=
double
.
INFINITY
;
double
newScrollOffset
=
scrollBehavior
.
updateExtents
(
contentsExtents:
layoutState
.
didReachLastChild
?
layoutState
.
contentsSize
:
double
.
INFINITY
,
scrollOffset:
scrollOffset
);
if
(
_contentsChanged
)
{
_contentsChanged
=
false
;
scrollTo
(
newScrollOffset
);
}
}
...
...
packages/flutter/lib/widgets/tabs.dart
View file @
dc7137b0
...
...
@@ -460,7 +460,7 @@ class TabBar extends Scrollable {
}
double
_centeredTabScrollOffset
(
int
tabIndex
)
{
double
viewportWidth
=
scrollBehavior
.
container
Size
;
double
viewportWidth
=
scrollBehavior
.
container
Extents
;
return
(
_tabRect
(
tabIndex
).
left
+
_tabWidths
[
tabIndex
]
/
2.0
-
viewportWidth
/
2.0
)
.
clamp
(
scrollBehavior
.
minScrollOffset
,
scrollBehavior
.
maxScrollOffset
);
}
...
...
@@ -495,8 +495,9 @@ class TabBar extends Scrollable {
setState
(()
{
_tabBarSize
=
tabBarSize
;
_tabWidths
=
tabWidths
;
scrollBehavior
.
containerSize
=
_tabBarSize
.
width
;
scrollBehavior
.
contentsSize
=
_tabWidths
.
reduce
((
sum
,
width
)
=>
sum
+
width
);
scrollBehavior
.
updateExtents
(
containerExtents:
_tabBarSize
.
width
,
contentsExtents:
_tabWidths
.
reduce
((
sum
,
width
)
=>
sum
+
width
));
});
}
...
...
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