/* OpenSceneGraph example, osgcallback. * * Permission is hereby granted, free of charge, to any person obtaining a copy * of this software and associated documentation files (the "Software"), to deal * in the Software without restriction, including without limitation the rights * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell * copies of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN * THE SOFTWARE. */ #include #include #include #include #include #include #include #include #include #include #include #include #include class UpdateCallback : public osg::NodeCallback { virtual void operator()(osg::Node* node, osg::NodeVisitor* nv) { std::cout<<"update callback - pre traverse"<drawImplementation(renderInfo); std::cout<<"draw call back - post drawImplementation"<setUpdateCallback(new DrawableUpdateCallback()); geode.getDrawable(i)->setCullCallback(new DrawableCullCallback()); geode.getDrawable(i)->setDrawCallback(new DrawableDrawCallback()); } } virtual void apply(osg::Transform& node) { apply((osg::Node&)node); } }; class MyReadFileCallback : public osgDB::Registry::ReadFileCallback { public: virtual osgDB::ReaderWriter::ReadResult readNode(const std::string& fileName, const osgDB::ReaderWriter::Options* options) { std::cout<<"before readNode"<readNodeImplementation(fileName,options); std::cout<<"after readNode"<setReadFileCallback(new MyReadFileCallback()); // initialize the viewer. osgViewer::Viewer viewer; // load the nodes from the commandline arguments. osg::ref_ptr rootnode; if (arguments.read("--test")) { osg::ref_ptr root = new osg::Group(); rootnode = root; osg::Node *test1 = new osg::Node(); test1->setUpdateCallback(new TestNodeUpdateCallback("test1")); root->addChild(test1); osg::Drawable *test2 = new osg::Drawable(); test2->osg::Node::setUpdateCallback(new TestNodeUpdateCallback("test2")); root->addChild(test2); osg::Drawable *test3 = new osg::Drawable(); test3->setUpdateCallback(new TestDrawableUpdateCallback("test3")); root->addChild(test3); osg::Geode *test4 = new osg::Geode(); osg::Drawable *drawable1 = new osg::Drawable(); drawable1->osg::Node::setUpdateCallback(new TestNodeUpdateCallback("test4")); test4->addDrawable(drawable1); root->addChild(test4); osg::Geode *test5 = new osg::Geode(); osg::Drawable *drawable2 = new osg::Drawable(); drawable2->setUpdateCallback(new TestDrawableUpdateCallback("test5")); test5->addDrawable(drawable2); root->addChild(test5); osg::Geode *test6 = new osg::Geode(); osg::Drawable *drawable3 = new osg::Drawable(); drawable3->setUpdateCallback(new TestDrawableUpdateCallback("test6")); test6->addChild(drawable3); root->addChild(test6); osg::Geode *test7 = new osg::Geode(); osg::Drawable *drawable4 = new osg::Drawable(); drawable4->osg::Node::setUpdateCallback(new TestNodeUpdateCallback("test7")); test7->addChild(drawable4); root->addChild(test7); printf("Numchildren with updates %u\n", rootnode->getNumChildrenRequiringUpdateTraversal()); } else { rootnode = osgDB::readNodeFiles(arguments); // if not loaded assume no arguments passed in, try use default mode instead. if (!rootnode) rootnode = osgDB::readNodeFile("cow.osgt"); if (!rootnode) { osg::notify(osg::NOTICE)<<"Please specify a file on the command line"<accept(icv); } viewer.getCamera()->setUpdateCallback(new CameraUpdateCallback()); viewer.getCamera()->setEventCallback(new CameraEventCallback()); // set the scene to render viewer.setSceneData(rootnode.get()); viewer.setCameraManipulator(new osgGA::TrackballManipulator); viewer.realize(); while(!viewer.done()) { OSG_NOTICE<