forked from mirror/openmw-tes3mp
b39d69e98c
- Fix rindex overflow - Fix audio sample size bugs (was using sample_fmt and channel count of the decoder, instead of the resampled settings). We didn't notice this bug before, because the OpenAL MovieAudioFactory tries to resample to a format of the same byte size. - Add support for play/pause and seeking controls (not used by cutscenes in OpenMW) - Closing the video when arriving at the stream end is now handled by the user (we may also want to keep the video open and seek back) The video player now has a standalone demo, at https://github.com/scrawl/ogre-ffmpeg-videoplayer
71 lines
2.2 KiB
C++
71 lines
2.2 KiB
C++
#ifndef VIDEOPLAYER_H
|
|
#define VIDEOPLAYER_H
|
|
|
|
#include <string>
|
|
#include <memory>
|
|
|
|
namespace Video
|
|
{
|
|
|
|
struct VideoState;
|
|
class MovieAudioFactory;
|
|
|
|
/**
|
|
* @brief Plays a video on an Ogre texture.
|
|
*/
|
|
class VideoPlayer
|
|
{
|
|
public:
|
|
VideoPlayer();
|
|
~VideoPlayer();
|
|
|
|
/// @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.
|
|
void playVideo (const std::string& resourceName);
|
|
|
|
/// 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();
|
|
|
|
/// Return the texture name of the currently playing video, or "" if no video is playing.
|
|
std::string getTextureName();
|
|
/// 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::auto_ptr<MovieAudioFactory> mAudioFactory;
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|