1 ///////////////////////////////////////////////////////////////////////////////
2 // Name: src/msw/nonownedwnd.cpp
3 // Purpose: wxNonOwnedWindow implementation for MSW.
4 // Author: Vadim Zeitlin
5 // Created: 2011-10-09 (extracted from src/msw/toplevel.cpp)
7 // Copyright: (c) 2011 Vadim Zeitlin <vadim@wxwidgets.org>
8 // Licence: wxWindows licence
9 ///////////////////////////////////////////////////////////////////////////////
11 // ============================================================================
13 // ============================================================================
15 // ----------------------------------------------------------------------------
17 // ----------------------------------------------------------------------------
19 // for compilers that support precompilation, includes "wx.h".
20 #include "wx/wxprec.h"
26 // This class can't be implemented and hence is not used under Win CE.
30 #include "wx/frame.h" // Only for wxFRAME_SHAPED.
31 #include "wx/region.h"
32 #include "wx/msw/private.h"
35 #include "wx/nonownedwnd.h"
37 #include "wx/msw/wrapgdip.h"
38 #include "wx/graphics.h"
39 #include "wx/scopedptr.h"
41 // ============================================================================
42 // wxNonOwnedWindow implementation
43 // ============================================================================
45 bool wxNonOwnedWindow::DoClearShape()
47 if (::SetWindowRgn(GetHwnd(), NULL
, TRUE
) == 0)
49 wxLogLastError(wxT("SetWindowRgn"));
56 bool wxNonOwnedWindow::DoSetRegionShape(const wxRegion
& region
)
58 // Windows takes ownership of the region, so
59 // we'll have to make a copy of the region to give to it.
60 DWORD noBytes
= ::GetRegionData(GetHrgnOf(region
), 0, NULL
);
61 RGNDATA
*rgnData
= (RGNDATA
*) new char[noBytes
];
62 ::GetRegionData(GetHrgnOf(region
), noBytes
, rgnData
);
63 HRGN hrgn
= ::ExtCreateRegion(NULL
, noBytes
, rgnData
);
64 delete[] (char*) rgnData
;
66 // SetWindowRgn expects the region to be in coordinates
67 // relative to the window, not the client area.
68 const wxPoint clientOrigin
= GetClientAreaOrigin();
69 ::OffsetRgn(hrgn
, -clientOrigin
.x
, -clientOrigin
.y
);
71 // Now call the shape API with the new region.
72 if (::SetWindowRgn(GetHwnd(), hrgn
, TRUE
) == 0)
74 wxLogLastError(wxT("SetWindowRgn"));
80 #if wxUSE_GRAPHICS_CONTEXT
82 #include "wx/msw/wrapgdip.h"
84 // This class contains data used only when SetPath(wxGraphicsPath) is called.
86 // Notice that it derives from wxEvtHandler solely to allow Connect()-ing its
87 // OnPaint() method to the window, we could get rid of this inheritance once
88 // Bind() can be used in wx sources.
89 class wxNonOwnedWindowShapeImpl
: public wxEvtHandler
92 wxNonOwnedWindowShapeImpl(wxNonOwnedWindow
* win
, const wxGraphicsPath
& path
) :
96 // Create the region corresponding to this path and set it as windows
98 wxScopedPtr
<wxGraphicsContext
> context(wxGraphicsContext::Create(win
));
99 Region
gr(static_cast<GraphicsPath
*>(m_path
.GetNativePath()));
102 gr
.GetHRGN(static_cast<Graphics
*>(context
->GetNativeContext()))
107 // Connect to the paint event to draw the border.
109 // TODO: Do this only optionally?
113 wxPaintEventHandler(wxNonOwnedWindowShapeImpl::OnPaint
),
119 virtual ~wxNonOwnedWindowShapeImpl()
124 wxPaintEventHandler(wxNonOwnedWindowShapeImpl::OnPaint
),
131 void OnPaint(wxPaintEvent
& event
)
136 wxScopedPtr
<wxGraphicsContext
> context(wxGraphicsContext::Create(dc
));
137 context
->SetPen(wxPen(*wxLIGHT_GREY
, 2));
138 context
->StrokePath(m_path
);
141 wxNonOwnedWindow
* const m_win
;
142 wxGraphicsPath m_path
;
144 wxDECLARE_NO_COPY_CLASS(wxNonOwnedWindowShapeImpl
);
147 wxNonOwnedWindow::wxNonOwnedWindow()
152 wxNonOwnedWindow::~wxNonOwnedWindow()
157 bool wxNonOwnedWindow::DoSetPathShape(const wxGraphicsPath
& path
)
160 m_shapeImpl
= new wxNonOwnedWindowShapeImpl(this, path
);
165 #else // !wxUSE_GRAPHICS_CONTEXT
167 // Trivial ctor and dtor as we don't have anything to do when wxGraphicsContext
168 // is not used but still define them here to avoid adding even more #if checks
169 // to the header, it it doesn't do any harm even though it's not needed.
170 wxNonOwnedWindow::wxNonOwnedWindow()
174 wxNonOwnedWindow::~wxNonOwnedWindow()
178 #endif // wxUSE_GRAPHICS_CONTEXT/!wxUSE_GRAPHICS_CONTEXT
180 #endif // !__WXWINCE__