mod_localmediaplay.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365
  1. #include "SpBase.h"
  2. #include "SpIni.h"
  3. #ifdef RVC_OS_WIN
  4. #include <Shlwapi.h>
  5. #pragma comment(lib, "ShLwApi.Lib")
  6. #include "../../Other/libwmpplayer/libwmpplayer.h"
  7. #include "../../Other/libimgplayer/libimgplayer.h"
  8. #else
  9. #include <pthread.h>
  10. #include <signal.h>
  11. #include <unistd.h>
  12. #include <semaphore.h>
  13. #endif // RVC_OS_WIN
  14. #include "../../Other/libmediaplayer/libmediaplayer.h"
  15. #include "../../Other/libpictureplayer/libpictureplayer.h"
  16. #include "../../Other/libaudioqueue/libaudioqueue.h"
  17. #include "LocalMediaPlay_server_g.h"
  18. #include "AdvertBase/AdvertSync.h"
  19. #include "AdvertManage/mediaManage.h"
  20. #include <iostream>
  21. #include "modVer.h"
  22. #include "EventCode.h"
  23. using namespace LocalMediaPlay;
  24. #define LOG_EVT_SELFCHECK_IEBROWSER_IDLE 0x50500007 //IEBrowser重启
  25. #define MAX_PLAY_CHANNELS 3 //最大播放通道数
  26. #define LOG_EVT_START_NOTICE_PLAY 0x31300101
  27. #define LOG_EVT_STOP_NOTICE_PLAY 0x31300102
  28. #define LOG_EVT_NOTICE_PLAY_FINISHED 0x31300103
  29. #define LOG_EVT_NOTICE_FILE_NOT_EXIST 0x31300104
  30. #define LOG_EVT_ADV_VIDEO_NOT_EXIST 0x31300105
  31. #define LOG_EVT_ADV_AUDIO_NOT_EXIST 0x31300106
  32. #define LOG_EVT_ADV_PIC_NOT_EXIST 0x31300107
  33. #define LOG_EVT_VICE_MONITOR_NOT_EXIST 0x31300108
  34. #define LOG_EVT_VICE_MONITOR_SET_ERROR 0x31300109
  35. #define LOG_EVT_NOTICE_PLAY_EARLY_TERM 0x3130010A
  36. #define LOG_EVT_PLAYING_AUDIO_INFOS 0x3130010B
  37. #define LOG_EVT_NOTICE_FILE_NOT_VALID 0x3130010C
  38. #define LOG_EVT_MEDIAPLAY_COST_TIME_ERROR 0x3130010D
  39. #ifndef RVC_AUDIO_LEN
  40. #define RVC_AUDIO_LEN 320
  41. #endif // !RVC_AUDIO_LEN
  42. #ifndef RVC_AUDIO_BUFFER_LEN
  43. #define RVC_AUDIO_BUFFER_LEN 320*8*2
  44. #endif // !RVC_AUDIO_BUFFER_LEN
  45. typedef struct {
  46. int nCfgInx;
  47. int nWndX;
  48. int nWndY;
  49. int nWndWidth;
  50. int nWndHeight;
  51. }MediaPlayParam;
  52. #ifdef RVC_OS_WIN
  53. DWORD WINAPI qryMedia(LPVOID lpv);
  54. DWORD WINAPI MediaPlayThread(LPVOID param);
  55. DWORD WINAPI clearOutdata(LPVOID lpv);
  56. DWORD WINAPI CheckAudioThread(LPVOID param);
  57. DWORD WINAPI NoticePlayThread(LPVOID param);
  58. DWORD WINAPI StartMediaPlayFunc(LPVOID param);
  59. DWORD WINAPI StartAudioPlayingThreadFunc(LPVOID param);
  60. DWORD WINAPI StartNoticePlayThreadFunc(LPVOID param);
  61. #endif
  62. #ifdef RVC_OS_WIN
  63. class CLocalMediaPlayEntity : public CWmpHostApi, public CImgHostApi, public CMediaHostApi, public CPicHostApi, public CEntityBase, public ILogListener
  64. #else
  65. class CLocalMediaPlayEntity : public CMediaHostApi, public CPicHostApi, public CEntityBase, public ILogListener
  66. #endif // RVC_OS_WIN
  67. {
  68. public:
  69. CLocalMediaPlayEntity();
  70. virtual ~CLocalMediaPlayEntity();
  71. virtual const char *GetEntityName() const { return "LocalMediaPlay"; }
  72. virtual bool IsService() const { return true; }
  73. const char* GetEntityVersion() const override
  74. {
  75. return MODULE_VERSION_FULL;
  76. }
  77. virtual CServerSessionBase *OnNewSession(const char* pszRemoteEntityName, const char * pszClass);
  78. virtual DeviceTypeEnum RvcGetDeviceType();
  79. #ifdef RVC_OS_WIN
  80. virtual BOOL LoadPlayConfig(CWmpPlayConfig& config, int CfgInx);
  81. virtual BOOL LoadPlayConfig(CImgPlayConfig& config, int CfgInx);
  82. virtual void WmpDebug(const char* fmt, ...);
  83. virtual void WmpLogEvt(int ievent, const char* strmsg);
  84. virtual void ImgDebug(const char* fmt, ...);
  85. #endif // _WIN32
  86. virtual int LoadPlayConfig(CMediaPlayConfig& config, int CfgInx);
  87. virtual int LoadPlayConfig(CPicPlayConfig& config, int CfgInx);
  88. virtual void Debug(media_loglevel log_level, const char* fmt, ...);
  89. virtual void PicDebug(pic_loglevel log_level, const char* fmt, ...);
  90. virtual void MediaPlayFinished(int iMediaType);
  91. virtual int GetMediaPlayerIcoPath(char* strPath, size_t uLen);
  92. virtual int GetPicPlayerIcoPath(char* strPath, size_t uLen);
  93. virtual int GetAudioOutDevName(char* strDev, size_t uLen);
  94. virtual int PlayingAudioDataCallback(audio_param_t* param, const void* input, unsigned long uaudiolen);
  95. bool GetPlayFlag();
  96. bool GetScanExitFlag();
  97. ErrorCodeEnum GetPcmRecordFlag();
  98. ErrorCodeEnum HandleRemoteRecord(const char* pszMessage);
  99. virtual void OnLog(const CAutoArray<CUUID> &SubIDs, const CUUID nLogID, const LogTypeEnum eLogType, const SeverityLevelEnum eLevel,
  100. const DWORD dwSysError, const DWORD dwUserCode, const DWORD dwEntityInstanceID, const WORD wEntityDevelID,
  101. const CAutoArray<DWORD> &Param, const char *pszEntityName, const char *pszModuleName, const char *pszMessage, const linkContext& pLinkInfo);
  102. virtual void OnPreStart(CAutoArray<CSimpleStringA> strArgs, CSmartPointer<ITransactionContext> pTransactionContext);
  103. ErrorCodeEnum __OnStart(ErrorCodeEnum preOperationError);
  104. virtual void OnStarted();
  105. virtual void OnPreClose(EntityCloseCauseEnum eCloseCause, CSmartPointer<ITransactionContext> pTransactionContext);
  106. ErrorCodeEnum __OnClose(ErrorCodeEnum preOperationError);
  107. void StartVideo(int nCfgInx, int nWndX, int nWndY, int nWndWidth, int nWndHeight);
  108. void StartAudio(const char *pAudioNames);
  109. void StartImage(int nCfgInx, int nWndX, int nWndY, int nWndWidth, int nWndHeight);
  110. void StopVideo(int nCfgInx);
  111. void StopAudio();
  112. void StopImage(int nCfgInx);
  113. void StopAll();
  114. bool GetLocalVideoVolume(int nCfgInx, int &nVolume);
  115. bool SetLocalVideoVolume(int nCfgInx, int nVolume);
  116. std::pair<bool, int> GetLocalAudioVolume();
  117. bool SetLocalAudioVolume(int nVolume);
  118. bool IsRunConfigExist();
  119. ErrorCodeEnum StartNotice(int nCfgInx, int nWndX, int nWndY, int nWndWidth, int nWndHeight, const char *pVideoName);
  120. ErrorCodeEnum StartMediaPlayerNotice(int nCfgInx, int nWndX, int nWndY, int nWndWidth, int nWndHeight, const char *pVideoName);
  121. ErrorCodeEnum StartFFPlayerNotice(int nCfgInx, int nWndX, int nWndY, int nWndWidth, int nWndHeight, const char *pVideoName);
  122. void SetLogFlag(bool bflag);
  123. bool GetLogFlag();
  124. void SetLocalLogFlag(bool bflag);
  125. bool GetLocalLogFlag();
  126. void SetLocalPicLogFlag(bool bflag);
  127. bool GetLocalPicLogFlag();
  128. ErrorCodeEnum LoadEntityConfig();
  129. ErrorCodeEnum StopNotice(int nCfgInx);
  130. ErrorCodeEnum StopPlayAllMedias();
  131. DeviceTypeEnum GetDeviceType();
  132. private:
  133. virtual void OnSelfTest(EntityTestEnum eTestType, CSmartPointer<ITransactionContext> pTransactionContext);
  134. // 按分隔符分隔字符串
  135. void CStringSplit(char *str, char **result, const char *del);
  136. #ifdef RVC_OS_WIN
  137. friend DWORD WINAPI clearOutdata(LPVOID lpv);
  138. friend DWORD WINAPI qryMedia(LPVOID lpv);
  139. friend DWORD WINAPI MediaPlayThread(LPVOID param);
  140. friend DWORD WINAPI CheckAudioThread(LPVOID param);
  141. friend DWORD WINAPI NoticePlayThread(LPVOID param);
  142. friend DWORD WINAPI StartMediaPlayFunc(LPVOID param);
  143. friend DWORD WINAPI StartAudioPlayingThreadFunc(LPVOID param);
  144. friend DWORD WINAPI StartNoticePlayThreadFunc(LPVOID param);
  145. #else
  146. friend void* queryMedia(void* param);
  147. friend void* StartAudioPlayingThreadFunc(void* param);
  148. friend void* StartMediaPlayFunc(void* param);
  149. friend void* StartNoticePlayThreadFunc(void* param);
  150. #endif // RVC_OS_WIN
  151. void setMediaPath();
  152. void SecureClientRelease();
  153. bool SecureClientConnect();
  154. void loadDefaultMedia(bool fNewVersion = true);
  155. int GetPlayerIcoPath(char* strPath, size_t uLen);
  156. int GetAudioOutDev();
  157. private:
  158. int m_id_seq;
  159. CUUID m_SubIDIEIdle;
  160. CUUID m_SubIDStartRecord;
  161. CUUID m_SubIDStopRecord;
  162. #ifdef RVC_OS_WIN
  163. // 视频播放对象指针数组
  164. Clibwmpplayer* m_pVideoPlayer[MAX_PLAY_CHANNELS];
  165. // 音频播放对象指针
  166. Clibwmpplayer* m_pAudioPlayer;
  167. // 图片播放对象指针数组
  168. Clibimgplayer* m_pImagePlayer[MAX_PLAY_CHANNELS];
  169. #endif // RVC_OS_WIN
  170. // 媒体播放对象指针数组
  171. Clibmediaplayer* m_pMediaPlayer[MAX_PLAY_CHANNELS];
  172. // 图片播放对象指针数组
  173. Clibpictureplayer* m_pPicturePlayer[MAX_PLAY_CHANNELS];
  174. Clibmediaplayer* m_pMediaAudioPlayer;
  175. //连接获取最新广告资源
  176. CAdvertSyncConnection *m_connection;
  177. mediaManage m_mediaManage;
  178. MediaPlayParam m_mediaParam;
  179. int m_defaultVolum;
  180. std::string m_lastPlayAudio;
  181. std::string m_lastPlayVideo;
  182. DeviceTypeEnum m_eDeviceType;
  183. bool m_bLogFlag;
  184. bool m_bLocalLogFlag;
  185. CSimpleStringA m_AudioPath;
  186. bool m_bLocalPicLogFlag;
  187. bool m_bRecordPCM;
  188. bool m_bStartRecord;
  189. bool m_bloged;
  190. #ifdef RVC_OS_WIN
  191. HANDLE m_scanThreadId;
  192. HANDLE m_uMediaPlayThreadId;
  193. HANDLE m_uNoticePlayThreadId;
  194. HANDLE m_scanThread, m_playThread;
  195. vector<CWmpPlayConfig> m_defaultVideo;
  196. vector<CWmpPlayConfig> m_defaultAudio;
  197. vector<CImgPlayConfig> m_defaultImg;
  198. #else
  199. pthread_t m_scanThreadId;
  200. pthread_t m_uMediaPlayThreadId;
  201. pthread_t m_uNoticePlayThreadId;
  202. #endif // RVC_OS_WIN
  203. vector<CMediaPlayConfig> m_Videos;
  204. vector<CMediaPlayConfig> m_Audios;
  205. vector<CPicPlayConfig> m_defaultPic;
  206. volatile bool m_badplayflag;
  207. bool m_scanexitflag;
  208. CSimpleStringA m_strAudioOutDev;
  209. bool m_bgetflag;
  210. bool m_bgetico;
  211. Clibaudioqueue* m_remote_audio_queue;
  212. FILE* m_pFile;
  213. char m_audiobuffer[RVC_AUDIO_BUFFER_LEN];
  214. int m_leftlen;
  215. int m_iseriesnumber;
  216. bool m_buserstopaudio;
  217. int m_iPlayType;
  218. pic_loglevel m_piclevel;
  219. media_loglevel m_medialevel;
  220. };
  221. class CLocalMediaPlaySession : public PlayService_ServerSessionBase
  222. {
  223. public:
  224. CLocalMediaPlaySession(CLocalMediaPlayEntity* pEntity, int id) : m_id(id), m_pEntity(pEntity)
  225. {
  226. }
  227. virtual void Handle_StartPlayVideo(SpReqAnsContext<PlayService_StartPlayVideo_Req, PlayService_StartPlayVideo_Ans>::Pointer ctx);
  228. virtual void Handle_StartPlayAudio(SpReqAnsContext<PlayService_StartPlayAudio_Req, PlayService_StartPlayAudio_Ans>::Pointer ctx);
  229. virtual void Handle_StartPlayImage(SpReqAnsContext<PlayService_StartPlayImage_Req, PlayService_StartPlayImage_Ans>::Pointer ctx);
  230. virtual void Handle_StopPlayVideo(SpReqAnsContext<PlayService_StopPlayVideo_Req, PlayService_StopPlayVideo_Ans>::Pointer ctx);
  231. virtual void Handle_StopPlayAudio(SpReqAnsContext<PlayService_StopPlayAudio_Req, PlayService_StopPlayAudio_Ans>::Pointer ctx);
  232. virtual void Handle_StopPlayImage(SpReqAnsContext<PlayService_StopPlayImage_Req, PlayService_StopPlayImage_Ans>::Pointer ctx);
  233. virtual void OnClose(ErrorCodeEnum eErrorCode);
  234. virtual void Handle_GetLocalVideoVolume(SpReqAnsContext<PlayService_GetLocalVideoVolume_Req, PlayService_GetLocalVideoVolume_Ans>::Pointer ctx);
  235. virtual void Handle_SetLocalVideoVolume(SpReqAnsContext<PlayService_SetLocalVideoVolume_Req, PlayService_SetLocalVideoVolume_Ans>::Pointer ctx);
  236. virtual void Handle_GetLocalAudioVolume(SpReqAnsContext<PlayService_GetLocalAudioVolume_Req, PlayService_GetLocalAudioVolume_Ans>::Pointer ctx);
  237. virtual void Handle_SetLocalAudioVolume(SpReqAnsContext<PlayService_SetLocalAudioVolume_Req, PlayService_SetLocalAudioVolume_Ans>::Pointer ctx);
  238. virtual void Handle_StartPlayNotice(SpReqAnsContext<PlayService_StartPlayNotice_Req, PlayService_StartPlayNotice_Ans>::Pointer ctx);
  239. virtual void Handle_StopPlayNotice(SpReqAnsContext<PlayService_StopPlayNotice_Req, PlayService_StopPlayNotice_Ans>::Pointer ctx);
  240. virtual void Handle_StopPlayAllMedias(SpReqAnsContext<PlayService_StopPlayAllMedias_Req, PlayService_StopPlayAllMedias_Ans>::Pointer ctx);
  241. private:
  242. int m_id;
  243. CLocalMediaPlayEntity* m_pEntity;
  244. };