diff options
| author | yzshen@chromium.org <yzshen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-06-03 10:29:24 +0000 |
|---|---|---|
| committer | yzshen@chromium.org <yzshen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2012-06-03 10:29:24 +0000 |
| commit | 890545016b87381a5ed5db6e840735c9fd08106c (patch) | |
| tree | 1c6b71cf7add01245ff0f3f3ef7487a45856bd2a /content/renderer/mouse_lock_dispatcher.cc | |
| parent | cb56392fa58db991fa609f04d37ee78a2f1f41fa (diff) | |
| download | chromium_src-890545016b87381a5ed5db6e840735c9fd08106c.zip chromium_src-890545016b87381a5ed5db6e840735c9fd08106c.tar.gz chromium_src-890545016b87381a5ed5db6e840735c9fd08106c.tar.bz2 | |
Support mouse lock in Flash fullscreen mode.
In this mode, we won't show a bubble to ask for user permission. Mouse lock content settings are not considered, either.
BUG=129241
TEST=1) run ppapi/examples/mouse_lock;
2) when one of the plugins is focused, press 'f' to enter Flash fullscreen;
3) left click to enter mouse lock.
Review URL: https://chromiumcodereview.appspot.com/10458008
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@140231 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/renderer/mouse_lock_dispatcher.cc')
| -rw-r--r-- | content/renderer/mouse_lock_dispatcher.cc | 49 |
1 files changed, 9 insertions, 40 deletions
diff --git a/content/renderer/mouse_lock_dispatcher.cc b/content/renderer/mouse_lock_dispatcher.cc index dd2326a..225c5a6 100644 --- a/content/renderer/mouse_lock_dispatcher.cc +++ b/content/renderer/mouse_lock_dispatcher.cc @@ -4,20 +4,14 @@ #include "content/renderer/mouse_lock_dispatcher.h" -#include "content/common/view_messages.h" -#include "content/renderer/render_view_impl.h" -#include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h" +#include "base/logging.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebInputEvent.h" -#include "third_party/WebKit/Source/WebKit/chromium/public/WebWidget.h" - -MouseLockDispatcher::MouseLockDispatcher(RenderViewImpl* render_view_impl) - : content::RenderViewObserver(render_view_impl), - render_view_impl_(render_view_impl), - mouse_locked_(false), - pending_lock_request_(false), - pending_unlock_request_(false), - unlocked_by_target_(false), - target_(NULL) { + +MouseLockDispatcher::MouseLockDispatcher() : mouse_locked_(false), + pending_lock_request_(false), + pending_unlock_request_(false), + unlocked_by_target_(false), + target_(NULL) { } MouseLockDispatcher::~MouseLockDispatcher() { @@ -30,13 +24,7 @@ bool MouseLockDispatcher::LockMouse(LockTarget* target) { pending_lock_request_ = true; target_ = target; - bool user_gesture = - render_view_impl_->webview() && - render_view_impl_->webview()->mainFrame() && - render_view_impl_->webview()->mainFrame()->isProcessingUserGesture(); - Send(new ViewHostMsg_LockMouse(routing_id(), - user_gesture, - unlocked_by_target_)); + SendLockMouseRequest(unlocked_by_target_); unlocked_by_target_ = false; return true; } @@ -45,7 +33,7 @@ void MouseLockDispatcher::UnlockMouse(LockTarget* target) { if (target && target == target_ && !pending_unlock_request_) { pending_unlock_request_ = true; unlocked_by_target_ = true; - Send(new ViewHostMsg_UnlockMouse(routing_id())); + SendUnlockMouseRequest(); } } @@ -67,16 +55,6 @@ bool MouseLockDispatcher::WillHandleMouseEvent( return false; } -bool MouseLockDispatcher::OnMessageReceived(const IPC::Message& message) { - bool handled = true; - IPC_BEGIN_MESSAGE_MAP(MouseLockDispatcher, message) - IPC_MESSAGE_HANDLER(ViewMsg_LockMouse_ACK, OnLockMouseACK) - IPC_MESSAGE_HANDLER(ViewMsg_MouseLockLost, OnMouseLockLost) - IPC_MESSAGE_UNHANDLED(handled = false) - IPC_END_MESSAGE_MAP() - return handled; -} - void MouseLockDispatcher::OnLockMouseACK(bool succeeded) { DCHECK(!mouse_locked_ && pending_lock_request_); @@ -98,15 +76,6 @@ void MouseLockDispatcher::OnLockMouseACK(bool succeeded) { if (last_target) last_target->OnLockMouseACK(succeeded); - - // Mouse Lock removes the system cursor and provides all mouse motion as - // .movementX/Y values on events all sent to a fixed target. This requires - // content to specifically request the mode to be entered. - // Mouse Capture is implicitly given for the duration of a drag event, and - // sends all mouse events to the initial target of the drag. - // If Lock is entered it supercedes any in progress Capture. - if (succeeded && render_view_impl_->webwidget()) - render_view_impl_->webwidget()->mouseCaptureLost(); } void MouseLockDispatcher::OnMouseLockLost() { |
