Further work on osg::ImageSequence/osgDB::ImagePager
This commit is contained in:
parent
73bcc2613c
commit
041a06b89d
@ -31,24 +31,9 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
//
|
//
|
||||||
// A simple demo demonstrating different texturing modes,
|
// A simple demo demonstrating how to set on an animated texture using an osg::ImageSequence
|
||||||
// including using of texture extensions.
|
|
||||||
//
|
//
|
||||||
|
|
||||||
struct ImageUpdateCallback : public osg::StateAttribute::Callback
|
|
||||||
{
|
|
||||||
/** do customized update code.*/
|
|
||||||
virtual void 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(fs);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
osg::StateSet* createState()
|
osg::StateSet* createState()
|
||||||
{
|
{
|
||||||
// read 4 2d images
|
// read 4 2d images
|
||||||
@ -58,11 +43,11 @@ osg::StateSet* createState()
|
|||||||
osg::ref_ptr<osg::Image> image_3 = osgDB::readImageFile("Images/skymap.jpg");
|
osg::ref_ptr<osg::Image> image_3 = osgDB::readImageFile("Images/skymap.jpg");
|
||||||
|
|
||||||
osg::ref_ptr<osg::ImageSequence> imageSequence = new osg::ImageSequence;
|
osg::ref_ptr<osg::ImageSequence> imageSequence = new osg::ImageSequence;
|
||||||
imageSequence->addImage(image_0.get(), 0.25);
|
imageSequence->addImage(image_0.get());
|
||||||
imageSequence->addImage(image_1.get(), 0.25);
|
imageSequence->addImage(image_1.get());
|
||||||
imageSequence->addImage(image_2.get(), 0.25);
|
imageSequence->addImage(image_2.get());
|
||||||
imageSequence->addImage(image_3.get(), 0.25);
|
imageSequence->addImage(image_3.get());
|
||||||
|
|
||||||
osg::Texture2D* texture = new osg::Texture2D;
|
osg::Texture2D* texture = new osg::Texture2D;
|
||||||
texture->setFilter(osg::Texture2D::MIN_FILTER,osg::Texture2D::LINEAR);
|
texture->setFilter(osg::Texture2D::MIN_FILTER,osg::Texture2D::LINEAR);
|
||||||
texture->setFilter(osg::Texture2D::MAG_FILTER,osg::Texture2D::LINEAR);
|
texture->setFilter(osg::Texture2D::MAG_FILTER,osg::Texture2D::LINEAR);
|
||||||
@ -71,7 +56,7 @@ osg::StateSet* createState()
|
|||||||
texture->setImage(imageSequence.get());
|
texture->setImage(imageSequence.get());
|
||||||
//texture->setTextureSize(512,512);
|
//texture->setTextureSize(512,512);
|
||||||
|
|
||||||
texture->setUpdateCallback(new ImageUpdateCallback);
|
texture->setUpdateCallback(new osg::ImageSequence::UpdateCallback);
|
||||||
|
|
||||||
// create the StateSet to store the texture data
|
// create the StateSet to store the texture data
|
||||||
osg::StateSet* stateset = new osg::StateSet;
|
osg::StateSet* stateset = new osg::StateSet;
|
||||||
|
@ -53,6 +53,9 @@
|
|||||||
|
|
||||||
namespace osg {
|
namespace osg {
|
||||||
|
|
||||||
|
// forward declare
|
||||||
|
class NodeVisitor;
|
||||||
|
|
||||||
/** Image class for encapsulating the storage texture image data. */
|
/** Image class for encapsulating the storage texture image data. */
|
||||||
class OSG_EXPORT Image : public Object
|
class OSG_EXPORT Image : public Object
|
||||||
{
|
{
|
||||||
@ -295,7 +298,7 @@ class OSG_EXPORT Image : public Object
|
|||||||
/** Get the const PixelBufferObject.*/
|
/** Get the const PixelBufferObject.*/
|
||||||
const PixelBufferObject* getPixelBufferObject() const { return _bufferObject.get(); }
|
const PixelBufferObject* getPixelBufferObject() const { return _bufferObject.get(); }
|
||||||
|
|
||||||
virtual void update(const osg::FrameStamp* fs) {}
|
virtual void update(NodeVisitor* nv) {}
|
||||||
|
|
||||||
protected :
|
protected :
|
||||||
|
|
||||||
|
@ -16,6 +16,7 @@
|
|||||||
|
|
||||||
#include <OpenThreads/Mutex>
|
#include <OpenThreads/Mutex>
|
||||||
#include <osg/ImageStream>
|
#include <osg/ImageStream>
|
||||||
|
#include <osg/StateAttribute>
|
||||||
|
|
||||||
#include <list>
|
#include <list>
|
||||||
|
|
||||||
@ -30,7 +31,7 @@ class OSG_EXPORT ImageSequence : public ImageStream
|
|||||||
ImageSequence();
|
ImageSequence();
|
||||||
|
|
||||||
/** Copy constructor using CopyOp to manage deep vs shallow copy. */
|
/** Copy constructor using CopyOp to manage deep vs shallow copy. */
|
||||||
ImageSequence(const ImageSequence& ImageSequence,const CopyOp& copyop=CopyOp::SHALLOW_COPY);
|
ImageSequence(const ImageSequence& ImageSequence, const CopyOp& copyop=CopyOp::SHALLOW_COPY);
|
||||||
|
|
||||||
virtual Object* cloneType() const { return new ImageSequence(); }
|
virtual Object* cloneType() const { return new ImageSequence(); }
|
||||||
virtual Object* clone(const CopyOp& copyop) const { return new ImageSequence(*this,copyop); }
|
virtual Object* clone(const CopyOp& copyop) const { return new ImageSequence(*this,copyop); }
|
||||||
@ -47,18 +48,25 @@ class OSG_EXPORT ImageSequence : public ImageStream
|
|||||||
virtual void setTimeMultiplier(double tm) { _timeMultiplier = tm; }
|
virtual void setTimeMultiplier(double tm) { _timeMultiplier = tm; }
|
||||||
virtual double getTimeMultiplier() const { return _timeMultiplier; }
|
virtual double getTimeMultiplier() const { return _timeMultiplier; }
|
||||||
|
|
||||||
|
typedef std::list< osg::ref_ptr<osg::Image> > Images;
|
||||||
|
typedef std::list< std::string > FileNames;
|
||||||
|
|
||||||
typedef std::pair<osg::ref_ptr<osg::Image>, double> ImageDurationPair;
|
void setDuration(double duration) { _duration = duration; }
|
||||||
typedef std::pair<std::string, double> FileNameDurationPair;
|
double getDuration() const { return _duration; }
|
||||||
|
|
||||||
typedef std::list<ImageDurationPair> ImageDurationSequence;
|
void setPruneOldImages(bool prune) { _pruneOldImages = prune; }
|
||||||
typedef std::list<FileNameDurationPair> FileNameDurationSequence;
|
bool getPruneOldImages() const { return _pruneOldImages; }
|
||||||
|
|
||||||
void addImageFile(const std::string& fileName, double duration = 0.040);
|
void addImageFile(const std::string& fileName);
|
||||||
|
|
||||||
void addImage(osg::Image* image, double duration = 0.040);
|
void addImage(osg::Image* image);
|
||||||
|
|
||||||
virtual void update(const osg::FrameStamp* fs);
|
virtual void update(NodeVisitor* nv);
|
||||||
|
|
||||||
|
struct OSG_EXPORT UpdateCallback : public osg::StateAttribute::Callback
|
||||||
|
{
|
||||||
|
virtual void operator () (osg::StateAttribute* attr, osg::NodeVisitor* nv);
|
||||||
|
};
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
@ -70,10 +78,15 @@ class OSG_EXPORT ImageSequence : public ImageStream
|
|||||||
double _timeMultiplier;
|
double _timeMultiplier;
|
||||||
|
|
||||||
OpenThreads::Mutex _mutex;
|
OpenThreads::Mutex _mutex;
|
||||||
FileNameDurationSequence _fileNameDurationSequence;
|
FileNames _fileNames;
|
||||||
ImageDurationSequence _imageDuationSequence;
|
|
||||||
|
double _duration;
|
||||||
|
bool _pruneOldImages;
|
||||||
|
|
||||||
|
double _imageHeadTime;
|
||||||
|
Images _images;
|
||||||
|
|
||||||
ImageDurationSequence::iterator _imageIterator;
|
Images::iterator _imageIterator;
|
||||||
double _imageIteratorTime;
|
double _imageIteratorTime;
|
||||||
|
|
||||||
|
|
||||||
|
@ -284,6 +284,30 @@ class OSG_EXPORT NodeVisitor : public virtual Referenced
|
|||||||
const DatabaseRequestHandler* getDatabaseRequestHandler() const { return _databaseRequestHandler.get(); }
|
const DatabaseRequestHandler* getDatabaseRequestHandler() const { return _databaseRequestHandler.get(); }
|
||||||
|
|
||||||
|
|
||||||
|
/** Callback for managing database paging, such as generated by PagedLOD nodes.*/
|
||||||
|
class ImageRequestHandler : public osg::Referenced
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
|
ImageRequestHandler():
|
||||||
|
Referenced(true) {}
|
||||||
|
|
||||||
|
virtual void requestNodeFile(const std::string& fileName,osg::Object* attachmentPoint, double timeToMergeBy, const FrameStamp* framestamp, osg::ref_ptr<osg::Referenced>& imageRequest) = 0;
|
||||||
|
|
||||||
|
protected:
|
||||||
|
virtual ~ImageRequestHandler() {}
|
||||||
|
};
|
||||||
|
|
||||||
|
/** Set the handler for image requests.*/
|
||||||
|
void setImageRequestHandler(ImageRequestHandler* handler) { _imageRequestHandler = handler; }
|
||||||
|
|
||||||
|
/** Get the handler for image requests.*/
|
||||||
|
ImageRequestHandler* getImageRequestHandler() { return _imageRequestHandler.get(); }
|
||||||
|
|
||||||
|
/** Get the const handler for image requests.*/
|
||||||
|
const ImageRequestHandler* getImageRequestHandler() const { return _imageRequestHandler.get(); }
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
@ -301,6 +325,7 @@ class OSG_EXPORT NodeVisitor : public virtual Referenced
|
|||||||
ref_ptr<Referenced> _userData;
|
ref_ptr<Referenced> _userData;
|
||||||
|
|
||||||
ref_ptr<DatabaseRequestHandler> _databaseRequestHandler;
|
ref_ptr<DatabaseRequestHandler> _databaseRequestHandler;
|
||||||
|
ref_ptr<ImageRequestHandler> _imageRequestHandler;
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#define OSGDB_IMAGEPAGER 1
|
#define OSGDB_IMAGEPAGER 1
|
||||||
|
|
||||||
#include <osg/Image>
|
#include <osg/Image>
|
||||||
|
#include <osg/NodeVisitor>
|
||||||
|
|
||||||
#include <OpenThreads/Thread>
|
#include <OpenThreads/Thread>
|
||||||
#include <OpenThreads/Mutex>
|
#include <OpenThreads/Mutex>
|
||||||
@ -24,7 +25,7 @@
|
|||||||
namespace osgDB
|
namespace osgDB
|
||||||
{
|
{
|
||||||
|
|
||||||
class OSGDB_EXPORT ImagePager : public osg::Referenced
|
class OSGDB_EXPORT ImagePager : public osg::NodeVisitor::ImageRequestHandler
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
||||||
@ -33,12 +34,12 @@ class OSGDB_EXPORT ImagePager : public osg::Referenced
|
|||||||
struct ImageRequest : public osg::Referenced
|
struct ImageRequest : public osg::Referenced
|
||||||
{
|
{
|
||||||
ImageRequest():
|
ImageRequest():
|
||||||
osg::Referenced(true) {}
|
osg::Referenced(true),
|
||||||
|
_timeToMergeBy(0.0) {}
|
||||||
|
|
||||||
|
double _timeToMergeBy;
|
||||||
std::string _fileName;
|
std::string _fileName;
|
||||||
osg::ref_ptr<ReaderWriter::Options> _loadOptions;
|
osg::ref_ptr<ReaderWriter::Options> _loadOptions;
|
||||||
|
|
||||||
|
|
||||||
osg::ref_ptr<osg::Object> _objectToAttachTo;
|
osg::ref_ptr<osg::Object> _objectToAttachTo;
|
||||||
osg::ref_ptr<osg::Image> _loadedImage;
|
osg::ref_ptr<osg::Image> _loadedImage;
|
||||||
|
|
||||||
@ -76,8 +77,10 @@ class OSGDB_EXPORT ImagePager : public osg::Referenced
|
|||||||
std::string _name;
|
std::string _name;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
virtual void requestNodeFile(const std::string& fileName,osg::Object* attachmentPoint, double timeToMergeBy, const osg::FrameStamp* framestamp, osg::ref_ptr<osg::Referenced>& imageRequest);
|
||||||
|
|
||||||
/** Return true if there are pending updates to the scene graph that require a call to updateSceneGraph(double). */
|
/** Return true if there are pending updates to the scene graph that require a call to updateSceneGraph(double). */
|
||||||
bool requiresUpdateSceneGraph() const;
|
virtual bool requiresUpdateSceneGraph() const;
|
||||||
|
|
||||||
/** Merge the changes to the scene graph. */
|
/** Merge the changes to the scene graph. */
|
||||||
virtual void updateSceneGraph(double currentFrameTime);
|
virtual void updateSceneGraph(double currentFrameTime);
|
||||||
|
@ -15,24 +15,44 @@
|
|||||||
#include <osg/ImageSequence>
|
#include <osg/ImageSequence>
|
||||||
#include <osg/Notify>
|
#include <osg/Notify>
|
||||||
#include <osg/Camera>
|
#include <osg/Camera>
|
||||||
|
#include <osg/NodeVisitor>
|
||||||
|
#include <osg/Texture2D>
|
||||||
|
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
|
|
||||||
using namespace osg;
|
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()
|
ImageSequence::ImageSequence()
|
||||||
{
|
{
|
||||||
_referenceTime = DBL_MAX;
|
_referenceTime = DBL_MAX;
|
||||||
_imageIteratorTime = DBL_MAX;
|
|
||||||
_timeMultiplier = 1.0;
|
_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):
|
ImageSequence::ImageSequence(const ImageSequence& is,const CopyOp& copyop):
|
||||||
osg::ImageStream(is,copyop),
|
osg::ImageStream(is,copyop),
|
||||||
_referenceTime(is._referenceTime),
|
_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
|
int ImageSequence::compare(const Image& rhs) const
|
||||||
@ -40,32 +60,29 @@ int ImageSequence::compare(const Image& rhs) const
|
|||||||
return ImageStream::compare(rhs);
|
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);
|
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);
|
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;
|
_imageIteratorTime = _referenceTime;
|
||||||
setImageToChild(_imageIterator->first.get());
|
setImageToChild(_imageIterator->get());
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageSequence::setImageToChild(const osg::Image* image)
|
void ImageSequence::setImageToChild(const osg::Image* image)
|
||||||
{
|
{
|
||||||
|
// osg::notify(osg::NOTICE)<<"setImageToChild("<<image<<")"<<std::endl;
|
||||||
|
|
||||||
setImage(image->s(),image->t(),image->r(),
|
setImage(image->s(),image->t(),image->r(),
|
||||||
image->getInternalTextureFormat(),
|
image->getInternalTextureFormat(),
|
||||||
image->getPixelFormat(),image->getDataType(),
|
image->getPixelFormat(),image->getDataType(),
|
||||||
@ -74,10 +91,14 @@ void ImageSequence::setImageToChild(const osg::Image* image)
|
|||||||
image->getPacking());
|
image->getPacking());
|
||||||
}
|
}
|
||||||
|
|
||||||
void ImageSequence::update(const osg::FrameStamp* fs)
|
void ImageSequence::update(osg::NodeVisitor* nv)
|
||||||
{
|
{
|
||||||
OpenThreads::ScopedLock<OpenThreads::Mutex> lock(_mutex);
|
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)
|
if (_referenceTime == DBL_MAX)
|
||||||
{
|
{
|
||||||
@ -90,33 +111,38 @@ void ImageSequence::update(const osg::FrameStamp* fs)
|
|||||||
}
|
}
|
||||||
|
|
||||||
double time = (fs->getSimulationTime() - _referenceTime)*_timeMultiplier;
|
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;
|
// osg::notify(osg::NOTICE)<<"time = "<<time<<std::endl;
|
||||||
|
|
||||||
if (_imageIterator!=_imageDuationSequence.end())
|
if (_imageIterator!=_images.end())
|
||||||
{
|
{
|
||||||
// osg::notify(osg::NOTICE)<<" _imageIteratorTime = "<<_imageIteratorTime<<std::endl;
|
// 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;
|
// osg::notify(osg::NOTICE)<<" _imageIteratorTime = "<<_imageIteratorTime<<std::endl;
|
||||||
++_imageIterator;
|
++_imageIterator;
|
||||||
|
|
||||||
if (_imageIterator ==_imageDuationSequence.end())
|
if (_imageIterator ==_images.end())
|
||||||
{
|
{
|
||||||
// return iterator to begining of set.
|
// 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());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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
|
bool ImagePager::requiresUpdateSceneGraph() const
|
||||||
{
|
{
|
||||||
//osg::notify(osg::NOTICE)<<"ImagePager::requiresUpdateSceneGraph()"<<std::endl;
|
//osg::notify(osg::NOTICE)<<"ImagePager::requiresUpdateSceneGraph()"<<std::endl;
|
||||||
|
@ -963,6 +963,8 @@ void CompositeViewer::updateTraversal()
|
|||||||
Scene* scene = *sitr;
|
Scene* scene = *sitr;
|
||||||
if (scene->getSceneData())
|
if (scene->getSceneData())
|
||||||
{
|
{
|
||||||
|
_updateVisitor->setImageRequestHandler(scene->getImagePager());
|
||||||
|
|
||||||
scene->getSceneData()->accept(*_updateVisitor);
|
scene->getSceneData()->accept(*_updateVisitor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
#include <osgViewer/View>
|
#include <osgViewer/View>
|
||||||
|
|
||||||
#include <osgDB/DatabasePager>
|
#include <osgDB/DatabasePager>
|
||||||
|
#include <osgDB/ImagePager>
|
||||||
|
|
||||||
#include <osg/io_utils>
|
#include <osg/io_utils>
|
||||||
|
|
||||||
@ -237,8 +238,12 @@ void Renderer::updateSceneView(osgUtil::SceneView* sceneView)
|
|||||||
}
|
}
|
||||||
|
|
||||||
osgViewer::View* view = dynamic_cast<osgViewer::View*>(_camera->getView());
|
osgViewer::View* view = dynamic_cast<osgViewer::View*>(_camera->getView());
|
||||||
|
|
||||||
osgDB::DatabasePager* databasePager = view ? view->getDatabasePager() : 0;
|
osgDB::DatabasePager* databasePager = view ? view->getDatabasePager() : 0;
|
||||||
sceneView->getCullVisitor()->setDatabaseRequestHandler(databasePager);
|
sceneView->getCullVisitor()->setDatabaseRequestHandler(databasePager);
|
||||||
|
|
||||||
|
osgDB::ImagePager* imagePager = view ? view->getImagePager() : 0;
|
||||||
|
sceneView->getCullVisitor()->setImageRequestHandler(imagePager);
|
||||||
|
|
||||||
sceneView->setFrameStamp(view ? view->getFrameStamp() : state->getFrameStamp());
|
sceneView->setFrameStamp(view ? view->getFrameStamp() : state->getFrameStamp());
|
||||||
|
|
||||||
|
@ -882,6 +882,7 @@ void Viewer::updateTraversal()
|
|||||||
|
|
||||||
if (getSceneData())
|
if (getSceneData())
|
||||||
{
|
{
|
||||||
|
_updateVisitor->setImageRequestHandler(_scene->getImagePager());
|
||||||
getSceneData()->accept(*_updateVisitor);
|
getSceneData()->accept(*_updateVisitor);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -12,8 +12,8 @@
|
|||||||
|
|
||||||
#include <osg/BufferObject>
|
#include <osg/BufferObject>
|
||||||
#include <osg/CopyOp>
|
#include <osg/CopyOp>
|
||||||
#include <osg/FrameStamp>
|
|
||||||
#include <osg/Image>
|
#include <osg/Image>
|
||||||
|
#include <osg/NodeVisitor>
|
||||||
#include <osg/Object>
|
#include <osg/Object>
|
||||||
#include <osg/Vec2>
|
#include <osg/Vec2>
|
||||||
#include <osg/Vec3>
|
#include <osg/Vec3>
|
||||||
@ -352,9 +352,9 @@ BEGIN_OBJECT_REFLECTOR(osg::Image)
|
|||||||
__C5_PixelBufferObject_P1__getPixelBufferObject,
|
__C5_PixelBufferObject_P1__getPixelBufferObject,
|
||||||
"Get the const PixelBufferObject. ",
|
"Get the const PixelBufferObject. ",
|
||||||
"");
|
"");
|
||||||
I_Method1(void, update, IN, const osg::FrameStamp *, fs,
|
I_Method1(void, update, IN, osg::NodeVisitor *, nv,
|
||||||
Properties::VIRTUAL,
|
Properties::VIRTUAL,
|
||||||
__void__update__C5_osg_FrameStamp_P1,
|
__void__update__NodeVisitor_P1,
|
||||||
"",
|
"",
|
||||||
"");
|
"");
|
||||||
I_StaticMethod1(bool, isPackedType, IN, GLenum, type,
|
I_StaticMethod1(bool, isPackedType, IN, GLenum, type,
|
||||||
|
@ -24,6 +24,7 @@
|
|||||||
#include <osg/MatrixTransform>
|
#include <osg/MatrixTransform>
|
||||||
#include <osg/Node>
|
#include <osg/Node>
|
||||||
#include <osg/NodeVisitor>
|
#include <osg/NodeVisitor>
|
||||||
|
#include <osg/Object>
|
||||||
#include <osg/OccluderNode>
|
#include <osg/OccluderNode>
|
||||||
#include <osg/OcclusionQueryNode>
|
#include <osg/OcclusionQueryNode>
|
||||||
#include <osg/PagedLOD>
|
#include <osg/PagedLOD>
|
||||||
@ -343,6 +344,21 @@ BEGIN_OBJECT_REFLECTOR(osg::NodeVisitor)
|
|||||||
__C5_DatabaseRequestHandler_P1__getDatabaseRequestHandler,
|
__C5_DatabaseRequestHandler_P1__getDatabaseRequestHandler,
|
||||||
"Get the const handler for database requests. ",
|
"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,
|
I_SimpleProperty(osg::NodeVisitor::DatabaseRequestHandler *, DatabaseRequestHandler,
|
||||||
__DatabaseRequestHandler_P1__getDatabaseRequestHandler,
|
__DatabaseRequestHandler_P1__getDatabaseRequestHandler,
|
||||||
__void__setDatabaseRequestHandler__DatabaseRequestHandler_P1);
|
__void__setDatabaseRequestHandler__DatabaseRequestHandler_P1);
|
||||||
@ -352,6 +368,9 @@ BEGIN_OBJECT_REFLECTOR(osg::NodeVisitor)
|
|||||||
I_SimpleProperty(osg::FrameStamp *, FrameStamp,
|
I_SimpleProperty(osg::FrameStamp *, FrameStamp,
|
||||||
0,
|
0,
|
||||||
__void__setFrameStamp__FrameStamp_P1);
|
__void__setFrameStamp__FrameStamp_P1);
|
||||||
|
I_SimpleProperty(osg::NodeVisitor::ImageRequestHandler *, ImageRequestHandler,
|
||||||
|
__ImageRequestHandler_P1__getImageRequestHandler,
|
||||||
|
__void__setImageRequestHandler__ImageRequestHandler_P1);
|
||||||
I_SimpleProperty(osg::Node::NodeMask, NodeMaskOverride,
|
I_SimpleProperty(osg::Node::NodeMask, NodeMaskOverride,
|
||||||
__Node_NodeMask__getNodeMaskOverride,
|
__Node_NodeMask__getNodeMaskOverride,
|
||||||
__void__setNodeMaskOverride__Node_NodeMask);
|
__void__setNodeMaskOverride__Node_NodeMask);
|
||||||
@ -391,6 +410,19 @@ BEGIN_ABSTRACT_OBJECT_REFLECTOR(osg::NodeVisitor::DatabaseRequestHandler)
|
|||||||
"");
|
"");
|
||||||
END_REFLECTOR
|
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 >)
|
BEGIN_VALUE_REFLECTOR(osg::ref_ptr< osg::Referenced >)
|
||||||
I_DeclaringFile("osg/ref_ptr");
|
I_DeclaringFile("osg/ref_ptr");
|
||||||
I_Constructor0(____ref_ptr,
|
I_Constructor0(____ref_ptr,
|
||||||
|
Loading…
Reference in New Issue
Block a user