diff options
author | varkha@chromium.org <varkha@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-10-24 20:30:32 +0000 |
---|---|---|
committer | varkha@chromium.org <varkha@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2013-10-24 20:30:32 +0000 |
commit | 923e85f5dbb8fcea66b4d4a791331b186486ac7d (patch) | |
tree | 56f9f3074acb053192cdb64d7401de3e3bfb43ad /skia/ext/image_operations.cc | |
parent | 72964574ec9066bf1c195f4660f7368dbf5c3e3a (diff) | |
download | chromium_src-923e85f5dbb8fcea66b4d4a791331b186486ac7d.zip chromium_src-923e85f5dbb8fcea66b4d4a791331b186486ac7d.tar.gz chromium_src-923e85f5dbb8fcea66b4d4a791331b186486ac7d.tar.bz2 |
Avoid creating two resizers for two-finger drag. This CL is trying to avoid creating two separate WindowResizer instances that are now created in both ToplevelWindowEventHandler and TwoFingerDragHandler in the following scenario:
. Start dragging a window with a touch.
. Drag a bit, then add a second finger (touching the caption).
. Continue dragging.
. Release both fingers.
In this scenario a WindowResizer is first created by ToplevelWindowEventHandler::OnGestureEvent(ET_GESTURE_SCROLL_BEGIN) and then a second instance gets created by TwoFingerDragHandler::ProcessGestureEvent(ET_GESTURE_BEGIN) when a second finger touches down. This scenario is probably an oversight but was not causing too many problems other than occasional window moving jitter. However with the docked windows introduction the DockedWindowLayoutManager currently assumes a single window resizing operation and breaks when FinishDragging is called for the second time.
Additional complication is when this one-two-finger gesture is used to drag a tab out of a browser. In this case The first resizer is created when ToplevelWindowEventHandler::RunMoveLoop is invoked and not as a result of a gesture (not in ToplevelWindowEventHandler::OnGestureEvent). I have added an accessor to the current window resizer to wm::WindowState and use it to determine if a new resizer needs to be created.
I have corrected the state model in TwoFingerDragHandler to always Complete or Revert a drag once it started. This takes care of scenarios when drags start with one or two fingers and get stopped when more fingers are added.
BUG=305730
TEST=interactive_ui_tests --gtest_filter=*TabDragControllerTest*DetachToOwnWindowTwo*/1
TEST=ash_unittests --gtest_filter=*SystemGestureEventFilterTest.TwoFingerDragDelayed*
TEST=ash_unittests --gtest_filter=*SystemGestureEventFilterTest.ThreeFingerGestureStopsDrag*
Committed: https://src.chromium.org/viewvc/chrome?view=rev&revision=230671
Review URL: https://codereview.chromium.org/28043002
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@230798 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'skia/ext/image_operations.cc')
0 files changed, 0 insertions, 0 deletions