General OpenGL componentThis components implements the interaction with the OpenGLDisplay service that is needed to setup, draw and move an object using OpenGL. It is recommended to use it as base class for new 3D components. It provides methods to be overridden for adding functionality. Example UsageOne of the simplest possible reasonable component would like something like this: class Point(OpenGLComponent): def draw(self): glBegin(GL_POINTS) glColor(1,0,0) glVertex(0,0,0) glEnd() A more complex component that changes colour in response to messages sent to its "colour" inbox and reacts to mouse clicks by rotationg slightly: class ChangingColourQuad(OpenGLComponent): def setup(self): self.colour = (0.5,1.0,0.5) self.addInbox("colour") self.addListenEvents([pygame.MOUSEBUTTONDOWN]) def draw(self): glBegin(GL_QUADS) glColor(*self.colour) glVertex(-1, 1, 0) glVertex(1, 1, 0) glVertex(1, -1, 0) glVertex(-1, -1, 0) glEnd() def handleEvents(self): while self.dataReady("events"): event = self.recv("events") if event.type == pygame.MOUSEBUTTONDOWN and self.identifier in event.hitobjects: self.rotation += Vector(0,0,10) self.rotation %= 360 def frame(self): while self.dataReady("colour"): self.colour = self.recv("colour") self.redraw() How does it work?OpenGLComponent provides functionality to display and move objects in OpenGL as well as to process events. The component registers at the OpenGL display service, draws its contens to a displaylist and applies its transformations to a Transform object. The display list id and the Transform objects are continuosly transfered to the display service when updated. For movement several inboxes are provided. The messages sent to these boxes are collected and applied automatically. The inboxes and expected messages are:
When an OpenGLComponent gets moved, it also provides feedback about its movement. This feedback is sent to the following outboxes:
OpenGLComponent is designed to get subclassed by opengl components. Using it as base class has the advantage not having to worry about interaction with the OpenGl display service. To add functionality, the following methods are provided to be overridden:
Stubs method are provided, so missing these out does not result in broken code. The methods get called from the main method, the following code shows in which order: def main(self): # create and send display request ... # setup function from derived objects self.setup() ... # inital apply trasformations self.applyTransforms() # generates and sends a Transform object # initial draw to display list self.redraw() # calls draw and saves it to a displaylist ... while 1: yield 1 self.applyTransforms() self.handleMovement() # handle events function from derived objects self.handleEvents() # frame function from derived objects self.frame() As can be seen here, there is no invocation of draw in the main loop. It is only called once to generate a displaylist which then gets send to the display service. This is the normal situation with static 3D objects. If you want to create a dynamic object, e.g. which changes e.g. its geometry or colour (see second example above), you need to call the redraw() method whenever changes happen. If you need to override the __init__() method, e.g. to get initialisation parameters, make sure to pass on all keyword arguments to __init__(...) of the superclass, e.g.: def __init__(self, **argd): super(ClassName, self).__init__(**argd) # get an initialisation parameter myparam = argd.get("myparam", defaultvalue) The following methods are provided to be used by inherited objects:
The are inteded to simplify component handling. For detailed description see their documentation. Every OpenGLComponent has its own pygame Clock object. It is used to measure the time between frames. The value gets stored in self.frametime in seconds and can be used by derived components to make movement time- based rather than frame-based. For example to rotate 3 degrees per second you would do something like: self.rotation.y += 3.0*self.frametime OpenGLComponent components terminate if a producerFinished or shutdownMicroprocess message is received on their "control" inbox. The received message is also forwarded to the "signal" outbox. Upon termination, this component does not unbind itself from the OpenGLDisplay service and does not free any requested resources. Kamaelia.UI.OpenGL.OpenGLComponent.OpenGLComponentclass OpenGLComponent(Axon.AdaptiveCommsComponent.AdaptiveCommsComponent)OpenGLComponent(...) -> create a new OpenGL component (not very useful though; it is rather designed to inherit from). This components implements the interaction with the OpenGLDisplay service that is needed to setup, draw and move an object using OpenGL. Keyword arguments:
Inboxes
Outboxes
Methods defined hereWarning! You should be using the inbox/outbox interface, not these methods (except construction). This documentation is designed as a roadmap as to their functionalilty for maintainers and new component developers. __init__(self, **argd)x.__init__(...) initializes x; see x.__class__.__doc__ for signature addListenEvents(self, events)Sends listening request for pygame events to the display service. The events parameter is expected to be a list of pygame event constants. applyTransforms(self)Use the objects translation/rotation/scaling values to generate a new transformation Matrix if changes have happened. draw(self)Method stub Override this method for drawing. Only use commands which are needed for drawing. Will not draw directly but be saved to a displaylist. Therefore, make sure not to use any commands which cannot be stored in displaylists (unlikely anyway). frame(self)Method stub Override this method for operations you want to do every frame. It will be called every time the component is scheduled. Do not include infinite loops, the method has to return every time it gets called. handleEvents(self)Method stub Override this method to do event handling inside. Should look like this: while self.dataReady("events"): event = self.recv("events") # handle event ... handleMovement(self)Handle movement commands received by corresponding inboxes. redraw(self)Invoke draw() and save its commands to a newly generated displaylist. The displaylist name is then sent to the display service via a "DISPLAYLIST_UPDATE" request. removeListenEvents(self, events)Sends stop listening request for pygame events to the display service. The events parameter is expected to be a list of pygame event constants. setup(self)Method stub Override this method for component setup. It will be called on the first scheduling of the component. FeedbackGot a problem with the documentation? Something unclear that could be clearer? Want to help improve it? Constructive criticism is very welcome - especially if you can suggest a better rewording! Please leave you feedback here in reply to the documentation thread in the Kamaelia blog. -- Automatic documentation generator, 05 Jun 2009 at 03:01:38 UTC/GMT |
Kamaelia
is an open source project originated from and guided by BBC
Research. For more information browse the site or get in
contact.
This is an ongoing community based development site. As a result the contents of this page is the opinions of the contributors of the pages involved not the organisations involved. Specificially, this page may contain personal views which are not the views of the BBC. (the site is powered by a wiki engine)
(C) Copyright 2008 Kamaelia Contributors, including the British Broadcasting Corporation, All Rights Reserved.