summaryrefslogtreecommitdiffstats
path: root/content/renderer/mouse_lock_dispatcher.cc
diff options
context:
space:
mode:
authoryzshen@chromium.org <yzshen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-06-03 10:29:24 +0000
committeryzshen@chromium.org <yzshen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2012-06-03 10:29:24 +0000
commit890545016b87381a5ed5db6e840735c9fd08106c (patch)
tree1c6b71cf7add01245ff0f3f3ef7487a45856bd2a /content/renderer/mouse_lock_dispatcher.cc
parentcb56392fa58db991fa609f04d37ee78a2f1f41fa (diff)
downloadchromium_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.cc49
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() {