forked from teamnwah/openmw-tes3coop
126 lines
2.7 KiB
C++
126 lines
2.7 KiB
C++
|
#ifndef VIDEOPLAYER_VIDEOSTATE_H
|
||
|
#define VIDEOPLAYER_VIDEOSTATE_H
|
||
|
|
||
|
#include <boost/thread.hpp>
|
||
|
|
||
|
#include <OgreTexture.h>
|
||
|
|
||
|
#include "videodefs.hpp"
|
||
|
|
||
|
#define VIDEO_PICTURE_QUEUE_SIZE 50
|
||
|
|
||
|
extern "C"
|
||
|
{
|
||
|
struct SwsContext;
|
||
|
struct AVPacketList;
|
||
|
struct AVPacket;
|
||
|
struct AVFormatContext;
|
||
|
struct AVStream;
|
||
|
struct AVFrame;
|
||
|
}
|
||
|
|
||
|
namespace Video
|
||
|
{
|
||
|
|
||
|
struct VideoState;
|
||
|
|
||
|
class MovieAudioFactory;
|
||
|
class MovieAudioDecoder;
|
||
|
|
||
|
struct PacketQueue {
|
||
|
PacketQueue()
|
||
|
: first_pkt(NULL), last_pkt(NULL), flushing(false), nb_packets(0), size(0)
|
||
|
{ }
|
||
|
~PacketQueue()
|
||
|
{ clear(); }
|
||
|
|
||
|
AVPacketList *first_pkt, *last_pkt;
|
||
|
volatile bool flushing;
|
||
|
int nb_packets;
|
||
|
int size;
|
||
|
|
||
|
boost::mutex mutex;
|
||
|
boost::condition_variable cond;
|
||
|
|
||
|
void put(AVPacket *pkt);
|
||
|
int get(AVPacket *pkt, VideoState *is);
|
||
|
|
||
|
void flush();
|
||
|
void clear();
|
||
|
};
|
||
|
|
||
|
struct VideoPicture {
|
||
|
VideoPicture() : pts(0.0)
|
||
|
{ }
|
||
|
|
||
|
std::vector<uint8_t> data;
|
||
|
double pts;
|
||
|
};
|
||
|
|
||
|
struct VideoState {
|
||
|
VideoState();
|
||
|
~VideoState();
|
||
|
|
||
|
void setAudioFactory(MovieAudioFactory* factory);
|
||
|
|
||
|
void init(const std::string& resourceName);
|
||
|
void deinit();
|
||
|
|
||
|
int stream_open(int stream_index, AVFormatContext *pFormatCtx);
|
||
|
|
||
|
bool update();
|
||
|
|
||
|
static void video_thread_loop(VideoState *is);
|
||
|
static void decode_thread_loop(VideoState *is);
|
||
|
|
||
|
void video_display(VideoPicture* vp);
|
||
|
void video_refresh();
|
||
|
|
||
|
int queue_picture(AVFrame *pFrame, double pts);
|
||
|
double synchronize_video(AVFrame *src_frame, double pts);
|
||
|
|
||
|
double get_audio_clock();
|
||
|
double get_video_clock();
|
||
|
double get_external_clock();
|
||
|
double get_master_clock();
|
||
|
|
||
|
static int OgreResource_Read(void *user_data, uint8_t *buf, int buf_size);
|
||
|
static int OgreResource_Write(void *user_data, uint8_t *buf, int buf_size);
|
||
|
static int64_t OgreResource_Seek(void *user_data, int64_t offset, int whence);
|
||
|
|
||
|
Ogre::TexturePtr mTexture;
|
||
|
|
||
|
MovieAudioFactory* mAudioFactory;
|
||
|
boost::shared_ptr<MovieAudioDecoder> mAudioDecoder;
|
||
|
|
||
|
Ogre::DataStreamPtr stream;
|
||
|
AVFormatContext* format_ctx;
|
||
|
|
||
|
int av_sync_type;
|
||
|
uint64_t external_clock_base;
|
||
|
|
||
|
AVStream** audio_st;
|
||
|
PacketQueue audioq;
|
||
|
|
||
|
AVStream** video_st;
|
||
|
double frame_last_pts;
|
||
|
double video_clock; ///<pts of last decoded frame / predicted pts of next decoded frame
|
||
|
PacketQueue videoq;
|
||
|
SwsContext* sws_context;
|
||
|
VideoPicture pictq[VIDEO_PICTURE_QUEUE_SIZE];
|
||
|
AVFrame* rgbaFrame; // used as buffer for the frame converted from its native format to RGBA
|
||
|
int pictq_size, pictq_rindex, pictq_windex;
|
||
|
boost::mutex pictq_mutex;
|
||
|
boost::condition_variable pictq_cond;
|
||
|
|
||
|
|
||
|
boost::thread parse_thread;
|
||
|
boost::thread video_thread;
|
||
|
|
||
|
volatile bool quit;
|
||
|
};
|
||
|
|
||
|
}
|
||
|
|
||
|
#endif
|