summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-18 21:11:11 +0000
committerjhawkins@chromium.org <jhawkins@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-08-18 21:11:11 +0000
commit1a89ea1ad2d890cf196eee4c24a8dec9fa573961 (patch)
treec2caf29306d0b899a6b5b7785718843e82da828f
parent1b8ca7112df30a566c911d77c84d145ba83fb1fa (diff)
downloadchromium_src-1a89ea1ad2d890cf196eee4c24a8dec9fa573961.zip
chromium_src-1a89ea1ad2d890cf196eee4c24a8dec9fa573961.tar.gz
chromium_src-1a89ea1ad2d890cf196eee4c24a8dec9fa573961.tar.bz2
Make NativeControl inherit from base::WindowImpl instead of CWindowImpl to reduce a dependency on ATL.
BUG=5027 TEST=none Review URL: http://codereview.chromium.org/169015 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@23645 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r--base/window_impl.cc9
-rw-r--r--base/window_impl.h3
-rw-r--r--views/controls/native_control.cc51
-rw-r--r--views/widget/widget_win.cc6
-rw-r--r--views/widget/widget_win.h10
5 files changed, 39 insertions, 40 deletions
diff --git a/base/window_impl.cc b/base/window_impl.cc
index c3b3ad4..7438bd9 100644
--- a/base/window_impl.cc
+++ b/base/window_impl.cc
@@ -155,7 +155,14 @@ LRESULT WindowImpl::OnWndProc(UINT message, WPARAM w_param, LPARAM l_param) {
// Handle the message if it's in our message map; otherwise, let the system
// handle it.
if (!ProcessWindowMessage(hwnd_, message, w_param, l_param, result))
- result = DefWindowProc(hwnd_, message, w_param, l_param);
+ result = DefWindowProc(hwnd_, message, w_param, l_param);
+
+ if (message == WM_NCDESTROY) {
+ // Notify the subclass that this is the last message before the window
+ // is destroyed.
+ OnFinalMessage(hwnd_);
+ hwnd_ = NULL;
+ }
return result;
}
diff --git a/base/window_impl.h b/base/window_impl.h
index 2941c3d9..ff8dd15 100644
--- a/base/window_impl.h
+++ b/base/window_impl.h
@@ -50,6 +50,9 @@ class WindowImpl : public MessageMapInterface {
// Retrieves the default window icon to use for windows if none is specified.
virtual HICON GetDefaultWindowIcon() const;
+ // Override this to be notified of the last message.
+ virtual void OnFinalMessage(HWND window) {}
+
// Returns the HWND associated with this Window.
HWND hwnd() const { return hwnd_; }
diff --git a/views/controls/native_control.cc b/views/controls/native_control.cc
index fd247f9..b506cb8 100644
--- a/views/controls/native_control.cc
+++ b/views/controls/native_control.cc
@@ -4,15 +4,12 @@
#include "views/controls/native_control.h"
-#include <atlbase.h>
-#include <atlapp.h>
-#include <atlcrack.h>
-#include <atlframe.h>
-#include <atlmisc.h>
+#include <algorithm>
#include "app/l10n_util_win.h"
#include "base/logging.h"
#include "base/win_util.h"
+#include "base/window_impl.h"
#include "views/background.h"
#include "views/border.h"
#include "views/controls/native/native_view_host.h"
@@ -30,16 +27,13 @@ static const wchar_t* const kHandlerKey =
// Maps to the NativeControl.
static const wchar_t* const kNativeControlKey = L"__NATIVE_CONTROL__";
-class NativeControlContainer : public CWindowImpl<NativeControlContainer,
- CWindow,
- CWinTraits<WS_CHILD | WS_CLIPSIBLINGS |
- WS_CLIPCHILDREN>> {
+class NativeControlContainer : public base::WindowImpl {
public:
-
explicit NativeControlContainer(NativeControl* parent) : parent_(parent),
control_(NULL) {
- Create(parent->GetWidget()->GetNativeView());
- ::ShowWindow(m_hWnd, SW_SHOW);
+ set_window_style(WS_CHILD | WS_CLIPSIBLINGS | WS_CLIPCHILDREN);
+ Init(parent->GetWidget()->GetNativeView(), gfx::Rect());
+ ShowWindow(hwnd(), SW_SHOW);
}
virtual ~NativeControlContainer() {
@@ -47,8 +41,7 @@ class NativeControlContainer : public CWindowImpl<NativeControlContainer,
// NOTE: If you add a new message, be sure and verify parent_ is valid before
// calling into parent_.
- DECLARE_FRAME_WND_CLASS(L"ChromeViewsNativeControlContainer", NULL);
- BEGIN_MSG_MAP(NativeControlContainer);
+ BEGIN_MSG_MAP_EX(NativeControlContainer);
MSG_WM_CREATE(OnCreate);
MSG_WM_ERASEBKGND(OnEraseBkgnd);
MSG_WM_PAINT(OnPaint);
@@ -79,7 +72,7 @@ class NativeControlContainer : public CWindowImpl<NativeControlContainer,
private:
LRESULT OnCreate(LPCREATESTRUCT create_struct) {
- control_ = parent_->CreateNativeControl(m_hWnd);
+ control_ = parent_->CreateNativeControl(hwnd());
// We subclass the control hwnd so we get the WM_KEYDOWN messages.
WNDPROC original_handler =
@@ -88,7 +81,7 @@ class NativeControlContainer : public CWindowImpl<NativeControlContainer,
SetProp(control_, kHandlerKey, original_handler);
SetProp(control_, kNativeControlKey , parent_);
- ::ShowWindow(control_, SW_SHOW);
+ ShowWindow(control_, SW_SHOW);
return 1;
}
@@ -98,12 +91,12 @@ class NativeControlContainer : public CWindowImpl<NativeControlContainer,
void OnPaint(HDC ignore) {
PAINTSTRUCT ps;
- HDC dc = ::BeginPaint(*this, &ps);
- ::EndPaint(*this, &ps);
+ HDC dc = BeginPaint(hwnd(), &ps);
+ EndPaint(hwnd(), &ps);
}
void OnSize(int type, const CSize& sz) {
- ::MoveWindow(control_, 0, 0, sz.cx, sz.cy, TRUE);
+ MoveWindow(control_, 0, 0, sz.cx, sz.cy, TRUE);
}
LRESULT OnCommand(UINT code, int id, HWND source) {
@@ -174,7 +167,7 @@ NativeControl::NativeControl() : hwnd_view_(NULL),
NativeControl::~NativeControl() {
if (container_) {
container_->ResetParent();
- ::DestroyWindow(*container_);
+ DestroyWindow(container_->hwnd());
}
}
@@ -186,15 +179,15 @@ void NativeControl::ValidateNativeControl() {
if (!container_ && IsVisible()) {
container_ = new NativeControlContainer(this);
- hwnd_view_->Attach(*container_);
+ hwnd_view_->Attach(container_->hwnd());
if (!enabled_)
EnableWindow(GetNativeControlHWND(), enabled_);
// This message ensures that the focus border is shown.
- ::SendMessage(container_->GetControl(),
- WM_CHANGEUISTATE,
- MAKELPARAM(UIS_CLEAR, UISF_HIDEFOCUS),
- 0);
+ SendMessage(container_->GetControl(),
+ WM_CHANGEUISTATE,
+ MAKELPARAM(UIS_CLEAR, UISF_HIDEFOCUS),
+ 0);
}
}
@@ -274,7 +267,7 @@ void NativeControl::OnContextMenu(const CPoint& location) {
void NativeControl::Focus() {
if (container_) {
DCHECK(container_->GetControl());
- ::SetFocus(container_->GetControl());
+ SetFocus(container_->GetControl());
}
}
@@ -295,7 +288,7 @@ void NativeControl::SetVisible(bool f) {
if (f != IsVisible()) {
View::SetVisible(f);
if (!f && container_) {
- ::DestroyWindow(*container_);
+ DestroyWindow(container_->hwnd());
} else if (f && !container_) {
ValidateNativeControl();
}
@@ -319,13 +312,13 @@ void NativeControl::VisibilityChanged(View* starting_from, bool is_visible) {
}
void NativeControl::SetFixedWidth(int width, Alignment alignment) {
- DCHECK(width > 0);
+ DCHECK_GT(width, 0);
fixed_width_ = width;
horizontal_alignment_ = alignment;
}
void NativeControl::SetFixedHeight(int height, Alignment alignment) {
- DCHECK(height > 0);
+ DCHECK_GT(height, 0);
fixed_height_ = height;
vertical_alignment_ = alignment;
}
diff --git a/views/widget/widget_win.cc b/views/widget/widget_win.cc
index f54da9a..255c63d 100644
--- a/views/widget/widget_win.cc
+++ b/views/widget/widget_win.cc
@@ -913,11 +913,7 @@ LRESULT WidgetWin::OnWndProc(UINT message, WPARAM w_param, LPARAM l_param) {
if (ProcessNativeControlMessage(message, w_param, l_param, &result))
return result;
- // Otherwise we handle everything else.
- if (!ProcessWindowMessage(window, message, w_param, l_param, result))
- result = DefWindowProc(window, message, w_param, l_param);
- if (message == WM_NCDESTROY)
- OnFinalMessage(window);
+ result = base::WindowImpl::OnWndProc(message, w_param, l_param);
if (message == WM_ACTIVATE)
PostProcessActivateMessage(this, LOWORD(w_param));
return result;
diff --git a/views/widget/widget_win.h b/views/widget/widget_win.h
index 3fbcc93..072041f 100644
--- a/views/widget/widget_win.h
+++ b/views/widget/widget_win.h
@@ -303,6 +303,7 @@ class WidgetWin : public base::WindowImpl,
protected:
// Overridden from WindowImpl:
virtual HICON GetDefaultWindowIcon() const;
+ virtual void OnFinalMessage(HWND window);
virtual LRESULT OnWndProc(UINT message, WPARAM w_param, LPARAM l_param);
// Message Handlers
@@ -374,7 +375,10 @@ class WidgetWin : public base::WindowImpl,
virtual void OnMove(const CPoint& point) { SetMsgHandled(FALSE); }
virtual void OnMoving(UINT param, const LPRECT new_bounds) { }
virtual LRESULT OnMouseRange(UINT msg, WPARAM w_param, LPARAM l_param);
- virtual LRESULT OnNCActivate(BOOL active) { SetMsgHandled(FALSE); return 0; }
+ virtual LRESULT OnNCActivate(BOOL active) {
+ SetMsgHandled(FALSE);
+ return 0;
+ }
virtual LRESULT OnNCCalcSize(BOOL w_param, LPARAM l_param) {
SetMsgHandled(FALSE);
return 0;
@@ -448,10 +452,6 @@ class WidgetWin : public base::WindowImpl,
SetMsgHandled(FALSE);
}
- // deletes this window as it is destroyed, override to provide different
- // behavior.
- virtual void OnFinalMessage(HWND window);
-
// Start tracking all mouse events so that this window gets sent mouse leave
// messages too. |is_nonclient| is true when we should track WM_NCMOUSELEAVE
// messages instead of WM_MOUSELEAVE ones.