Further work on osg::ImageSequence/osgDB::ImagePager

This commit is contained in:
Robert Osfield
2008-07-21 21:00:57 +00:00
parent 73bcc2613c
commit 041a06b89d
12 changed files with 168 additions and 68 deletions

View File

@@ -15,24 +15,44 @@
#include <osg/ImageSequence>
#include <osg/Notify>
#include <osg/Camera>
#include <osg/NodeVisitor>
#include <osg/Texture2D>
#include <math.h>
using namespace osg;
void ImageSequence::UpdateCallback::operator () (osg::StateAttribute* attr, osg::NodeVisitor* nv)
{
const osg::FrameStamp* fs = nv!=0 ? nv->getFrameStamp() : 0;
osg::Texture2D* texture2D = dynamic_cast<osg::Texture2D*>(attr);
if (texture2D && texture2D->getImage() && fs)
{
texture2D->getImage()->update(nv);
}
}
ImageSequence::ImageSequence()
{
_referenceTime = DBL_MAX;
_imageIteratorTime = DBL_MAX;
_timeMultiplier = 1.0;
_imageIterator = _imageDuationSequence.end();
_duration = 1.0;
_pruneOldImages = false;
_imageIteratorTime = DBL_MAX;
_imageIterator = _images.end();
}
ImageSequence::ImageSequence(const ImageSequence& is,const CopyOp& copyop):
osg::ImageStream(is,copyop),
_referenceTime(is._referenceTime),
_timeMultiplier(is._timeMultiplier)
_timeMultiplier(is._timeMultiplier),
_duration(is._duration),
_pruneOldImages(is._pruneOldImages)
{
_imageIteratorTime = DBL_MAX;
_imageIterator = _images.end();
}
int ImageSequence::compare(const Image& rhs) const
@@ -40,32 +60,29 @@ int ImageSequence::compare(const Image& rhs) const
return ImageStream::compare(rhs);
}
void ImageSequence::addImageFile(const std::string& fileName, double duration)
void ImageSequence::addImageFile(const std::string& fileName)
{
if (duration<0.01) duration = 0.01;
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(_mutex);
_fileNameDurationSequence.push_back(FileNameDurationPair(fileName, duration));
_fileNames.push_back(fileName);
}
void ImageSequence::addImage(osg::Image* image, double duration)
void ImageSequence::addImage(osg::Image* image)
{
if (duration<0.01) duration = 0.01;
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(_mutex);
_imageDuationSequence.push_back(ImageDurationPair(image, duration));
_images.push_back(image);
if (_imageIterator==_imageDuationSequence.end())
if (_imageIterator==_images.end())
{
_imageIterator = _imageDuationSequence.begin();
_imageIterator = _images.begin();
_imageIteratorTime = _referenceTime;
setImageToChild(_imageIterator->first.get());
setImageToChild(_imageIterator->get());
}
}
void ImageSequence::setImageToChild(const osg::Image* image)
{
// osg::notify(osg::NOTICE)<<"setImageToChild("<<image<<")"<<std::endl;
setImage(image->s(),image->t(),image->r(),
image->getInternalTextureFormat(),
image->getPixelFormat(),image->getDataType(),
@@ -74,10 +91,14 @@ void ImageSequence::setImageToChild(const osg::Image* image)
image->getPacking());
}
void ImageSequence::update(const osg::FrameStamp* fs)
void ImageSequence::update(osg::NodeVisitor* nv)
{
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(_mutex);
// osg::notify(osg::NOTICE)<<"ImageSequence::update("<<fs<<")"<<std::endl;
osg::NodeVisitor::ImageRequestHandler* irh = nv->getImageRequestHandler();
const osg::FrameStamp* fs = nv->getFrameStamp();
// osg::notify(osg::NOTICE)<<"ImageSequence::update("<<fs<<", "<<irh<<")"<<std::endl;
if (_referenceTime == DBL_MAX)
{
@@ -90,33 +111,38 @@ void ImageSequence::update(const osg::FrameStamp* fs)
}
double time = (fs->getSimulationTime() - _referenceTime)*_timeMultiplier;
double delta = _fileNames.empty() ?
_duration / _images.size() :
_duration / _fileNames.size();
Images::iterator previous_imageIterator = _imageIterator;
// osg::notify(osg::NOTICE)<<"time = "<<time<<std::endl;
if (_imageIterator!=_imageDuationSequence.end())
if (_imageIterator!=_images.end())
{
// osg::notify(osg::NOTICE)<<" _imageIteratorTime = "<<_imageIteratorTime<<std::endl;
while(time > (_imageIteratorTime + _imageIterator->second))
while(time > (_imageIteratorTime + delta))
{
_imageIteratorTime += _imageIterator->second;
_imageIteratorTime += delta;
// osg::notify(osg::NOTICE)<<" _imageIteratorTime = "<<_imageIteratorTime<<std::endl;
++_imageIterator;
if (_imageIterator ==_imageDuationSequence.end())
if (_imageIterator ==_images.end())
{
// return iterator to begining of set.
_imageIterator = _imageDuationSequence.begin();
_imageIterator = _images.begin();
}
}
}
if (_imageIterator==_imageDuationSequence.end())
if (_imageIterator==_images.end())
{
_imageIterator = _imageDuationSequence.begin();
_imageIterator = _images.begin();
}
if (_imageIterator!=_imageDuationSequence.end())
if (_imageIterator!=_images.end() && previous_imageIterator != _imageIterator)
{
setImageToChild(_imageIterator->first.get());
setImageToChild(_imageIterator->get());
}
}

