Added some basic event handler.
This commit is contained in:
parent
de9af5d6bd
commit
a7799bf2d9
@ -12,9 +12,148 @@
|
|||||||
#include <osg/TextureRectangle>
|
#include <osg/TextureRectangle>
|
||||||
#include <osg/TexMat>
|
#include <osg/TexMat>
|
||||||
#include <osg/CullFace>
|
#include <osg/CullFace>
|
||||||
|
#include <osg/ImageStream>
|
||||||
|
|
||||||
#include <osgGA/TrackballManipulator>
|
#include <osgGA/TrackballManipulator>
|
||||||
|
|
||||||
|
class MovieEventHandler : public osgGA::GUIEventHandler
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
MovieEventHandler() {}
|
||||||
|
|
||||||
|
void set(osg::Node* node);
|
||||||
|
|
||||||
|
virtual void accept(osgGA::GUIEventHandlerVisitor& v) { v.visit(*this); }
|
||||||
|
|
||||||
|
virtual bool handle(const osgGA::GUIEventAdapter& ea,osgGA::GUIActionAdapter&);
|
||||||
|
|
||||||
|
virtual void getUsage(osg::ApplicationUsage& usage) const;
|
||||||
|
|
||||||
|
typedef std::vector< osg::ref_ptr<osg::ImageStream> > ImageStreamList;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
virtual ~MovieEventHandler() {}
|
||||||
|
|
||||||
|
class FindImageStreamsVisitor : public osg::NodeVisitor
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
FindImageStreamsVisitor(ImageStreamList& imageStreamList):
|
||||||
|
_imageStreamList(imageStreamList) {}
|
||||||
|
|
||||||
|
virtual void apply(osg::Geode& geode)
|
||||||
|
{
|
||||||
|
apply(geode.getStateSet());
|
||||||
|
|
||||||
|
for(unsigned int i=0;i<geode.getNumDrawables();++i)
|
||||||
|
{
|
||||||
|
apply(geode.getDrawable(i)->getStateSet());
|
||||||
|
}
|
||||||
|
|
||||||
|
traverse(geode);
|
||||||
|
}
|
||||||
|
|
||||||
|
virtual void apply(osg::Node& node)
|
||||||
|
{
|
||||||
|
apply(node.getStateSet());
|
||||||
|
traverse(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void apply(osg::StateSet* stateset)
|
||||||
|
{
|
||||||
|
if (!stateset) return;
|
||||||
|
|
||||||
|
osg::StateAttribute* attr = stateset->getTextureAttribute(0,osg::StateAttribute::TEXTURE);
|
||||||
|
if (attr)
|
||||||
|
{
|
||||||
|
osg::Texture2D* texture2D = dynamic_cast<osg::Texture2D*>(attr);
|
||||||
|
if (texture2D) apply(dynamic_cast<osg::ImageStream*>(texture2D->getImage()));
|
||||||
|
|
||||||
|
osg::TextureRectangle* textureRec = dynamic_cast<osg::TextureRectangle*>(attr);
|
||||||
|
if (textureRec) apply(dynamic_cast<osg::ImageStream*>(textureRec->getImage()));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
inline void apply(osg::ImageStream* imagestream)
|
||||||
|
{
|
||||||
|
if (imagestream) _imageStreamList.push_back(imagestream);
|
||||||
|
}
|
||||||
|
|
||||||
|
ImageStreamList& _imageStreamList;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
ImageStreamList _imageStreamList;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void MovieEventHandler::set(osg::Node* node)
|
||||||
|
{
|
||||||
|
_imageStreamList.clear();
|
||||||
|
if (node)
|
||||||
|
{
|
||||||
|
FindImageStreamsVisitor fisv(_imageStreamList);
|
||||||
|
node->accept(fisv);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool MovieEventHandler::handle(const osgGA::GUIEventAdapter& ea,osgGA::GUIActionAdapter&)
|
||||||
|
{
|
||||||
|
switch(ea.getEventType())
|
||||||
|
{
|
||||||
|
case(osgGA::GUIEventAdapter::KEYDOWN):
|
||||||
|
{
|
||||||
|
if (ea.getKey()=='s')
|
||||||
|
{
|
||||||
|
for(ImageStreamList::iterator itr=_imageStreamList.begin();
|
||||||
|
itr!=_imageStreamList.end();
|
||||||
|
++itr)
|
||||||
|
{
|
||||||
|
std::cout<<"Play"<<std::endl;
|
||||||
|
(*itr)->play();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if (ea.getKey()=='p')
|
||||||
|
{
|
||||||
|
for(ImageStreamList::iterator itr=_imageStreamList.begin();
|
||||||
|
itr!=_imageStreamList.end();
|
||||||
|
++itr)
|
||||||
|
{
|
||||||
|
std::cout<<"Pause"<<std::endl;
|
||||||
|
(*itr)->pause();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if (ea.getKey()=='r')
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
else if (ea.getKey()=='l')
|
||||||
|
{
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void MovieEventHandler::getUsage(osg::ApplicationUsage& usage) const
|
||||||
|
{
|
||||||
|
usage.addKeyboardMouseBinding("p","Pause movie");
|
||||||
|
usage.addKeyboardMouseBinding("s","Play movie");
|
||||||
|
usage.addKeyboardMouseBinding("r","Start movie");
|
||||||
|
usage.addKeyboardMouseBinding("l","Toggle looping of movie");
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
osg::Geometry* createTexturedQuadGeometry(const osg::Vec3& pos,float width,float height, osg::Image* image)
|
osg::Geometry* createTexturedQuadGeometry(const osg::Vec3& pos,float width,float height, osg::Image* image)
|
||||||
{
|
{
|
||||||
bool useTextureRectangle = true;
|
bool useTextureRectangle = true;
|
||||||
@ -64,6 +203,11 @@ int main(int argc, char** argv)
|
|||||||
// set up the value with sensible default event handlers.
|
// set up the value with sensible default event handlers.
|
||||||
viewer.setUpViewer(osgProducer::Viewer::STANDARD_SETTINGS);
|
viewer.setUpViewer(osgProducer::Viewer::STANDARD_SETTINGS);
|
||||||
|
|
||||||
|
// register the handler to add keyboard and mosue handling.
|
||||||
|
MovieEventHandler* meh = new MovieEventHandler();
|
||||||
|
viewer.getEventHandlerList().push_front(meh);
|
||||||
|
|
||||||
|
|
||||||
// get details on keyboard and mouse bindings used by the viewer.
|
// get details on keyboard and mouse bindings used by the viewer.
|
||||||
viewer.getUsage(*arguments.getApplicationUsage());
|
viewer.getUsage(*arguments.getApplicationUsage());
|
||||||
|
|
||||||
@ -87,6 +231,8 @@ int main(int argc, char** argv)
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// pass the model to the MovieEventHandler so it can pick out ImageStream's to manipulate.
|
||||||
|
meh->set(geode);
|
||||||
|
|
||||||
// report any errors if they have occured when parsing the program aguments.
|
// report any errors if they have occured when parsing the program aguments.
|
||||||
if (arguments.errors())
|
if (arguments.errors())
|
||||||
|
Loading…
Reference in New Issue
Block a user