Je viens de rencontrer cette situation étrange: J'ai trouvé un exemple, où OnPaint de wx.Frame est substituée, et un cercle est dessiné. Curieusement, dès que j'ajoute même un seul panneau au cadre, le cercle n'est plus dessiné - en fait, OnPaint n'est plus appelé au plus! (Btw, j'ai essayé l'exemple sur Ubuntu Lucid)wxpython: ajouter un panneau à wx.Frame désactive/est en conflit avec OnPaint de wx.Frame?
Quelqu'un peut-il m'expliquer si c'est le comportement attendu, et comment gérer correctement un wx.Frame OnPaint
, si le wx.Frame a des panneaux enfants? Petit exemple de code est ci-dessous ..
Merci d'avance pour toute réponse,
Cheers!
Le code:
#!/usr/bin/env python
# http://www.linuxquestions.org/questions/programming-9/wxwidgets-wxpython-drawing-problems-with-onpaint-event-703946/
import wx
class MainWindow(wx.Frame):
def __init__(self, parent, title, size=wx.DefaultSize):
wx.Frame.__init__(self, parent, wx.ID_ANY, title, wx.DefaultPosition, size)
self.circles = list()
self.displaceX = 30
self.displaceY = 30
circlePos = (self.displaceX, self.displaceY)
self.circles.append(circlePos)
## uncommenting either only first, or both of
## the commands below, causes OnPaint *not* to be called anymore!
#~ self.panel = wx.Panel(self, wx.ID_ANY)
#~ self.mpanelA = wx.Panel(self.panel, -1, size=(200,50))
self.Bind(wx.EVT_PAINT, self.OnPaint)
def OnPaint(self, e):
print "OnPaint called"
dc = wx.PaintDC(self)
dc.SetPen(wx.Pen(wx.BLUE))
dc.SetBrush(wx.Brush(wx.BLUE))
# Go through the list of circles to draw all of them
for circle in self.circles:
dc.DrawCircle(circle[0], circle[1], 10)
def main():
app = wx.App()
win = MainWindow(None, "Draw delayed circles", size=(620,460))
win.Show()
app.MainLoop()
if __name__ == "__main__":
main()