-
from wxPython.wx import *
try:
from wxPython.glcanvas import *
box.Add(btn, 0, wxALIGN_CENTER|wxALL, 15)
EVT_BUTTON(self, k, self.OnButton)
+ #** Enable this to show putting a wxGLCanvas on the wxPanel
+ if 0:
+ c = CubeCanvas(self)
+ c.SetSize((200, 200))
+ box.Add(c, 0, wxALIGN_CENTER|wxALL, 15)
+
self.SetAutoLayout(true)
self.SetSizer(box)
+
def OnButton(self, evt):
canvasClassName = buttonDefs[evt.GetId()][0]
canvasClass = eval(canvasClassName)
+
class MyCanvasBase(wxGLCanvas):
def __init__(self, parent):
wxGLCanvas.__init__(self, parent, -1)
EVT_ERASE_BACKGROUND(self, self.OnEraseBackground)
EVT_SIZE(self, self.OnSize)
EVT_PAINT(self, self.OnPaint)
- #EVT_LEFT_DOWN(self, self.OnMouseDown) # needs fixing...
- #EVT_LEFT_UP(self, self.OnMouseUp)
- #EVT_MOTION(self, self.OnMouseMotion)
+ EVT_LEFT_DOWN(self, self.OnMouseDown) # needs fixing...
+ EVT_LEFT_UP(self, self.OnMouseUp)
+ EVT_MOTION(self, self.OnMouseMotion)
def OnEraseBackground(self, event):
pass # Do nothing, to avoid flashing on MSW.
if evt.Dragging() and evt.LeftIsDown():
self.x, self.y = self.lastx, self.lasty
self.x, self.y = evt.GetPosition()
- self.Refresh()
+ self.Refresh(false)
glVertex3f(-0.5, 0.5,-0.5)
glEnd()
- glRotatef(self.lasty - self.y, 1.0, 0.0, 0.0);
- glRotatef(self.lastx - self.x, 0.0, 1.0, 0.0);
+ glRotatef((self.lasty - self.y)/100., 1.0, 0.0, 0.0);
+ glRotatef((self.lastx - self.x)/100., 0.0, 1.0, 0.0);
self.SwapBuffers()
glDepthFunc(GL_LESS)
glEnable(GL_DEPTH_TEST)
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)
+ # position viewer
+ glMatrixMode(GL_MODELVIEW);
def OnDraw(self):
# clear color and depth buffers
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
- # position viewer
- glMatrixMode(GL_MODELVIEW);
# use a fresh transformation matrix
glPushMatrix()
# position object
glTranslate(0, -1, 0)
glRotate(250, 1, 0, 0)
- glutSolidCone(1, 2, 50, 10)
+ glutSolidCone(0.5, 1, 30, 5)
glPopMatrix()
+ glRotatef((self.lasty - self.y)/100., 0.0, 0.0, 1.0);
+ glRotatef(0.0, (self.lastx - self.x)/100., 1.0, 0.0);
# push into visible buffer
self.SwapBuffers()
if __name__ == '__main__':
_test()
+