View File

@@ -54,6 +54,11 @@ ImagePager::~ImagePager()
{
}
void ImagePager::requestNodeFile(const std::string& fileName,osg::Object* attachmentPoint, double timeToMergeBy, const osg::FrameStamp* framestamp, osg::ref_ptr<osg::Referenced>& imageRequest)
{
osg::notify(osg::NOTICE)<<"ImagePager::requestNodeFile("<<fileName<<")"<<std::endl;
}
bool ImagePager::requiresUpdateSceneGraph() const
{
//osg::notify(osg::NOTICE)<<"ImagePager::requiresUpdateSceneGraph()"<<std::endl;

View File

@@ -963,6 +963,8 @@ void CompositeViewer::updateTraversal()
Scene* scene = *sitr;
if (scene->getSceneData())
{
_updateVisitor->setImageRequestHandler(scene->getImagePager());
scene->getSceneData()->accept(*_updateVisitor);
}

View File

@@ -22,6 +22,7 @@
#include <osgViewer/View>
#include <osgDB/DatabasePager>
#include <osgDB/ImagePager>
#include <osg/io_utils>
@@ -237,8 +238,12 @@ void Renderer::updateSceneView(osgUtil::SceneView* sceneView)
}
osgViewer::View* view = dynamic_cast<osgViewer::View*>(_camera->getView());
osgDB::DatabasePager* databasePager = view ? view->getDatabasePager() : 0;
sceneView->getCullVisitor()->setDatabaseRequestHandler(databasePager);
osgDB::ImagePager* imagePager = view ? view->getImagePager() : 0;
sceneView->getCullVisitor()->setImageRequestHandler(imagePager);
sceneView->setFrameStamp(view ? view->getFrameStamp() : state->getFrameStamp());

View File

@@ -882,6 +882,7 @@ void Viewer::updateTraversal()
if (getSceneData())
{
_updateVisitor->setImageRequestHandler(_scene->getImagePager());
getSceneData()->accept(*_updateVisitor);
}

View File

