| Index: content/browser/renderer_host/legacy_render_widget_host_win.cc
|
| ===================================================================
|
| --- content/browser/renderer_host/legacy_render_widget_host_win.cc (revision 0)
|
| +++ content/browser/renderer_host/legacy_render_widget_host_win.cc (revision 0)
|
| @@ -0,0 +1,173 @@
|
| +// Copyright (c) 2014 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#include "content/browser/renderer_host/legacy_render_widget_host_win.h"
|
| +
|
| +#include "base/win/windows_version.h"
|
| +#include "content/browser/accessibility/browser_accessibility_manager_win.h"
|
| +#include "content/browser/accessibility/browser_accessibility_win.h"
|
| +#include "ui/base/touch/touch_enabled.h"
|
| +#include "ui/gfx/geometry/rect.h"
|
| +
|
| +namespace content {
|
| +
|
| +LegacyRenderWidgetHostHWND::LegacyRenderWidgetHostHWND(HWND parent)
|
| + : manager_(NULL),
|
| + parent_(parent) {
|
| + RECT rect = {0};
|
| + Create(parent, rect, NULL, WS_CHILDWINDOW, WS_EX_TRANSPARENT);
|
| +
|
| + if (base::win::GetVersion() >= base::win::VERSION_WIN7 &&
|
| + ui::AreTouchEventsEnabled())
|
| + RegisterTouchWindow(hwnd(), TWF_WANTPALM);
|
| +
|
| + HRESULT hr = ::CreateStdAccessibleObject(
|
| + hwnd(), OBJID_WINDOW, IID_IAccessible,
|
| + reinterpret_cast<void **>(window_accessible_.Receive()));
|
| + if (::IsWindow(hwnd())) {
|
| + mouse_window_bounds_tracker_.set_tracking_window(m_hWnd);
|
| + mouse_window_bounds_tracker_.SubclassWindow(parent_);
|
| + }
|
| +}
|
| +
|
| +LegacyRenderWidgetHostHWND::~LegacyRenderWidgetHostHWND() {
|
| +}
|
| +
|
| +void LegacyRenderWidgetHostHWND::OnManagerDeleted() {
|
| + manager_ = NULL;
|
| +}
|
| +
|
| +void LegacyRenderWidgetHostHWND::Show() {
|
| + ::ShowWindow(hwnd(), SW_SHOW);
|
| +}
|
| +
|
| +void LegacyRenderWidgetHostHWND::Hide() {
|
| + ::ShowWindow(hwnd(), SW_HIDE);
|
| +}
|
| +
|
| +void LegacyRenderWidgetHostHWND::OnFinalMessage(HWND hwnd) {
|
| + if (manager_)
|
| + manager_->OnAccessibleHwndDeleted();
|
| + delete this;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnEraseBkGnd(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param) {
|
| + return 1;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnGetObject(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param) {
|
| + if (OBJID_CLIENT != l_param || !manager_)
|
| + return static_cast<LRESULT>(0L);
|
| +
|
| + base::win::ScopedComPtr<IAccessible> root(
|
| + manager_->GetRoot()->ToBrowserAccessibilityWin());
|
| + return LresultFromObject(IID_IAccessible, w_param,
|
| + static_cast<IAccessible*>(root.Detach()));
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnKeyboardRange(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param,
|
| + BOOL& handled) {
|
| + ::PostMessage(parent_, message, w_param, l_param);
|
| + return 0;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnMouseRange(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param,
|
| + BOOL& handled) {
|
| + // We won't receive mouse messages when capture is with the parent window.
|
| + // If we receive a mouse move then it means that parent capture was released.
|
| + // This would happen if we lost focus or if the mouse left our window bounds
|
| + // and we released capture.
|
| + if (message == WM_MOUSEMOVE) {
|
| + if (::GetCapture() != parent_)
|
| + ::SetCapture(parent_);
|
| + }
|
| + // TODO(ananta)
|
| + // This code should be restored/deleted prior to landing this, based on
|
| + // decisions as to whether capturing the parent window to ensure that all
|
| + // mouse messages go to it and the ensuing complexity with the same is worth
|
| + // the effort. Posting the message to the parent seems much simpler with
|
| + // the caveat of converting mouse messages into posted mouse messages which
|
| + // may lead to performance issues with the message pump and the fact that
|
| + // we need to peeks for every mouse event.
|
| +#if 0
|
| + POINT mouse_coords;
|
| + mouse_coords.x = GET_X_LPARAM(l_param);
|
| + mouse_coords.y = GET_Y_LPARAM(l_param);
|
| + ::MapWindowPoints(hwnd(), parent_, &mouse_coords, 1);
|
| + ::PostMessage(parent_, message, w_param,
|
| + MAKELPARAM(mouse_coords.x, mouse_coords.y));
|
| +#endif
|
| + return 0;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnNCPaint(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param) {
|
| + return 0;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnPaint(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param) {
|
| + PAINTSTRUCT ps = {0};
|
| + ::BeginPaint(hwnd(), &ps);
|
| + ::EndPaint(hwnd(), &ps);
|
| + return 0;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnSetCursor(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param) {
|
| + return 0;
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::OnTouch(UINT message,
|
| + WPARAM w_param,
|
| + LPARAM l_param) {
|
| + ::PostMessage(parent_, message, w_param, l_param);
|
| + return 0;
|
| +}
|
| +
|
| +LegacyRenderWidgetHostHWND::
|
| + MouseWindowBoundsTracker::MouseWindowBoundsTracker()
|
| + : tracking_window_(NULL) {
|
| +}
|
| +
|
| +LegacyRenderWidgetHostHWND::
|
| + MouseWindowBoundsTracker::~MouseWindowBoundsTracker() {
|
| + UnsubclassWindow();
|
| +}
|
| +
|
| +LRESULT LegacyRenderWidgetHostHWND::MouseWindowBoundsTracker::OnMouseMove(
|
| + UINT message, WPARAM w_param, LPARAM l_param) {
|
| + SetMsgHandled(FALSE);
|
| + // Don't mess with the capture if mouse buttons are down.
|
| + const int mouse_down_flags =
|
| + MK_LBUTTON | MK_MBUTTON | MK_RBUTTON | MK_XBUTTON1 | MK_XBUTTON2;
|
| + if (::GetCapture() == m_hWnd && !(w_param & mouse_down_flags)) {
|
| + DCHECK(::IsWindow(tracking_window_));
|
| + POINT pt = {0};
|
| + pt.x = GET_X_LPARAM(l_param);
|
| + pt.y = GET_Y_LPARAM(l_param);
|
| + ::ClientToScreen(m_hWnd, &pt);
|
| +
|
| + RECT window_rect = {0};
|
| + ::GetWindowRect(tracking_window_, &window_rect);
|
| + if (!::PtInRect(&window_rect, pt) ||
|
| + ::WindowFromPoint(pt) != tracking_window_) {
|
| + ::ReleaseCapture();
|
| + }
|
| + }
|
| + return 0;
|
| +}
|
| +
|
| +} // namespace content
|
|
|