mirror of
https://github.com/Sneed-Group/Poodletooth-iLand
synced 2025-01-09 17:53:50 +00:00
198 lines
5.4 KiB
Python
198 lines
5.4 KiB
Python
|
#----------------------------------------------------------------------
|
||
|
# Name: wx.lib.statbmp
|
||
|
# Purpose: A generic StaticBitmap class.
|
||
|
#
|
||
|
# Author: Robin Dunn
|
||
|
#
|
||
|
# Created: 12-May-2004
|
||
|
# Copyright: (c) 2004 by Total Control Software
|
||
|
# Licence: wxWindows license
|
||
|
# Tags: phoenix-port, unittest, documented
|
||
|
#----------------------------------------------------------------------
|
||
|
|
||
|
"""
|
||
|
:class:`GenStaticBitmap` is a generic implementation of :class:`StaticBitmap`.
|
||
|
|
||
|
|
||
|
Description
|
||
|
===========
|
||
|
|
||
|
:class:`GenStaticBitmap` is a generic implementation of :class:`StaticBitmap`.
|
||
|
|
||
|
Some of the platforms supported by wxPython (most notably GTK), do not consider
|
||
|
:class:`StaticBitmap` as a separate widget; instead, the bitmap is just drawn on its
|
||
|
parent window. This essentially bars the use of almost all mouse events (such as
|
||
|
detection of mouse motions, mouse clicks and so on).
|
||
|
|
||
|
Using :class:`GenStaticBitmap` will overcome all the problems described above, as it
|
||
|
is a generic widget and a real window on its own.
|
||
|
|
||
|
|
||
|
Usage
|
||
|
=====
|
||
|
|
||
|
Sample usage::
|
||
|
|
||
|
import wx
|
||
|
import wx.lib.statbmp as SB
|
||
|
|
||
|
app = wx.App(0)
|
||
|
|
||
|
frame = wx.Frame(None, -1, "wx.lib.statbmp Test")
|
||
|
panel = wx.Panel(frame)
|
||
|
|
||
|
bmp = wx.ArtProvider.GetBitmap(wx.ART_INFORMATION, wx.ART_OTHER, (16, 16))
|
||
|
st1 = SB.GenStaticBitmap(panel, -1, bmp, (20, 10))
|
||
|
|
||
|
bmp = wx.ArtProvider.GetBitmap(wx.ART_WARNING, wx.ART_OTHER, (32, 32))
|
||
|
st2 = SB.GenStaticBitmap(panel, -1, bmp, (20, 60))
|
||
|
|
||
|
frame.Show()
|
||
|
app.MainLoop()
|
||
|
|
||
|
|
||
|
"""
|
||
|
|
||
|
import wx
|
||
|
|
||
|
#----------------------------------------------------------------------
|
||
|
|
||
|
class GenStaticBitmap(wx.Control):
|
||
|
""" :class:`GenStaticBitmap` is a generic implementation of :class:`StaticBitmap`. """
|
||
|
|
||
|
labelDelta = 1
|
||
|
|
||
|
def __init__(self, parent, ID, bitmap,
|
||
|
pos = wx.DefaultPosition, size = wx.DefaultSize,
|
||
|
style = 0,
|
||
|
name = "genstatbmp"):
|
||
|
"""
|
||
|
Default class constructor.
|
||
|
|
||
|
:param `parent`: parent window, must not be ``None``;
|
||
|
:param integer `ID`: window identifier. A value of -1 indicates a default value;
|
||
|
:param Bitmap `bitmap`: the static bitmap used in the control;
|
||
|
:param `pos`: the control position. A value of (-1, -1) indicates a default position,
|
||
|
chosen by either the windowing system or wxPython, depending on platform;
|
||
|
:param `size`: the control size. A value of (-1, -1) indicates a default size,
|
||
|
chosen by either the windowing system or wxPython, depending on platform;
|
||
|
:param integer `style`: the underlying :class:`Control` style;
|
||
|
:param string `name`: the widget name.
|
||
|
|
||
|
:type parent: :class:`Window`
|
||
|
:type pos: tuple or :class:`Point`
|
||
|
:type size: tuple or :class:`Size`
|
||
|
"""
|
||
|
|
||
|
if not style & wx.BORDER_MASK:
|
||
|
style = style | wx.BORDER_NONE
|
||
|
|
||
|
wx.Control.__init__(self, parent, ID, pos, size, style,
|
||
|
wx.DefaultValidator, name)
|
||
|
self._bitmap = bitmap
|
||
|
self.InheritAttributes()
|
||
|
self.SetInitialSize(size)
|
||
|
|
||
|
self.Bind(wx.EVT_ERASE_BACKGROUND, self.OnEraseBackground)
|
||
|
self.Bind(wx.EVT_PAINT, self.OnPaint)
|
||
|
|
||
|
|
||
|
def SetBitmap(self, bitmap):
|
||
|
"""
|
||
|
Sets the bitmap label.
|
||
|
|
||
|
:param Bitmap `bitmap`: the new bitmap.
|
||
|
|
||
|
.. seealso:: :meth:`GetBitmap`
|
||
|
"""
|
||
|
|
||
|
self._bitmap = bitmap
|
||
|
self.SetInitialSize( (bitmap.GetWidth(), bitmap.GetHeight()) )
|
||
|
self.Refresh()
|
||
|
|
||
|
|
||
|
def GetBitmap(self):
|
||
|
"""
|
||
|
Returns the bitmap currently used in the control.
|
||
|
|
||
|
:rtype: Bitmap
|
||
|
|
||
|
.. seealso:: :meth:`SetBitmap`
|
||
|
"""
|
||
|
|
||
|
return self._bitmap
|
||
|
|
||
|
|
||
|
def DoGetBestSize(self):
|
||
|
"""
|
||
|
Overridden base class virtual. Determines the best size of
|
||
|
the control based on the label size and the current font.
|
||
|
|
||
|
.. note:: Overridden from :class:`Control`.
|
||
|
"""
|
||
|
|
||
|
return wx.Size(self._bitmap.GetWidth(), self._bitmap.GetHeight())
|
||
|
|
||
|
|
||
|
def AcceptsFocus(self):
|
||
|
"""
|
||
|
Can this window be given focus by mouse click?
|
||
|
|
||
|
.. note:: Overridden from :class:`Control`.
|
||
|
"""
|
||
|
|
||
|
return False
|
||
|
|
||
|
|
||
|
def GetDefaultAttributes(self):
|
||
|
"""
|
||
|
Overridden base class virtual. By default we should use
|
||
|
the same font/colour attributes as the native :class:`StaticBitmap`.
|
||
|
|
||
|
.. note:: Overridden from :class:`Control`.
|
||
|
"""
|
||
|
|
||
|
return wx.StaticBitmap.GetClassDefaultAttributes()
|
||
|
|
||
|
|
||
|
def ShouldInheritColours(self):
|
||
|
"""
|
||
|
Overridden base class virtual. If the parent has non-default
|
||
|
colours then we want this control to inherit them.
|
||
|
|
||
|
.. note:: Overridden from :class:`Control`.
|
||
|
"""
|
||
|
|
||
|
return True
|
||
|
|
||
|
|
||
|
def OnPaint(self, event):
|
||
|
"""
|
||
|
Handles the ``wx.EVT_PAINT`` for :class:`GenStaticBitmap`.
|
||
|
|
||
|
:param `event`: a :class:`PaintEvent` event to be processed.
|
||
|
"""
|
||
|
|
||
|
dc = wx.PaintDC(self)
|
||
|
if self._bitmap:
|
||
|
dc.DrawBitmap(self._bitmap, 0, 0, True)
|
||
|
|
||
|
|
||
|
def OnEraseBackground(self, event):
|
||
|
"""
|
||
|
Handles the ``wx.EVT_ERASE_BACKGROUND`` event for :class:`GenStaticBitmap`.
|
||
|
|
||
|
:param `event`: a :class:`EraseEvent` event to be processed.
|
||
|
|
||
|
.. note:: This is intentionally empty to reduce flicker.
|
||
|
"""
|
||
|
|
||
|
pass
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
#----------------------------------------------------------------------
|
||
|
|
||
|
|