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
18e512d3
Commit
18e512d3
authored
Sep 04, 2015
by
Hans Muller
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Replace Scroll with Drag in names in GestureRecognizer et al
parent
e6d48ac5
Changes
6
Hide whitespace changes
Inline
Side-by-side
Showing
6 changed files
with
144 additions
and
142 deletions
+144
-142
scroll.dart
packages/flutter/lib/gestures/scroll.dart
+51
-51
dismissable.dart
packages/flutter/lib/src/widgets/dismissable.dart
+9
-9
gesture_detector.dart
packages/flutter/lib/src/widgets/gesture_detector.dart
+50
-50
scrollable.dart
packages/flutter/lib/src/widgets/scrollable.dart
+4
-4
dismissable_test.dart
packages/unit/test/widget/dismissable_test.dart
+2
-0
gesture_detector_test.dart
packages/unit/test/widget/gesture_detector_test.dart
+28
-28
No files found.
packages/flutter/lib/gestures/scroll.dart
View file @
18e512d3
...
@@ -8,15 +8,15 @@ import 'package:sky/gestures/arena.dart';
...
@@ -8,15 +8,15 @@ import 'package:sky/gestures/arena.dart';
import
'package:sky/gestures/recognizer.dart'
;
import
'package:sky/gestures/recognizer.dart'
;
import
'package:sky/gestures/constants.dart'
;
import
'package:sky/gestures/constants.dart'
;
enum
Scroll
State
{
enum
Drag
State
{
ready
,
ready
,
possible
,
possible
,
accepted
accepted
}
}
typedef
void
Gesture
Scroll
StartCallback
(
);
typedef
void
Gesture
Drag
StartCallback
(
);
typedef
void
Gesture
Scroll
UpdateCallback
(
double
scrollDelta
);
typedef
void
Gesture
Drag
UpdateCallback
(
double
scrollDelta
);
typedef
void
Gesture
Scroll
EndCallback
(
);
typedef
void
Gesture
Drag
EndCallback
(
);
typedef
void
GesturePanStartCallback
(
);
typedef
void
GesturePanStartCallback
(
);
typedef
void
GesturePanUpdateCallback
(
sky
.
Offset
scrollDelta
);
typedef
void
GesturePanUpdateCallback
(
sky
.
Offset
scrollDelta
);
...
@@ -24,39 +24,39 @@ typedef void GesturePanEndCallback();
...
@@ -24,39 +24,39 @@ typedef void GesturePanEndCallback();
typedef
void
_GesturePolymorphicUpdateCallback
<
T
>(
T
scrollDelta
);
typedef
void
_GesturePolymorphicUpdateCallback
<
T
>(
T
scrollDelta
);
abstract
class
_
Scroll
GestureRecognizer
<
T
extends
dynamic
>
extends
GestureRecognizer
{
abstract
class
_
Drag
GestureRecognizer
<
T
extends
dynamic
>
extends
GestureRecognizer
{
_
Scroll
GestureRecognizer
({
PointerRouter
router
,
this
.
onStart
,
this
.
onUpdate
,
this
.
onEnd
})
_
Drag
GestureRecognizer
({
PointerRouter
router
,
this
.
onStart
,
this
.
onUpdate
,
this
.
onEnd
})
:
super
(
router:
router
);
:
super
(
router:
router
);
Gesture
Scroll
StartCallback
onStart
;
Gesture
Drag
StartCallback
onStart
;
_GesturePolymorphicUpdateCallback
<
T
>
onUpdate
;
_GesturePolymorphicUpdateCallback
<
T
>
onUpdate
;
Gesture
Scroll
EndCallback
onEnd
;
Gesture
Drag
EndCallback
onEnd
;
ScrollState
_state
=
Scroll
State
.
ready
;
DragState
_state
=
Drag
State
.
ready
;
T
_pending
Scroll
Delta
;
T
_pending
Drag
Delta
;
T
get
_initialPending
Scroll
Delta
;
T
get
_initialPending
Drag
Delta
;
T
_get
Scroll
Delta
(
sky
.
PointerEvent
event
);
T
_get
Drag
Delta
(
sky
.
PointerEvent
event
);
bool
get
_hasSufficientPending
Scroll
DeltaToAccept
;
bool
get
_hasSufficientPending
Drag
DeltaToAccept
;
void
addPointer
(
sky
.
PointerEvent
event
)
{
void
addPointer
(
sky
.
PointerEvent
event
)
{
startTrackingPointer
(
event
.
pointer
);
startTrackingPointer
(
event
.
pointer
);
if
(
_state
==
Scroll
State
.
ready
)
{
if
(
_state
==
Drag
State
.
ready
)
{
_state
=
Scroll
State
.
possible
;
_state
=
Drag
State
.
possible
;
_pending
ScrollDelta
=
_initialPendingScroll
Delta
;
_pending
DragDelta
=
_initialPendingDrag
Delta
;
}
}
}
}
void
handleEvent
(
sky
.
PointerEvent
event
)
{
void
handleEvent
(
sky
.
PointerEvent
event
)
{
assert
(
_state
!=
Scroll
State
.
ready
);
assert
(
_state
!=
Drag
State
.
ready
);
if
(
event
.
type
==
'pointermove'
)
{
if
(
event
.
type
==
'pointermove'
)
{
T
delta
=
_get
Scroll
Delta
(
event
);
T
delta
=
_get
Drag
Delta
(
event
);
if
(
_state
==
Scroll
State
.
accepted
)
{
if
(
_state
==
Drag
State
.
accepted
)
{
if
(
onUpdate
!=
null
)
if
(
onUpdate
!=
null
)
onUpdate
(
delta
);
onUpdate
(
delta
);
}
else
{
}
else
{
_pending
Scroll
Delta
+=
delta
;
_pending
Drag
Delta
+=
delta
;
if
(
_hasSufficientPending
Scroll
DeltaToAccept
)
if
(
_hasSufficientPending
Drag
DeltaToAccept
)
resolve
(
GestureDisposition
.
accepted
);
resolve
(
GestureDisposition
.
accepted
);
}
}
}
}
...
@@ -64,58 +64,58 @@ abstract class _ScrollGestureRecognizer<T extends dynamic> extends GestureRecogn
...
@@ -64,58 +64,58 @@ abstract class _ScrollGestureRecognizer<T extends dynamic> extends GestureRecogn
}
}
void
acceptGesture
(
int
pointer
)
{
void
acceptGesture
(
int
pointer
)
{
if
(
_state
!=
Scroll
State
.
accepted
)
{
if
(
_state
!=
Drag
State
.
accepted
)
{
_state
=
Scroll
State
.
accepted
;
_state
=
Drag
State
.
accepted
;
T
delta
=
_pending
Scroll
Delta
;
T
delta
=
_pending
Drag
Delta
;
_pending
Scroll
Delta
=
null
;
_pending
Drag
Delta
=
null
;
if
(
onStart
!=
null
)
if
(
onStart
!=
null
)
onStart
();
onStart
();
if
(
delta
!=
_initialPending
Scroll
Delta
&&
onUpdate
!=
null
)
if
(
delta
!=
_initialPending
Drag
Delta
&&
onUpdate
!=
null
)
onUpdate
(
delta
);
onUpdate
(
delta
);
}
}
}
}
void
didStopTrackingLastPointer
()
{
void
didStopTrackingLastPointer
()
{
if
(
_state
==
Scroll
State
.
possible
)
{
if
(
_state
==
Drag
State
.
possible
)
{
resolve
(
GestureDisposition
.
rejected
);
resolve
(
GestureDisposition
.
rejected
);
_state
=
Scroll
State
.
ready
;
_state
=
Drag
State
.
ready
;
return
;
return
;
}
}
bool
wasAccepted
=
(
_state
==
Scroll
State
.
accepted
);
bool
wasAccepted
=
(
_state
==
Drag
State
.
accepted
);
_state
=
Scroll
State
.
ready
;
_state
=
Drag
State
.
ready
;
if
(
wasAccepted
&&
onEnd
!=
null
)
if
(
wasAccepted
&&
onEnd
!=
null
)
onEnd
();
onEnd
();
}
}
}
}
class
Vertical
ScrollGestureRecognizer
extends
_Scroll
GestureRecognizer
<
double
>
{
class
Vertical
DragGestureRecognizer
extends
_Drag
GestureRecognizer
<
double
>
{
Vertical
Scroll
GestureRecognizer
({
Vertical
Drag
GestureRecognizer
({
PointerRouter
router
,
PointerRouter
router
,
Gesture
Scroll
StartCallback
onStart
,
Gesture
Drag
StartCallback
onStart
,
Gesture
Scroll
UpdateCallback
onUpdate
,
Gesture
Drag
UpdateCallback
onUpdate
,
Gesture
Scroll
EndCallback
onEnd
Gesture
Drag
EndCallback
onEnd
})
:
super
(
router:
router
,
onStart:
onStart
,
onUpdate:
onUpdate
,
onEnd:
onEnd
);
})
:
super
(
router:
router
,
onStart:
onStart
,
onUpdate:
onUpdate
,
onEnd:
onEnd
);
double
get
_initialPending
Scroll
Delta
=>
0.0
;
double
get
_initialPending
Drag
Delta
=>
0.0
;
// Notice that we negate dy because scroll offsets go in the opposite direction.
// Notice that we negate dy because scroll offsets go in the opposite direction.
double
_get
Scroll
Delta
(
sky
.
PointerEvent
event
)
=>
-
event
.
dy
;
double
_get
Drag
Delta
(
sky
.
PointerEvent
event
)
=>
-
event
.
dy
;
bool
get
_hasSufficientPending
ScrollDeltaToAccept
=>
_pendingScroll
Delta
.
abs
()
>
kTouchSlop
;
bool
get
_hasSufficientPending
DragDeltaToAccept
=>
_pendingDrag
Delta
.
abs
()
>
kTouchSlop
;
}
}
class
Horizontal
ScrollGestureRecognizer
extends
_Scroll
GestureRecognizer
<
double
>
{
class
Horizontal
DragGestureRecognizer
extends
_Drag
GestureRecognizer
<
double
>
{
Horizontal
Scroll
GestureRecognizer
({
Horizontal
Drag
GestureRecognizer
({
PointerRouter
router
,
PointerRouter
router
,
Gesture
Scroll
StartCallback
onStart
,
Gesture
Drag
StartCallback
onStart
,
Gesture
Scroll
UpdateCallback
onUpdate
,
Gesture
Drag
UpdateCallback
onUpdate
,
Gesture
Scroll
EndCallback
onEnd
Gesture
Drag
EndCallback
onEnd
})
:
super
(
router:
router
,
onStart:
onStart
,
onUpdate:
onUpdate
,
onEnd:
onEnd
);
})
:
super
(
router:
router
,
onStart:
onStart
,
onUpdate:
onUpdate
,
onEnd:
onEnd
);
double
get
_initialPending
Scroll
Delta
=>
0.0
;
double
get
_initialPending
Drag
Delta
=>
0.0
;
double
_get
Scroll
Delta
(
sky
.
PointerEvent
event
)
=>
-
event
.
dx
;
double
_get
Drag
Delta
(
sky
.
PointerEvent
event
)
=>
-
event
.
dx
;
bool
get
_hasSufficientPending
ScrollDeltaToAccept
=>
_pendingScroll
Delta
.
abs
()
>
kTouchSlop
;
bool
get
_hasSufficientPending
DragDeltaToAccept
=>
_pendingDrag
Delta
.
abs
()
>
kTouchSlop
;
}
}
class
PanGestureRecognizer
extends
_
Scroll
GestureRecognizer
<
sky
.
Offset
>
{
class
PanGestureRecognizer
extends
_
Drag
GestureRecognizer
<
sky
.
Offset
>
{
PanGestureRecognizer
({
PanGestureRecognizer
({
PointerRouter
router
,
PointerRouter
router
,
GesturePanStartCallback
onStart
,
GesturePanStartCallback
onStart
,
...
@@ -123,10 +123,10 @@ class PanGestureRecognizer extends _ScrollGestureRecognizer<sky.Offset> {
...
@@ -123,10 +123,10 @@ class PanGestureRecognizer extends _ScrollGestureRecognizer<sky.Offset> {
GesturePanEndCallback
onEnd
GesturePanEndCallback
onEnd
})
:
super
(
router:
router
,
onStart:
onStart
,
onUpdate:
onUpdate
,
onEnd:
onEnd
);
})
:
super
(
router:
router
,
onStart:
onStart
,
onUpdate:
onUpdate
,
onEnd:
onEnd
);
sky
.
Offset
get
_initialPending
Scroll
Delta
=>
sky
.
Offset
.
zero
;
sky
.
Offset
get
_initialPending
Drag
Delta
=>
sky
.
Offset
.
zero
;
// Notice that we negate dy because scroll offsets go in the opposite direction.
// Notice that we negate dy because scroll offsets go in the opposite direction.
sky
.
Offset
_get
Scroll
Delta
(
sky
.
PointerEvent
event
)
=>
new
sky
.
Offset
(
event
.
dx
,
-
event
.
dy
);
sky
.
Offset
_get
Drag
Delta
(
sky
.
PointerEvent
event
)
=>
new
sky
.
Offset
(
event
.
dx
,
-
event
.
dy
);
bool
get
_hasSufficientPending
Scroll
DeltaToAccept
{
bool
get
_hasSufficientPending
Drag
DeltaToAccept
{
return
_pending
ScrollDelta
.
dx
.
abs
()
>
kTouchSlop
||
_pendingScroll
Delta
.
dy
.
abs
()
>
kTouchSlop
;
return
_pending
DragDelta
.
dx
.
abs
()
>
kTouchSlop
||
_pendingDrag
Delta
.
dy
.
abs
()
>
kTouchSlop
;
}
}
}
}
packages/flutter/lib/src/widgets/dismissable.dart
View file @
18e512d3
...
@@ -119,7 +119,7 @@ class Dismissable extends StatefulComponent {
...
@@ -119,7 +119,7 @@ class Dismissable extends StatefulComponent {
_maybeCallOnResized
();
_maybeCallOnResized
();
}
}
void
_handle
Scroll
Start
()
{
void
_handle
Drag
Start
()
{
if
(
_fadePerformance
.
isAnimating
)
if
(
_fadePerformance
.
isAnimating
)
return
;
return
;
_dragUnderway
=
true
;
_dragUnderway
=
true
;
...
@@ -127,7 +127,7 @@ class Dismissable extends StatefulComponent {
...
@@ -127,7 +127,7 @@ class Dismissable extends StatefulComponent {
_fadePerformance
.
progress
=
0.0
;
_fadePerformance
.
progress
=
0.0
;
}
}
void
_handle
Scroll
Update
(
double
scrollOffset
)
{
void
_handle
Drag
Update
(
double
scrollOffset
)
{
if
(!
_isActive
||
_fadePerformance
.
isAnimating
)
if
(!
_isActive
||
_fadePerformance
.
isAnimating
)
return
;
return
;
...
@@ -157,7 +157,7 @@ class Dismissable extends StatefulComponent {
...
@@ -157,7 +157,7 @@ class Dismissable extends StatefulComponent {
_fadePerformance
.
progress
=
_dragExtent
.
abs
()
/
(
_size
.
width
*
_kDismissCardThreshold
);
_fadePerformance
.
progress
=
_dragExtent
.
abs
()
/
(
_size
.
width
*
_kDismissCardThreshold
);
}
}
_handle
Scroll
End
()
{
_handle
Drag
End
()
{
if
(!
_isActive
||
_fadePerformance
.
isAnimating
)
if
(!
_isActive
||
_fadePerformance
.
isAnimating
)
return
;
return
;
_dragUnderway
=
false
;
_dragUnderway
=
false
;
...
@@ -238,12 +238,12 @@ class Dismissable extends StatefulComponent {
...
@@ -238,12 +238,12 @@ class Dismissable extends StatefulComponent {
}
}
return
new
GestureDetector
(
return
new
GestureDetector
(
onHorizontal
ScrollStart:
_directionIsYAxis
?
null
:
_handleScroll
Start
,
onHorizontal
DragStart:
_directionIsYAxis
?
null
:
_handleDrag
Start
,
onHorizontal
ScrollUpdate:
_directionIsYAxis
?
null
:
_handleScroll
Update
,
onHorizontal
DragUpdate:
_directionIsYAxis
?
null
:
_handleDrag
Update
,
onHorizontal
ScrollEnd:
_directionIsYAxis
?
null
:
_handleScroll
End
,
onHorizontal
DragEnd:
_directionIsYAxis
?
null
:
_handleDrag
End
,
onVertical
ScrollStart:
_directionIsYAxis
?
_handleScroll
Start
:
null
,
onVertical
DragStart:
_directionIsYAxis
?
_handleDrag
Start
:
null
,
onVertical
ScrollUpdate:
_directionIsYAxis
?
_handleScroll
Update
:
null
,
onVertical
DragUpdate:
_directionIsYAxis
?
_handleDrag
Update
:
null
,
onVertical
ScrollEnd:
_directionIsYAxis
?
_handleScroll
End
:
null
,
onVertical
DragEnd:
_directionIsYAxis
?
_handleDrag
End
:
null
,
child:
new
Listener
(
child:
new
Listener
(
onGestureFlingStart:
_handleFlingStart
,
onGestureFlingStart:
_handleFlingStart
,
child:
new
SizeObserver
(
child:
new
SizeObserver
(
...
...
packages/flutter/lib/src/widgets/gesture_detector.dart
View file @
18e512d3
...
@@ -19,12 +19,12 @@ class GestureDetector extends StatefulComponent {
...
@@ -19,12 +19,12 @@ class GestureDetector extends StatefulComponent {
this
.
onTap
,
this
.
onTap
,
this
.
onShowPress
,
this
.
onShowPress
,
this
.
onLongPress
,
this
.
onLongPress
,
this
.
onVertical
Scroll
Start
,
this
.
onVertical
Drag
Start
,
this
.
onVertical
Scroll
Update
,
this
.
onVertical
Drag
Update
,
this
.
onVertical
Scroll
End
,
this
.
onVertical
Drag
End
,
this
.
onHorizontal
Scroll
Start
,
this
.
onHorizontal
Drag
Start
,
this
.
onHorizontal
Scroll
Update
,
this
.
onHorizontal
Drag
Update
,
this
.
onHorizontal
Scroll
End
,
this
.
onHorizontal
Drag
End
,
this
.
onPanStart
,
this
.
onPanStart
,
this
.
onPanUpdate
,
this
.
onPanUpdate
,
this
.
onPanEnd
this
.
onPanEnd
...
@@ -35,13 +35,13 @@ class GestureDetector extends StatefulComponent {
...
@@ -35,13 +35,13 @@ class GestureDetector extends StatefulComponent {
GestureShowPressListener
onShowPress
;
GestureShowPressListener
onShowPress
;
GestureLongPressListener
onLongPress
;
GestureLongPressListener
onLongPress
;
Gesture
ScrollStartCallback
onVerticalScroll
Start
;
Gesture
DragStartCallback
onVerticalDrag
Start
;
Gesture
ScrollUpdateCallback
onVerticalScroll
Update
;
Gesture
DragUpdateCallback
onVerticalDrag
Update
;
Gesture
ScrollEndCallback
onVerticalScroll
End
;
Gesture
DragEndCallback
onVerticalDrag
End
;
Gesture
ScrollStartCallback
onHorizontalScroll
Start
;
Gesture
DragStartCallback
onHorizontalDrag
Start
;
Gesture
ScrollUpdateCallback
onHorizontalScroll
Update
;
Gesture
DragUpdateCallback
onHorizontalDrag
Update
;
Gesture
ScrollEndCallback
onHorizontalScroll
End
;
Gesture
DragEndCallback
onHorizontalDrag
End
;
GesturePanStartCallback
onPanStart
;
GesturePanStartCallback
onPanStart
;
GesturePanUpdateCallback
onPanUpdate
;
GesturePanUpdateCallback
onPanUpdate
;
...
@@ -52,12 +52,12 @@ class GestureDetector extends StatefulComponent {
...
@@ -52,12 +52,12 @@ class GestureDetector extends StatefulComponent {
onTap
=
source
.
onTap
;
onTap
=
source
.
onTap
;
onShowPress
=
source
.
onShowPress
;
onShowPress
=
source
.
onShowPress
;
onLongPress
=
source
.
onLongPress
;
onLongPress
=
source
.
onLongPress
;
onVertical
ScrollStart
=
source
.
onVerticalScroll
Start
;
onVertical
DragStart
=
source
.
onVerticalDrag
Start
;
onVertical
ScrollUpdate
=
source
.
onVerticalScroll
Update
;
onVertical
DragUpdate
=
source
.
onVerticalDrag
Update
;
onVertical
ScrollEnd
=
source
.
onVerticalScroll
End
;
onVertical
DragEnd
=
source
.
onVerticalDrag
End
;
onHorizontal
ScrollStart
=
source
.
onHorizontalScroll
Start
;
onHorizontal
DragStart
=
source
.
onHorizontalDrag
Start
;
onHorizontal
ScrollUpdate
=
source
.
onHorizontalScroll
Update
;
onHorizontal
DragUpdate
=
source
.
onHorizontalDrag
Update
;
onHorizontal
ScrollEnd
=
source
.
onHorizontalScroll
End
;
onHorizontal
DragEnd
=
source
.
onHorizontalDrag
End
;
onPanStart
=
source
.
onPanStart
;
onPanStart
=
source
.
onPanStart
;
onPanUpdate
=
source
.
onPanUpdate
;
onPanUpdate
=
source
.
onPanUpdate
;
onPanEnd
=
source
.
onPanEnd
;
onPanEnd
=
source
.
onPanEnd
;
...
@@ -87,18 +87,18 @@ class GestureDetector extends StatefulComponent {
...
@@ -87,18 +87,18 @@ class GestureDetector extends StatefulComponent {
return
_longPress
;
return
_longPress
;
}
}
Vertical
ScrollGestureRecognizer
_verticalScroll
;
Vertical
DragGestureRecognizer
_verticalDrag
;
Vertical
ScrollGestureRecognizer
_ensureVerticalScroll
()
{
Vertical
DragGestureRecognizer
_ensureVerticalDrag
()
{
if
(
_vertical
Scroll
==
null
)
if
(
_vertical
Drag
==
null
)
_vertical
Scroll
=
new
VerticalScroll
GestureRecognizer
(
router:
_router
);
_vertical
Drag
=
new
VerticalDrag
GestureRecognizer
(
router:
_router
);
return
_vertical
Scroll
;
return
_vertical
Drag
;
}
}
Horizontal
ScrollGestureRecognizer
_horizontalScroll
;
Horizontal
DragGestureRecognizer
_horizontalDrag
;
Horizontal
ScrollGestureRecognizer
_ensureHorizontalScroll
()
{
Horizontal
DragGestureRecognizer
_ensureHorizontalDrag
()
{
if
(
_horizontal
Scroll
==
null
)
if
(
_horizontal
Drag
==
null
)
_horizontal
Scroll
=
new
HorizontalScroll
GestureRecognizer
(
router:
_router
);
_horizontal
Drag
=
new
HorizontalDrag
GestureRecognizer
(
router:
_router
);
return
_horizontal
Scroll
;
return
_horizontal
Drag
;
}
}
PanGestureRecognizer
_pan
;
PanGestureRecognizer
_pan
;
...
@@ -118,8 +118,8 @@ class GestureDetector extends StatefulComponent {
...
@@ -118,8 +118,8 @@ class GestureDetector extends StatefulComponent {
_tap
=
_ensureDisposed
(
_tap
);
_tap
=
_ensureDisposed
(
_tap
);
_showPress
=
_ensureDisposed
(
_showPress
);
_showPress
=
_ensureDisposed
(
_showPress
);
_longPress
=
_ensureDisposed
(
_longPress
);
_longPress
=
_ensureDisposed
(
_longPress
);
_vertical
Scroll
=
_ensureDisposed
(
_verticalScroll
);
_vertical
Drag
=
_ensureDisposed
(
_verticalDrag
);
_horizontal
Scroll
=
_ensureDisposed
(
_horizontalScroll
);
_horizontal
Drag
=
_ensureDisposed
(
_horizontalDrag
);
_pan
=
_ensureDisposed
(
_pan
);
_pan
=
_ensureDisposed
(
_pan
);
}
}
...
@@ -127,8 +127,8 @@ class GestureDetector extends StatefulComponent {
...
@@ -127,8 +127,8 @@ class GestureDetector extends StatefulComponent {
_syncTap
();
_syncTap
();
_syncShowPress
();
_syncShowPress
();
_syncLongPress
();
_syncLongPress
();
_syncVertical
Scroll
();
_syncVertical
Drag
();
_syncHorizontal
Scroll
();
_syncHorizontal
Drag
();
_syncPan
();
_syncPan
();
}
}
...
@@ -153,25 +153,25 @@ class GestureDetector extends StatefulComponent {
...
@@ -153,25 +153,25 @@ class GestureDetector extends StatefulComponent {
_ensureLongPress
().
onLongPress
=
onLongPress
;
_ensureLongPress
().
onLongPress
=
onLongPress
;
}
}
void
_syncVertical
Scroll
()
{
void
_syncVertical
Drag
()
{
if
(
onVertical
ScrollStart
==
null
&&
onVerticalScrollUpdate
==
null
&&
onVerticalScroll
End
==
null
)
{
if
(
onVertical
DragStart
==
null
&&
onVerticalDragUpdate
==
null
&&
onVerticalDrag
End
==
null
)
{
_vertical
Scroll
=
_ensureDisposed
(
_verticalScroll
);
_vertical
Drag
=
_ensureDisposed
(
_verticalDrag
);
}
else
{
}
else
{
_ensureVertical
Scroll
()
_ensureVertical
Drag
()
..
onStart
=
onVertical
Scroll
Start
..
onStart
=
onVertical
Drag
Start
..
onUpdate
=
onVertical
Scroll
Update
..
onUpdate
=
onVertical
Drag
Update
..
onEnd
=
onVertical
Scroll
End
;
..
onEnd
=
onVertical
Drag
End
;
}
}
}
}
void
_syncHorizontal
Scroll
()
{
void
_syncHorizontal
Drag
()
{
if
(
onHorizontal
ScrollStart
==
null
&&
onHorizontalScrollUpdate
==
null
&&
onHorizontalScroll
End
==
null
)
{
if
(
onHorizontal
DragStart
==
null
&&
onHorizontalDragUpdate
==
null
&&
onHorizontalDrag
End
==
null
)
{
_horizontal
Scroll
=
_ensureDisposed
(
_horizontalScroll
);
_horizontal
Drag
=
_ensureDisposed
(
_horizontalDrag
);
}
else
{
}
else
{
_ensureHorizontal
Scroll
()
_ensureHorizontal
Drag
()
..
onStart
=
onHorizontal
Scroll
Start
..
onStart
=
onHorizontal
Drag
Start
..
onUpdate
=
onHorizontal
Scroll
Update
..
onUpdate
=
onHorizontal
Drag
Update
..
onEnd
=
onHorizontal
Scroll
End
;
..
onEnd
=
onHorizontal
Drag
End
;
}
}
}
}
...
@@ -198,10 +198,10 @@ class GestureDetector extends StatefulComponent {
...
@@ -198,10 +198,10 @@ class GestureDetector extends StatefulComponent {
_showPress
.
addPointer
(
event
);
_showPress
.
addPointer
(
event
);
if
(
_longPress
!=
null
)
if
(
_longPress
!=
null
)
_longPress
.
addPointer
(
event
);
_longPress
.
addPointer
(
event
);
if
(
_vertical
Scroll
!=
null
)
if
(
_vertical
Drag
!=
null
)
_vertical
Scroll
.
addPointer
(
event
);
_vertical
Drag
.
addPointer
(
event
);
if
(
_horizontal
Scroll
!=
null
)
if
(
_horizontal
Drag
!=
null
)
_horizontal
Scroll
.
addPointer
(
event
);
_horizontal
Drag
.
addPointer
(
event
);
if
(
_pan
!=
null
)
if
(
_pan
!=
null
)
_pan
.
addPointer
(
event
);
_pan
.
addPointer
(
event
);
return
EventDisposition
.
processed
;
return
EventDisposition
.
processed
;
...
...
packages/flutter/lib/src/widgets/scrollable.dart
View file @
18e512d3
...
@@ -85,10 +85,10 @@ abstract class Scrollable extends StatefulComponent {
...
@@ -85,10 +85,10 @@ abstract class Scrollable extends StatefulComponent {
Widget
build
()
{
Widget
build
()
{
return
new
GestureDetector
(
return
new
GestureDetector
(
onVertical
Scroll
Update:
scrollDirection
==
ScrollDirection
.
vertical
?
scrollBy
:
null
,
onVertical
Drag
Update:
scrollDirection
==
ScrollDirection
.
vertical
?
scrollBy
:
null
,
onVertical
Scroll
End:
scrollDirection
==
ScrollDirection
.
vertical
?
_maybeSettleScrollOffset
:
null
,
onVertical
Drag
End:
scrollDirection
==
ScrollDirection
.
vertical
?
_maybeSettleScrollOffset
:
null
,
onHorizontal
Scroll
Update:
scrollDirection
==
ScrollDirection
.
horizontal
?
scrollBy
:
null
,
onHorizontal
Drag
Update:
scrollDirection
==
ScrollDirection
.
horizontal
?
scrollBy
:
null
,
onHorizontal
Scroll
End:
scrollDirection
==
ScrollDirection
.
horizontal
?
_maybeSettleScrollOffset
:
null
,
onHorizontal
Drag
End:
scrollDirection
==
ScrollDirection
.
horizontal
?
_maybeSettleScrollOffset
:
null
,
child:
new
Listener
(
child:
new
Listener
(
child:
buildContent
(),
child:
buildContent
(),
onPointerDown:
_handlePointerDown
,
onPointerDown:
_handlePointerDown
,
...
...
packages/unit/test/widget/dismissable_test.dart
View file @
18e512d3
...
@@ -77,6 +77,8 @@ void dismissItem(WidgetTester tester, int item, { DismissDirection gestureDirect
...
@@ -77,6 +77,8 @@ void dismissItem(WidgetTester tester, int item, { DismissDirection gestureDirect
downLocation
=
tester
.
getTopLeft
(
itemWidget
);
downLocation
=
tester
.
getTopLeft
(
itemWidget
);
upLocation
=
tester
.
getBottomLeft
(
itemWidget
);
upLocation
=
tester
.
getBottomLeft
(
itemWidget
);
break
;
break
;
default
:
fail
(
"unsupported gestureDirection"
);
}
}
TestPointer
pointer
=
new
TestPointer
(
5
);
TestPointer
pointer
=
new
TestPointer
(
5
);
...
...
packages/unit/test/widget/gesture_detector_test.dart
View file @
18e512d3
...
@@ -9,49 +9,49 @@ void main() {
...
@@ -9,49 +9,49 @@ void main() {
WidgetTester
tester
=
new
WidgetTester
();
WidgetTester
tester
=
new
WidgetTester
();
TestPointer
pointer
=
new
TestPointer
(
7
);
TestPointer
pointer
=
new
TestPointer
(
7
);
bool
didStart
Scroll
=
false
;
bool
didStart
Drag
=
false
;
double
updated
Scroll
Delta
;
double
updated
Drag
Delta
;
bool
didEnd
Scroll
=
false
;
bool
didEnd
Drag
=
false
;
Widget
builder
()
{
Widget
builder
()
{
return
new
GestureDetector
(
return
new
GestureDetector
(
onVertical
Scroll
Start:
()
{
onVertical
Drag
Start:
()
{
didStart
Scroll
=
true
;
didStart
Drag
=
true
;
},
},
onVertical
Scroll
Update:
(
double
scrollDelta
)
{
onVertical
Drag
Update:
(
double
scrollDelta
)
{
updated
Scroll
Delta
=
scrollDelta
;
updated
Drag
Delta
=
scrollDelta
;
},
},
onVertical
Scroll
End:
()
{
onVertical
Drag
End:
()
{
didEnd
Scroll
=
true
;
didEnd
Drag
=
true
;
},
},
child:
new
Container
()
child:
new
Container
()
);
);
}
}
tester
.
pumpFrame
(
builder
);
tester
.
pumpFrame
(
builder
);
expect
(
didStart
Scroll
,
isFalse
);
expect
(
didStart
Drag
,
isFalse
);
expect
(
updated
Scroll
Delta
,
isNull
);
expect
(
updated
Drag
Delta
,
isNull
);
expect
(
didEnd
Scroll
,
isFalse
);
expect
(
didEnd
Drag
,
isFalse
);
Point
firstLocation
=
new
Point
(
10.0
,
10.0
);
Point
firstLocation
=
new
Point
(
10.0
,
10.0
);
tester
.
dispatchEvent
(
pointer
.
down
(
firstLocation
),
firstLocation
);
tester
.
dispatchEvent
(
pointer
.
down
(
firstLocation
),
firstLocation
);
expect
(
didStart
Scroll
,
isTrue
);
expect
(
didStart
Drag
,
isTrue
);
didStart
Scroll
=
false
;
didStart
Drag
=
false
;
expect
(
updated
Scroll
Delta
,
isNull
);
expect
(
updated
Drag
Delta
,
isNull
);
expect
(
didEnd
Scroll
,
isFalse
);
expect
(
didEnd
Drag
,
isFalse
);
Point
secondLocation
=
new
Point
(
10.0
,
9.0
);
Point
secondLocation
=
new
Point
(
10.0
,
9.0
);
tester
.
dispatchEvent
(
pointer
.
move
(
secondLocation
),
firstLocation
);
tester
.
dispatchEvent
(
pointer
.
move
(
secondLocation
),
firstLocation
);
expect
(
didStart
Scroll
,
isFalse
);
expect
(
didStart
Drag
,
isFalse
);
expect
(
updated
Scroll
Delta
,
1.0
);
expect
(
updated
Drag
Delta
,
1.0
);
updated
Scroll
Delta
=
null
;
updated
Drag
Delta
=
null
;
expect
(
didEnd
Scroll
,
isFalse
);
expect
(
didEnd
Drag
,
isFalse
);
tester
.
dispatchEvent
(
pointer
.
up
(),
firstLocation
);
tester
.
dispatchEvent
(
pointer
.
up
(),
firstLocation
);
expect
(
didStart
Scroll
,
isFalse
);
expect
(
didStart
Drag
,
isFalse
);
expect
(
updated
Scroll
Delta
,
isNull
);
expect
(
updated
Drag
Delta
,
isNull
);
expect
(
didEnd
Scroll
,
isTrue
);
expect
(
didEnd
Drag
,
isTrue
);
didEnd
Scroll
=
false
;
didEnd
Drag
=
false
;
tester
.
pumpFrame
(()
=>
new
Container
());
tester
.
pumpFrame
(()
=>
new
Container
());
});
});
...
@@ -68,10 +68,10 @@ void main() {
...
@@ -68,10 +68,10 @@ void main() {
Widget
builder
()
{
Widget
builder
()
{
return
new
GestureDetector
(
return
new
GestureDetector
(
onVertical
Scroll
Update:
(
double
delta
)
{
dragDistance
+=
delta
;
},
onVertical
Drag
Update:
(
double
delta
)
{
dragDistance
+=
delta
;
},
onVertical
Scroll
End:
()
{
gestureCount
+=
1
;
},
onVertical
Drag
End:
()
{
gestureCount
+=
1
;
},
onHorizontal
Scroll
Update:
(
_
)
{
fail
(
"gesture should not match"
);
},
onHorizontal
Drag
Update:
(
_
)
{
fail
(
"gesture should not match"
);
},
onHorizontal
Scroll
End:
()
{
fail
(
"gesture should not match"
);
},
onHorizontal
Drag
End:
()
{
fail
(
"gesture should not match"
);
},
child:
new
Container
()
child:
new
Container
()
);
);
}
}
...
...
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