@@ -12,8 +12,8 @@
#include <osg/BufferObject>
#include <osg/CopyOp>
#include <osg/FrameStamp>
#include <osg/Image>
#include <osg/NodeVisitor>
#include <osg/Object>
#include <osg/Vec2>
#include <osg/Vec3>
@@ -352,9 +352,9 @@ BEGIN_OBJECT_REFLECTOR(osg::Image)
__C5_PixelBufferObject_P1__getPixelBufferObject,
"Get the const PixelBufferObject. ",
"");
I_Method1(void, update, IN, const osg::FrameStamp *, fs,
I_Method1(void, update, IN, osg::NodeVisitor *, nv,
Properties::VIRTUAL,
__void__update__C5_osg_FrameStamp_P1,
__void__update__NodeVisitor_P1,
"",
"");
I_StaticMethod1(bool, isPackedType, IN, GLenum, type,

View File

@@ -24,6 +24,7 @@
#include <osg/MatrixTransform>
#include <osg/Node>
#include <osg/NodeVisitor>
#include <osg/Object>
#include <osg/OccluderNode>
#include <osg/OcclusionQueryNode>
#include <osg/PagedLOD>
@@ -343,6 +344,21 @@ BEGIN_OBJECT_REFLECTOR(osg::NodeVisitor)
__C5_DatabaseRequestHandler_P1__getDatabaseRequestHandler,
"Get the const handler for database requests. ",
"");
I_Method1(void, setImageRequestHandler, IN, osg::NodeVisitor::ImageRequestHandler *, handler,
Properties::NON_VIRTUAL,
__void__setImageRequestHandler__ImageRequestHandler_P1,
"Set the handler for image requests. ",
"");
I_Method0(osg::NodeVisitor::ImageRequestHandler *, getImageRequestHandler,
Properties::NON_VIRTUAL,
__ImageRequestHandler_P1__getImageRequestHandler,
"Get the handler for image requests. ",
"");
I_Method0(const osg::NodeVisitor::ImageRequestHandler *, getImageRequestHandler,
Properties::NON_VIRTUAL,
__C5_ImageRequestHandler_P1__getImageRequestHandler,
"Get the const handler for image requests. ",
"");
I_SimpleProperty(osg::NodeVisitor::DatabaseRequestHandler *, DatabaseRequestHandler,
__DatabaseRequestHandler_P1__getDatabaseRequestHandler,
__void__setDatabaseRequestHandler__DatabaseRequestHandler_P1);
@@ -352,6 +368,9 @@ BEGIN_OBJECT_REFLECTOR(osg::NodeVisitor)
I_SimpleProperty(osg::FrameStamp *, FrameStamp,
0,
__void__setFrameStamp__FrameStamp_P1);
I_SimpleProperty(osg::NodeVisitor::ImageRequestHandler *, ImageRequestHandler,
__ImageRequestHandler_P1__getImageRequestHandler,
__void__setImageRequestHandler__ImageRequestHandler_P1);
I_SimpleProperty(osg::Node::NodeMask, NodeMaskOverride,
__Node_NodeMask__getNodeMaskOverride,
__void__setNodeMaskOverride__Node_NodeMask);
@@ -391,6 +410,19 @@ BEGIN_ABSTRACT_OBJECT_REFLECTOR(osg::NodeVisitor::DatabaseRequestHandler)
"");
END_REFLECTOR
BEGIN_ABSTRACT_OBJECT_REFLECTOR(osg::NodeVisitor::ImageRequestHandler)
I_DeclaringFile("osg/NodeVisitor");
I_BaseType(osg::Referenced);
I_Constructor0(____ImageRequestHandler,
"",
"");
I_Method5(void, requestNodeFile, IN, const std::string &, fileName, IN, osg::Object *, attachmentPoint, IN, double, timeToMergeBy, IN, const osg::FrameStamp *, framestamp, IN, osg::ref_ptr< osg::Referenced > &, imageRequest,
Properties::PURE_VIRTUAL,
__void__requestNodeFile__C5_std_string_R1__osg_Object_P1__double__C5_FrameStamp_P1__osg_ref_ptrT1_osg_Referenced__R1,
"",
"");
END_REFLECTOR
BEGIN_VALUE_REFLECTOR(osg::ref_ptr< osg::Referenced >)
I_DeclaringFile("osg/ref_ptr");
I_Constructor0(____ref_ptr,