-
Notifications
You must be signed in to change notification settings - Fork 0
/
TheoraVideoManager.h
112 lines (89 loc) · 3.9 KB
/
TheoraVideoManager.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/************************************************************************************
This source file is part of the Theora Video Playback Library
For latest info, see http://libtheoraplayer.sourceforge.net/
*************************************************************************************
Copyright (c) 2008-2010 Kresimir Spes ([email protected])
This program is free software; you can redistribute it and/or modify it under
the terms of the GNU Lesser General Public License (LGPL) as published by the
Free Software Foundation; either version 2 of the License, or (at your option)
any later version.
This program is distributed in the hope that it will be useful, but WITHOUT
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License along with
this program; if not, write to the Free Software Foundation, Inc., 59 Temple
Place - Suite 330, Boston, MA 02111-1307, USA, or go to
http://www.gnu.org/copyleft/lesser.txt.
*************************************************************************************/
#ifndef _TheoraVideoManager_h
#define _TheoraVideoManager_h
#include <vector>
#include <string>
#include "TheoraExport.h"
#include "TheoraVideoClip.h"
#ifdef _WIN32
#pragma warning( disable: 4251 ) // MSVC++
#endif
// forward class declarations
class TheoraWorkerThread;
class TheoraMutex;
class TheoraDataSource;
class TheoraAudioInterfaceFactory;
/**
This is the main singleton class that handles all playback/sync operations
*/
class TheoraPlayerExport TheoraVideoManager
{
protected:
friend class TheoraWorkerThread;
typedef std::vector<TheoraVideoClip*> ClipList;
typedef std::vector<TheoraWorkerThread*> ThreadList;
//! stores pointers to worker threads which are decoding video and audio
ThreadList mWorkerThreads;
//! stores pointers to created video clips
ClipList mClips;
int mDefaultNumPrecachedFrames;
TheoraMutex* mWorkMutex;
TheoraAudioInterfaceFactory* mAudioFactory;
void createWorkerThreads(int n);
void destroyWorkerThreads();
/**
* Called by TheoraWorkerThread to request a TheoraVideoClip instance to work on decoding
*/
TheoraVideoClip* requestWork(TheoraWorkerThread* caller);
public:
TheoraVideoManager(int num_worker_threads=1);
virtual ~TheoraVideoManager();
//! get the global reference to the manager instance
static TheoraVideoManager& getSingleton();
//! get the global pointer to the manager instance
static TheoraVideoManager* getSingletonPtr();
//! search registered clips by name
TheoraVideoClip* getVideoClipByName(std::string name);
TheoraVideoClip* createVideoClip(std::string filename,TheoraOutputMode output_mode=TH_RGB,int numPrecachedOverride=0,bool usePower2Stride=0);
TheoraVideoClip* createVideoClip(TheoraDataSource* data_source,TheoraOutputMode output_mode=TH_RGB,int numPrecachedOverride=0,bool usePower2Stride=0);
void update(float time_increase);
void destroyVideoClip(TheoraVideoClip* clip);
void setAudioInterfaceFactory(TheoraAudioInterfaceFactory* factory);
TheoraAudioInterfaceFactory* getAudioInterfaceFactory();
int getNumWorkerThreads();
void setNumWorkerThreads(int n);
void setDefaultNumPrecachedFrames(int n) { mDefaultNumPrecachedFrames=n; }
int getDefaultNumPrecachedFrames() { return mDefaultNumPrecachedFrames; }
//! used by libtheoraplayer functions
void logMessage(std::string msg);
/**
\brief you can set your own log function to recieve theora's log calls
This way you can integrate libtheoraplayer's log messages in your own
logging system, prefix them, mute them or whatever you want
*/
static void setLogFunction(void (*fn)(std::string));
//! get nicely formated version string
std::string getVersionString();
/**
\brief get version numbers
if c is negative, it means it's a release candidate -c
*/
void getVersion(int* a,int* b,int* c);
};
#endif