Index: trunk/src/ui/aura/window_tree_host_win.h |
=================================================================== |
--- trunk/src/ui/aura/window_tree_host_win.h (revision 284904) |
+++ trunk/src/ui/aura/window_tree_host_win.h (working copy) |
@@ -6,23 +6,19 @@ |
#define UI_AURA_WINDOW_TREE_HOST_WIN_H_ |
#include "base/compiler_specific.h" |
-#include "base/memory/scoped_ptr.h" |
#include "ui/aura/aura_export.h" |
#include "ui/aura/window_tree_host.h" |
#include "ui/events/event_source.h" |
-#include "ui/platform_window/platform_window.h" |
-#include "ui/platform_window/platform_window_delegate.h" |
+#include "ui/gfx/win/window_impl.h" |
namespace aura { |
-class AURA_EXPORT WindowTreeHostWin |
- : public WindowTreeHost, |
- public ui::EventSource, |
- public NON_EXPORTED_BASE(ui::PlatformWindowDelegate) { |
+class AURA_EXPORT WindowTreeHostWin : public WindowTreeHost, |
+ public ui::EventSource, |
+ public gfx::WindowImpl { |
public: |
explicit WindowTreeHostWin(const gfx::Rect& bounds); |
virtual ~WindowTreeHostWin(); |
- |
// WindowTreeHost: |
virtual ui::EventSource* GetEventSource() OVERRIDE; |
virtual gfx::AcceleratedWidget GetAcceleratedWidget() OVERRIDE; |
@@ -41,30 +37,56 @@ |
// ui::EventSource: |
virtual ui::EventProcessor* GetEventProcessor() OVERRIDE; |
- protected: |
- gfx::AcceleratedWidget hwnd() const { return widget_; } |
- |
private: |
- // ui::PlatformWindowDelegate: |
- virtual void OnBoundsChanged(const gfx::Rect& new_bounds) OVERRIDE; |
- virtual void OnDamageRect(const gfx::Rect& damaged_region) OVERRIDE; |
- virtual void DispatchEvent(ui::Event* event) OVERRIDE; |
- virtual void OnCloseRequest() OVERRIDE; |
- virtual void OnClosed() OVERRIDE; |
- virtual void OnWindowStateChanged(ui::PlatformWindowState new_state) OVERRIDE; |
- virtual void OnLostCapture() OVERRIDE; |
- virtual void OnAcceleratedWidgetAvailable( |
- gfx::AcceleratedWidget widget) OVERRIDE; |
- virtual void OnActivationChanged(bool active) OVERRIDE; |
+ CR_BEGIN_MSG_MAP_EX(WindowTreeHostWin) |
+ // Range handlers must go first! |
+ CR_MESSAGE_RANGE_HANDLER_EX(WM_MOUSEFIRST, WM_MOUSELAST, OnMouseRange) |
+ CR_MESSAGE_RANGE_HANDLER_EX(WM_NCMOUSEMOVE, |
+ WM_NCXBUTTONDBLCLK, |
+ OnMouseRange) |
+ // Mouse capture events. |
+ CR_MESSAGE_HANDLER_EX(WM_CAPTURECHANGED, OnCaptureChanged) |
+ |
+ // Key events. |
+ CR_MESSAGE_HANDLER_EX(WM_KEYDOWN, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_KEYUP, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_SYSKEYDOWN, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_SYSKEYUP, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_CHAR, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_SYSCHAR, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_IME_CHAR, OnKeyEvent) |
+ CR_MESSAGE_HANDLER_EX(WM_NCACTIVATE, OnNCActivate) |
+ |
+ CR_MSG_WM_CLOSE(OnClose) |
+ CR_MSG_WM_MOVE(OnMove) |
+ CR_MSG_WM_PAINT(OnPaint) |
+ CR_MSG_WM_SIZE(OnSize) |
+ CR_END_MSG_MAP() |
+ |
+ void OnClose(); |
+ LRESULT OnKeyEvent(UINT message, WPARAM w_param, LPARAM l_param); |
+ LRESULT OnMouseRange(UINT message, WPARAM w_param, LPARAM l_param); |
+ LRESULT OnCaptureChanged(UINT message, WPARAM w_param, LPARAM l_param); |
+ LRESULT OnNCActivate(UINT message, WPARAM w_param, LPARAM l_param); |
+ void OnMove(const gfx::Point& point); |
+ void OnPaint(HDC dc); |
+ void OnSize(UINT param, const gfx::Size& size); |
+ |
bool has_capture_; |
- gfx::Rect bounds_; |
- gfx::AcceleratedWidget widget_; |
- scoped_ptr<ui::PlatformWindow> window_; |
DISALLOW_COPY_AND_ASSIGN(WindowTreeHostWin); |
}; |
+namespace test { |
+ |
+// Set true to let WindowTreeHostWin use a popup window |
+// with no frame/title so that the window size and test's |
+// expectations matches. |
+AURA_EXPORT void SetUsePopupAsRootWindowForTest(bool use); |
+ |
+} // namespace |
+ |
} // namespace aura |
#endif // UI_AURA_WINDOW_TREE_HOST_WIN_H_ |