1
0
mirror of https://gitlab.com/OpenMW/openmw.git synced 2025-01-25 06:35:30 +00:00

87 lines
2.5 KiB
C++
Raw Normal View History

#ifndef VIDEOPLAYER_H
#define VIDEOPLAYER_H
2015-06-04 01:16:52 +02:00
#include <stdint.h>
#include <string>
#include <memory>
2015-04-19 20:07:18 +02:00
#include <iosfwd>
#include <osg/Texture2D>
#include <boost/shared_ptr.hpp>
namespace osg
{
class Texture2D;
}
namespace Video
{
struct VideoState;
class MovieAudioFactory;
/**
2015-04-19 20:12:37 +02:00
* @brief Plays a video on an osg texture.
*/
class VideoPlayer
{
public:
VideoPlayer();
~VideoPlayer();
2014-10-22 23:22:22 +02:00
/// @brief Set the MovieAudioFactory to use.
/// @par This class must be implemented by the user and is responsible for reading the decoded audio data.
/// @note If you do not set up a MovieAudioFactory, then audio streams will be ignored and the video will be played with no sound.
/// @note Takes ownership of the passed pointer.
void setAudioFactory (MovieAudioFactory* factory);
/// Return true if a video is currently playing and it has an audio stream.
bool hasAudioStream();
/// Play the given video. If a video is already playing, the old video is closed first.
/// @note The video will be unpaused by default. Use the pause() and play() methods to control pausing.
/// @param name A name for the video stream - only used for logging purposes.
void playVideo (boost::shared_ptr<std::istream> inputstream, const std::string& name);
/// Get the current playback time position in the video, in seconds
double getCurrentTime();
/// Get the duration of the video in seconds
double getDuration();
/// Seek to the specified time position in the video
void seek(double time);
void play();
void pause();
bool isPaused();
/// This should be called every frame by the user to update the video texture.
/// @return Returns true if the video is still playing, false if we have reached the end of the video stream.
bool update();
/// Stop the currently playing video, if a video is playing.
void close();
2015-04-19 20:07:18 +02:00
/// Return the texture of the currently playing video, or a null pointer if no video is playing.
osg::ref_ptr<osg::Texture2D> getVideoTexture();
/// Return the width of the currently playing video, or 0 if no video is playing.
int getVideoWidth();
/// Return the height of the currently playing video, or 0 if no video is playing.
int getVideoHeight();
private:
VideoState* mState;
std::unique_ptr<MovieAudioFactory> mAudioFactory;
};
}
#endif