blob: c4d08d352c9cc3f1d47665de30c21408150f0701 [file] [log] [blame]
// Copyright (c) 2006-2008 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.
#ifndef CHROME_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_WIN_H_
#define CHROME_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_WIN_H_
#include <atlbase.h>
#include <atlapp.h>
#include <atlcrack.h>
#include <atlmisc.h>
#include "base/basictypes.h"
#include "base/gfx/size.h"
#include "base/scoped_handle.h"
#include "base/shared_memory.h"
#include "base/task.h"
#include "chrome/browser/ime_input.h"
#include "chrome/browser/renderer_host/render_widget_host_view.h"
#include "chrome/common/render_messages.h"
#include "chrome/views/focus_manager.h"
namespace gfx {
class Rect;
}
namespace IPC {
class Message;
}
class RenderWidgetHost;
class WebMouseEvent;
class WebCursor;
typedef CWinTraits<WS_CHILD | WS_CLIPCHILDREN | WS_CLIPSIBLINGS, 0>
RenderWidgetHostHWNDTraits;
static const wchar_t* const kRenderWidgetHostHWNDClass =
L"Chrome_RenderWidgetHostHWND";
///////////////////////////////////////////////////////////////////////////////
// RenderWidgetHostViewWin
//
// An object representing the "View" of a rendered web page. This object is
// responsible for displaying the content of the web page, receiving windows
// messages, and containing plugins HWNDs. It is the implementation of the
// RenderWidgetHostView that the cross-platform RenderWidgetHost object uses
// to display the data.
//
// Comment excerpted from render_widget_host.h:
//
// "The lifetime of the RenderWidgetHostHWND is tied to the render process.
// If the render process dies, the RenderWidgetHostHWND goes away and all
// references to it must become NULL."
//
class RenderWidgetHostViewWin :
public CWindowImpl<RenderWidgetHostViewWin,
CWindow,
RenderWidgetHostHWNDTraits>,
public RenderWidgetHostView {
public:
// The view will associate itself with the given widget.
explicit RenderWidgetHostViewWin(RenderWidgetHost* widget);
virtual ~RenderWidgetHostViewWin();
void set_close_on_deactivate(bool close_on_deactivate) {
close_on_deactivate_ = close_on_deactivate;
}
void set_activatable(bool activatable) {
activatable_ = activatable;
}
bool activatable() const { return activatable_; }
void set_parent_hwnd(HWND parent) { parent_hwnd_ = parent; }
DECLARE_WND_CLASS_EX(kRenderWidgetHostHWNDClass, CS_DBLCLKS, 0);
BEGIN_MSG_MAP(RenderWidgetHostHWND)
MSG_WM_CREATE(OnCreate)
MSG_WM_ACTIVATE(OnActivate)
MSG_WM_DESTROY(OnDestroy)
MSG_WM_PAINT(OnPaint)
MSG_WM_NCPAINT(OnNCPaint)
MSG_WM_ERASEBKGND(OnEraseBkgnd)
MSG_WM_SETCURSOR(OnSetCursor)
MSG_WM_SETFOCUS(OnSetFocus)
MSG_WM_KILLFOCUS(OnKillFocus)
MSG_WM_CAPTURECHANGED(OnCaptureChanged)
MSG_WM_CANCELMODE(OnCancelMode)
MSG_WM_INPUTLANGCHANGE(OnInputLangChange)
MSG_WM_THEMECHANGED(OnThemeChanged)
MSG_WM_NOTIFY(OnNotify)
MESSAGE_HANDLER(WM_IME_SETCONTEXT, OnImeSetContext)
MESSAGE_HANDLER(WM_IME_STARTCOMPOSITION, OnImeStartComposition)
MESSAGE_HANDLER(WM_IME_COMPOSITION, OnImeComposition)
MESSAGE_HANDLER(WM_IME_ENDCOMPOSITION, OnImeEndComposition)
MESSAGE_HANDLER(WM_MOUSEMOVE, OnMouseEvent)
MESSAGE_HANDLER(WM_MOUSELEAVE, OnMouseEvent)
MESSAGE_HANDLER(WM_LBUTTONDOWN, OnMouseEvent)
MESSAGE_HANDLER(WM_MBUTTONDOWN, OnMouseEvent)
MESSAGE_HANDLER(WM_RBUTTONDOWN, OnMouseEvent)
MESSAGE_HANDLER(WM_LBUTTONUP, OnMouseEvent)
MESSAGE_HANDLER(WM_MBUTTONUP, OnMouseEvent)
MESSAGE_HANDLER(WM_RBUTTONUP, OnMouseEvent)
MESSAGE_HANDLER(WM_LBUTTONDBLCLK, OnMouseEvent)
MESSAGE_HANDLER(WM_MBUTTONDBLCLK, OnMouseEvent)
MESSAGE_HANDLER(WM_RBUTTONDBLCLK, OnMouseEvent)
MESSAGE_HANDLER(WM_SYSKEYDOWN, OnKeyEvent)
MESSAGE_HANDLER(WM_SYSKEYUP, OnKeyEvent)
MESSAGE_HANDLER(WM_KEYDOWN, OnKeyEvent)
MESSAGE_HANDLER(WM_KEYUP, OnKeyEvent)
MESSAGE_HANDLER(WM_MOUSEWHEEL, OnWheelEvent)
MESSAGE_HANDLER(WM_MOUSEHWHEEL, OnWheelEvent)
MESSAGE_HANDLER(WM_HSCROLL, OnWheelEvent)
MESSAGE_HANDLER(WM_VSCROLL, OnWheelEvent)
MESSAGE_HANDLER(WM_CHAR, OnKeyEvent)
MESSAGE_HANDLER(WM_SYSCHAR, OnKeyEvent)
MESSAGE_HANDLER(WM_IME_CHAR, OnKeyEvent)
MESSAGE_HANDLER(WM_MOUSEACTIVATE, OnMouseActivate)
MESSAGE_HANDLER(WM_GETOBJECT, OnGetObject)
END_MSG_MAP()
// Implementation of RenderWidgetHostView:
virtual RenderWidgetHost* GetRenderWidgetHost() const;
virtual void DidBecomeSelected();
virtual void WasHidden();
virtual void SetSize(const gfx::Size& size);
virtual gfx::NativeView GetPluginNativeView();
virtual void MovePluginWindows(
const std::vector<WebPluginGeometry>& plugin_window_moves);
virtual void Focus();
virtual void Blur();
virtual bool HasFocus();
virtual void Show();
virtual void Hide();
virtual gfx::Rect GetViewBounds() const;
virtual void UpdateCursor(const WebCursor& cursor);
virtual void UpdateCursorIfOverSelf();
virtual void SetIsLoading(bool is_loading);
virtual void IMEUpdateStatus(int control, const gfx::Rect& caret_rect);
virtual void DidPaintRect(const gfx::Rect& rect);
virtual void DidScrollRect(const gfx::Rect& rect, int dx, int dy);
virtual void RendererGone();
virtual void Destroy();
virtual void SetTooltipText(const std::wstring& tooltip_text);
protected:
// Windows Message Handlers
LRESULT OnCreate(CREATESTRUCT* create_struct);
void OnActivate(UINT, BOOL, HWND);
void OnDestroy();
void OnPaint(HDC dc);
void OnNCPaint(HRGN update_region);
LRESULT OnEraseBkgnd(HDC dc);
LRESULT OnSetCursor(HWND window, UINT hittest_code, UINT mouse_message_id);
void OnSetFocus(HWND window);
void OnKillFocus(HWND window);
void OnCaptureChanged(HWND window);
void OnCancelMode();
void OnInputLangChange(DWORD character_set, HKL input_language_id);
void OnThemeChanged();
LRESULT OnNotify(int w_param, NMHDR* header);
LRESULT OnImeSetContext(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnImeStartComposition(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnImeComposition(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnImeEndComposition(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnMouseEvent(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnKeyEvent(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnWheelEvent(
UINT message, WPARAM wparam, LPARAM lparam, BOOL& handled);
LRESULT OnMouseActivate(UINT, WPARAM, LPARAM, BOOL& handled);
// Handle MSAA requests for accessibility information.
LRESULT OnGetObject(UINT message, WPARAM wparam, LPARAM lparam,
BOOL& handled);
// Handle vertical scrolling
LRESULT OnVScroll(int code, short position, HWND scrollbar_control);
// Handle horizontal scrolling
LRESULT OnHScroll(int code, short position, HWND scrollbar_control);
void OnFinalMessage(HWND window);
private:
// Tells Windows that we want to hear about mouse exit messages.
void TrackMouseLeave(bool start_tracking);
// Sends a message to the RenderView in the renderer process.
bool Send(IPC::Message* message);
// Set the tooltip region to the size of the window, creating the tooltip
// hwnd if it has not been created yet.
void EnsureTooltip();
// Tooltips become invalid when the root ancestor changes. When the View
// becomes hidden, this method is called to reset the tooltip.
void ResetTooltip();
// Sends the specified mouse event to the renderer.
void ForwardMouseEventToRenderer(UINT message, WPARAM wparam, LPARAM lparam);
// Synthesize mouse wheel event.
LRESULT SynthesizeMouseWheel(bool is_vertical, int scroll_code,
short scroll_position);
// Shuts down the render_widget_host_. This is a separate function so we can
// invoke it from the message loop.
void ShutdownHost();
// Redraws the window synchronously, and any child windows (i.e. plugins)
// asynchronously.
void Redraw(const gfx::Rect& invalid_rect);
// The associated Model.
RenderWidgetHost* render_widget_host_;
// The cursor for the page. This is passed up from the renderer.
WebCursor current_cursor_;
// Indicates if the page is loading.
bool is_loading_;
// true if we are currently tracking WM_MOUSEEXIT messages.
bool track_mouse_leave_;
// Wrapper class for IME input.
// (See "chrome/browser/ime_input.h" for its details.)
ImeInput ime_input_;
// Represents whether or not this browser process is receiving status
// messages about the focused edit control from a renderer process.
bool ime_notification_;
// true if the View is not visible.
bool is_hidden_;
// true if the View should be closed when its HWND is deactivated (used to
// support SELECT popups which are closed when they are deactivated).
bool close_on_deactivate_;
// Tooltips
// The text to be shown in the tooltip, supplied by the renderer.
std::wstring tooltip_text_;
// The tooltip control hwnd
HWND tooltip_hwnd_;
// Whether or not a tooltip is currently visible. We use this to track
// whether or not we want to force-close the tooltip when we receive mouse
// move notifications from the renderer. See comment in OnMsgSetTooltipText.
bool tooltip_showing_;
// Factory used to safely scope delayed calls to ShutdownHost().
ScopedRunnableMethodFactory<RenderWidgetHostViewWin> shutdown_factory_;
// Our parent HWND. We keep a reference to it as we SetParent(NULL) when
// hidden to prevent getting messages (Paint, Resize...), and we reattach
// when shown again.
HWND parent_hwnd_;
// Instance of accessibility information for the root of the MSAA
// tree representation of the WebKit render tree.
CComPtr<IAccessible> browser_accessibility_root_;
// The time at which this view started displaying white pixels as a result of
// not having anything to paint (empty backing store from renderer). This
// value returns true for is_null() if we are not recording whiteout times.
base::TimeTicks whiteout_start_time_;
// Whether the window can be activated. Autocomplete popup windows for example
// cannot be activated. Default is true.
bool activatable_;
// Whether the renderer is made accessible.
// TODO(jcampan): http://b/issue?id=1432077 This is a temporary work-around
// until that bug is fixed.
bool renderer_accessible_;
DISALLOW_COPY_AND_ASSIGN(RenderWidgetHostViewWin);
};
#endif // CHROME_BROWSER_RENDERER_HOST_RENDER_WIDGET_HOST_VIEW_WIN_H_