Common base class for all non-child windows.
This is the common base class of wx.TopLevelWindow and wx.PopupWindow and is not used directly.
Currently the only additional functionality it provides, compared to base wx.Window class, is the ability to set the window shape.
New in version 2.9.3.
wx.PopupWindow, wx.TopLevelWindow
If the platform supports it, sets the shape of the window to that depicted by region. |
wx.
NonOwnedWindow
(Window)¶Common base class for all non-child windows.
SetShape
(self, *args, **kw)¶SetShape (self, region : Region)
If the platform supports it, sets the shape of the window to that depicted by region.
The system will not display or respond to any mouse event for the pixels that lie outside of the region. To reset the window to the normal rectangular shape simply call SetShape
again with an empty wx.Region. Returns True
if the operation is successful.
This method is available in this class only since wxWidgets 2.9.3, previous versions only provided it in wx.TopLevelWindow.
Note that windows with non default shape have a fixed size and can’t be resized using SetSize
.
region (wx.Region) –
bool
SetShape (self, path : GraphicsPath)
Set the window shape to the given path.
Set the window shape to the interior of the given path and also draw the window border along the specified path.
For example, to make a clock-like circular window you could use
size = self.GetSize()
path = wx.GraphicsRenderer.GetDefaultRenderer().CreatePath()
path.AddCircle(size.x/2, size.y/2, 30)
self.SetShape(path)
Note that windows with non default shape have a fixed size and can’t be resized using SetSize
.
As the overload above, this method is not guaranteed to work on all platforms but currently does work in wxMSW, OSX/Cocoa and wxGTK (with the appropriate but almost always present X11 extensions) ports.
path (wx.GraphicsPath) –
bool
New in version 2.9.3.