Added ShapedWindow sample to the wxPython demo
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/branches/WX_2_4_BRANCH@19875 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -29,6 +29,7 @@ _treeList = [
|
|||||||
'wxIntCtrl',
|
'wxIntCtrl',
|
||||||
'wxPyColourChooser',
|
'wxPyColourChooser',
|
||||||
'wxScrolledPanel',
|
'wxScrolledPanel',
|
||||||
|
'ShapedWindow',
|
||||||
]),
|
]),
|
||||||
|
|
||||||
# managed windows == things with a (optional) caption you can close
|
# managed windows == things with a (optional) caption you can close
|
||||||
|
106
wxPython/demo/ShapedWindow.py
Normal file
106
wxPython/demo/ShapedWindow.py
Normal file
@@ -0,0 +1,106 @@
|
|||||||
|
|
||||||
|
from wxPython.wx import *
|
||||||
|
import images
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
class TestFrame(wxFrame):
|
||||||
|
def __init__(self, parent, log):
|
||||||
|
self.log = log
|
||||||
|
wxFrame.__init__(self, parent, -1, "Shaped Window")
|
||||||
|
self.hasShape = False
|
||||||
|
|
||||||
|
EVT_LEFT_DCLICK(self, self.OnDoubleClick)
|
||||||
|
EVT_LEFT_DOWN(self, self.OnLeftDown)
|
||||||
|
EVT_LEFT_UP(self, self.OnLeftUp)
|
||||||
|
EVT_MOTION(self, self.OnMouseMove)
|
||||||
|
EVT_RIGHT_UP(self, self.OnExit)
|
||||||
|
EVT_PAINT(self, self.OnPaint)
|
||||||
|
EVT_SIZE(self, self.OnSize)
|
||||||
|
|
||||||
|
self.bmp = images.getTuxBitmap()
|
||||||
|
w, h = self.bmp.GetWidth(), self.bmp.GetHeight()
|
||||||
|
#self.SetClientSize( (w, h) )
|
||||||
|
self.SetToolTipString("Right-click to close the window")
|
||||||
|
s = wxStaticText(self, -1, "Double-click the image to set the window shape",
|
||||||
|
pos = (w+10, h))
|
||||||
|
s.SetFont(wxFont(12, wxSWISS, wxNORMAL, wxBOLD))
|
||||||
|
s.SetSize(s.GetBestSize())
|
||||||
|
self.Fit()
|
||||||
|
|
||||||
|
|
||||||
|
def SetWindowShape(self, *evt):
|
||||||
|
r = wxRegionFromBitmap(self.bmp)
|
||||||
|
self.hasShape = self.SetShape(r)
|
||||||
|
|
||||||
|
|
||||||
|
def OnDoubleClick(self, evt):
|
||||||
|
if self.hasShape:
|
||||||
|
self.SetShape(wxRegion())
|
||||||
|
self.hasShape = False
|
||||||
|
else:
|
||||||
|
self.SetWindowShape()
|
||||||
|
|
||||||
|
|
||||||
|
def OnPaint(self, evt):
|
||||||
|
dc = wxPaintDC(self)
|
||||||
|
dc.DrawBitmap(self.bmp, 0,0, True)
|
||||||
|
|
||||||
|
def OnSize(self, evt):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def OnExit(self, evt):
|
||||||
|
self.Close()
|
||||||
|
|
||||||
|
|
||||||
|
def OnLeftDown(self, evt):
|
||||||
|
self.CaptureMouse()
|
||||||
|
pos = self.ClientToScreen(evt.GetPosition())
|
||||||
|
origin = self.GetPosition()
|
||||||
|
dx = pos.x - origin.x
|
||||||
|
dy = pos.y - origin.y
|
||||||
|
self.delta = wxPoint(dx, dy)
|
||||||
|
|
||||||
|
|
||||||
|
def OnLeftUp(self, evt):
|
||||||
|
if self.HasCapture():
|
||||||
|
self.ReleaseMouse()
|
||||||
|
|
||||||
|
|
||||||
|
def OnMouseMove(self, evt):
|
||||||
|
if evt.Dragging() and evt.LeftIsDown():
|
||||||
|
pos = self.ClientToScreen(evt.GetPosition())
|
||||||
|
fp = (pos.x - self.delta.x, pos.y - self.delta.y)
|
||||||
|
self.Move(fp)
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
def runTest(frame, nb, log):
|
||||||
|
win = TestFrame(nb, log)
|
||||||
|
frame.otherWin = win
|
||||||
|
win.Show(True)
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
overview = """<html><body>
|
||||||
|
<h2><center>Shaped Window</center></h2>
|
||||||
|
|
||||||
|
Top level windows now have a SetShape method that lets you set a
|
||||||
|
non-rectangular shape for the window using a wxRegion. All pixels
|
||||||
|
outside of the region will not be drawn and the window will not be
|
||||||
|
sensitive to the mouse in those areas either.
|
||||||
|
|
||||||
|
</body></html>
|
||||||
|
"""
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
import sys,os
|
||||||
|
import run
|
||||||
|
run.main(['', os.path.basename(sys.argv[0])])
|
||||||
|
|
@@ -60,6 +60,7 @@ command_lines = [
|
|||||||
"-a -u -n WizTest1 bmp_source/wiztest1.bmp images.py",
|
"-a -u -n WizTest1 bmp_source/wiztest1.bmp images.py",
|
||||||
"-a -u -n WizTest2 bmp_source/wiztest2.bmp images.py",
|
"-a -u -n WizTest2 bmp_source/wiztest2.bmp images.py",
|
||||||
|
|
||||||
|
"-a -u -n Tux bmp_source/Tux.png images.py",
|
||||||
|
|
||||||
|
|
||||||
" -u -c bmp_source/001.png throbImages.py",
|
" -u -c bmp_source/001.png throbImages.py",
|
||||||
|
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user