Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1204)

Unified Diff: content/browser/renderer_host/legacy_render_widget_host_win.cc

Issue 151083002: Create a visible window with class name Chrome_RenderWidgetHostHWND which corresponds to the bounds… (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 6 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
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);
scottmg 2014/01/31 21:52:01 could you change the title to "Legacy Helper" or s
ananta 2014/01/31 23:56:26 Changed to Chrome Legacy Helper
+
+ 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

Powered by Google App Engine
This is Rietveld 408576698