12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444 |
- #include "stdafx.h"
- #include "y2k_time.h"
- #include "capture.h"
- #include "Event.h"
- #include "CommEntityUtil.hpp"
- #include "fileutil.h"
- #ifdef RVC_OS_WIN
- #include "iaudiorenderinterface.h"
- #endif
- #include "../mod_snapshot/Event.h"
- #include "mod_mediacontroller.h"
- #include "../mod_interactivecontrol/Event.h"
- #include "../mod_recorder/Event.h"
- #include "../mod_counterconnector/Event.h"
- #include "../mod_sipphone/Event.h"
- #include "../mod_SalesRecorder/Event.h"
- #include "../mod_evtconverter/Event.h"
- #ifndef AUTOMATCH_CAMERA_ENV
- #define AUTOMATCH_CAMERA_ENV "ENV_"
- #endif
- #ifndef AUTOMATCH_CAMERA_OPT
- #define AUTOMATCH_CAMERA_OPT "OPT_"
- #endif
- #ifndef MAX_PATH
- #define MAX_PATH 260
- #endif
- #ifndef RVC_CAMERA_OFF_TIMER
- #define RVC_CAMERA_OFF_TIMER 3
- #endif // !RVC_CAMERA_OFF_TIMER
- #ifndef RVC_CAMERA_CAP_PROCESS
- #define RVC_CAMERA_CAP_PROCESS 4
- #endif // !RVC_CAMERA_CAP_PROCESS
- #ifdef RVC_OS_WIN
- static void __audio_render_log(void* user_data, const char* fmt, va_list arg)
- {
- int n = vsnprintf(NULL, 0, fmt, arg);
- if (n >= MAX_PATH) {
- char* buf = (char*)malloc((size_t)(n + 1));
- vsnprintf(buf, n + 1, fmt, arg);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("%s", buf);
- free(buf);
- }
- else{
- char strlog[MAX_PATH] = {0};
- vsnprintf(strlog, MAX_PATH, fmt, arg);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("%s", strlog);
- }
- }
- #else
- static void __audiomgrlog(void* user_data, const char* fmt, va_list arg)
- {
- int n = vsnprintf(NULL, 0, fmt, arg);
- if (n >= MAX_PATH) {
- char* buf = (char*)malloc((size_t)(n + 1));
- vsnprintf(buf, n + 1, fmt, arg);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("%s", buf);
- free(buf);
- }
- else{
- char strlog[MAX_PATH] = {0};
- vsnprintf(strlog, MAX_PATH, fmt, arg);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("%s", strlog);
- }
- }
- #endif
- static int GetFormatString(char* strVala, size_t uValaLen, char* strValb, size_t uValbLen, const char* pSrc, size_t uSrcLen, char cWord)
- {
- int iRet = -1;
- if (NULL == pSrc || 0 == uSrcLen || MAX_PATH < uSrcLen) {
- return iRet;
- }
- char strBuffer[MAX_PATH] = { 0 };
- memcpy(strBuffer, pSrc, uSrcLen);
- char* pIndex = NULL;
- if (pIndex = strrchr(strBuffer, cWord)) {
- char* pHash = pIndex + sizeof(char);
- *pIndex = '\0';
- if (NULL != pHash) {
- memcpy(strVala, strBuffer, pIndex - strBuffer);
- memcpy(strValb, pHash, strlen(pHash));
- iRet = 0;
- }
- }
- return iRet;
- }
- static void LogTransToCMSEvt()
- {
- static bool blogevt = false;
- if (false == blogevt) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_JSOCCUPYCAMERA_REQUEST, "js occupy camera request evt.");
- blogevt = true;
- }
- }
- CMediaControllerEntity::CMediaControllerEntity(): m_capture(NULL), m_salesaudio_capture(NULL), m_lCaptureEnvCount(0), m_lCaptureEnvOptCount(0), m_lCaptureOptCount(0),
- m_pHMClient(NULL),m_pMediaControllerChannel(NULL),m_bIsRemoteRecord(false), m_bHasStartSpeakerRender(false), m_bConnectedAssist(false)
- {
- #ifdef RVC_OS_WIN
- m_pAudioRenderObj = NULL;
- m_bSpeakerCap = true;
- #else
- m_env_mutex = PTHREAD_MUTEX_INITIALIZER;
- m_opt_mutex = PTHREAD_MUTEX_INITIALIZER;
- m_envopt_mutex = PTHREAD_MUTEX_INITIALIZER;
- m_pAudioCap = NULL;
- #endif
- m_iCamTimeout = CAMERA_TIMEOUT;
- m_iDelayTime = RVC_MAX_DELAY_TIME;
- m_interValTime = RVC_CAM_INTERVAL_TIME;
- m_bOnBusiness = false;
- m_bJsOccupyCamera = false;
- m_bCameraOffTimerOn = false;
- m_eDeviceType = eStand2sType;
- m_nCameraErrorCode = Error_Succeed;
- memset(&conf, 0, sizeof(capture_config_t));
- memset(&m_sales_audio_conf, 0, sizeof(rvc_audio_capture_config_t));
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- m_PhotoSaveDir = "";
- #endif
- #endif
- }
- void CMediaControllerEntity::OnSysVarEvent(const char *pszKey, const char *pszValue,const char *pszOldValue,const char *pszEntityName)
- {
- if (_stricmp(pszKey, SYSVAR_CALLSTATE) == 0)
- {
- CSimpleStringA strState;
- GetFunction()->GetSysVar("UIState", strState);
- if ('C' == pszValue[0]) {
- if (!m_bStartCamera) {
- StartCameraAndSetSysVar();
- if (m_bStartCamera) {
- OnCameraStarted();
- }
- }
- else {
- if (strState.GetLength() > 0 && strState[0] == 'M') {
- if (m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->KillTimer(RVC_CAMERA_OFF_TIMER)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "Call State is Connecting, and UIState is M, kill camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = false;
- }
- }
- }
- }
- }
- else if ('O' == pszValue[0]){
- if (strState.GetLength() > 0 && strState[0] == 'M') {
- if (m_bStartCamera) {
- if (false == m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->SetTimer(RVC_CAMERA_OFF_TIMER, this, m_iDelayTime * 1000)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_SETTIMER_ERROR, "Call State is OffLine, and UIState is M, set camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = true;
- }
- }
- }
- }
- }
- }
- }
- void CMediaControllerEntity::OnPreStart(CAutoArray<CSimpleStringA> strArgs,CSmartPointer<ITransactionContext> pTransactionContext)
- {
- m_eDeviceType = eStand2sType;
- g_eDeviceType = eStand2sType;
- //is Pad Version
- m_eDeviceType = RvcGetDeviceType();
- g_eDeviceType = m_eDeviceType;
-
- #ifdef RVC_OS_LINUX
- {
- audiomgr_callback_t t_callback = { 0 };
- t_callback.debug = &__audiomgrlog;
- m_pAudioCap = CreateAudioMgrObj(&t_callback);
- if (0 != m_pAudioCap->audio_mgr_initialize()) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Audio Manager Initialize failed!");
- return;
- }
- }
- #endif
- if (GetFunction()->RegistSysVarEvent("SessionID", this) != Error_Succeed){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("register sysvar %s failed!", "SessionID");
- }
- if (GetFunction()->RegistSysVarEvent(SYSVAR_CALLSTATE, this) != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("register sysvar %s failed!", SYSVAR_CALLSTATE);
- }
- SetCameraSysVar(CAMERA_STATE_INIT);
- int i = 0;
- m_arrListener.Init(15);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, MOD_EVENT_SNAPSHOT_START_CAPTURE_ENV);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, MOD_EVENT_SNAPSHOT_START_CAPTURE_OPT);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, MOD_EVENT_SNAPSHOT_START_CAPTURE_ENVOPT);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_MOD_ASSISCHAN_STARTED_SUCCESS,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_RECORDFAILED,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_RECORDFAILED,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_STARTREMOTERECORD,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_STOPREMOTERECORD,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_MOD_SALESRECORDER_STARTED_SUCCESS, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_Middle, Error_IgnoreAll, LOG_EVT_BEGIN_HANDLE_BUSINESS, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_Middle, Error_IgnoreAll, LOG_EVT_END_HANDLE_BUSINESS, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_MOD_FACETRACKING_STARTED_SUCCESS, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_Middle, Error_IgnoreAll, EVENT_MOD_CONNECT_BEGAIN_RECORD_CALL, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_STARTCAMERACAPTURE, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_STOPCAMERACAPTURE, NULL, false);
- pTransactionContext->SendAnswer(Error_Succeed);
- }
- void CMediaControllerEntity::OnStarted()
- {
- m_bStartCamera = false;
- ErrorCodeEnum Error = Error_Succeed;
- //MessageBoxA(0,0,0,0);
- m_pMediaControllerChannel = new ChannelMediaControllerClient(this);
- if (Error_Succeed == ConnectAssistChannel()) {
- m_bConnectedAssist = true;
- }
- m_pHMClient = new HealthManagerService_ClientBase(this);
- Error = m_pHMClient->Connect();
- if (Error != Error_Succeed){
- m_pHMClient->SafeDelete();
- m_pHMClient = NULL;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("m_pHMClient connect fail!");
- }
- if (Error_Succeed != GetMediaConfig()) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get entity config from config failed!");
- }
- if (Error_Succeed == GetSalesRecordAudioParam()) {
- //DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get sales record audio param success, record local PCM flag is %s.", m_bRecordPCM ? "true" : "false");
- }
- #ifdef RVC_OS_WIN
- audiorender_callback_t t_callback = { 0 };
- t_callback.debug = &__audio_render_log;
- t_callback.user_data = this;
- m_pAudioRenderObj = CreateIAudioRenderObj(&t_callback);
- if (NULL == m_pAudioRenderObj){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("create audio render failed.");
- }
- #endif
- int icamnum = 0;
- Error = (ErrorCodeEnum)capture_lib_init(&icamnum);
- if (Error == Error_Succeed)
- {
- RvcGetAudioDevice();
- RvcCheckCameraInfo(icamnum);
- Error = LoadConfig(&conf);
- if (Error != Error_Succeed)
- {
- if ((Error == Error_OptCamera) || (Error == Error_EnvCamera))
- {
- if (Error == Error_EnvCamera)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Load EnvCamera Config failed!");
- SetCameraSysVar(CAMERA_ENV_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_ENV_ERROR");
- m_nCameraErrorCode = Error_EnvCamera;
- }
- else if (Error == Error_OptCamera)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Load OptCamera Config failed!");
- SetCameraSysVar(CAMERA_OPT_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_OPT_ERROR");
- m_nCameraErrorCode = Error_OptCamera;
- }
- }
- else
- {
- if (Error == Error_AllCamera)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Load all camera Config failed!");
- SetCameraSysVar(CAMERA_BOTH_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_BOTH_ERROR");
- m_nCameraErrorCode = Error_AllCamera;
- }
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Load Config failed!");
- }
- }
- else {
- SetCameraSysVar(CAMERA_NO_ERROR);
- }
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("capture_lib_init failed!");
- }
-
- LogEvent(Severity_Middle, LOG_EVT_MOD_MEDIACONTROLLER_STARTED_SUCCESS, "mediacontroller entity started successfully.");
- if (Error != Error_AllCamera)
- {
- CSimpleStringA uiState("");
- GetFunction()->GetSysVar("UIState", uiState);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Get UIState value is %s.", uiState.GetData());
- if (uiState.GetLength() > 0 && uiState[0] == 'F') {
- StartCameraAndSetSysVar();
- if (m_bStartCamera) {
- OnCameraStarted();
- }
- }
- }
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- Error = GetFunction()->GetPath("Temp", m_PhotoSaveDir);
- if (Error != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get global record save path failed!");
- }
- if (m_PhotoSaveDir.GetLength() > 0 && m_PhotoSaveDir[m_PhotoSaveDir.GetLength() - 1] != SPLIT_SLASH) {
- m_PhotoSaveDir += SPLIT_SLASH_STR;
- }
- m_PhotoSaveDir += "CameraPhoto";
- m_PhotoSaveDir += SPLIT_SLASH_STR;
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("photo save dir is %s.", m_PhotoSaveDir.GetData());
- #endif
- #endif
- }
- ErrorCodeEnum CMediaControllerEntity::RvcCheckCameraInfo(int iCamNumber)
- {
- ErrorCodeEnum Error = Error_Succeed;
- bool bnumbererror = false;
- if (eStand2sType == m_eDeviceType) {
- if (3 != iCamNumber) {
- bnumbererror = true;
- }
- }
- else if (eStand1SPlusType == m_eDeviceType) {
- if (1 != iCamNumber) {
- bnumbererror = true;
- }
- }
- if (bnumbererror) {
- LogWarn(Severity_Middle, Error_Debug, ERROR_MOD_MEDIACONTROLLER_CAMERA_NUM, CSimpleStringA::Format("camera number(%d) error.", iCamNumber).GetData());
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::RvcGetAudioDevice()
- {
- ErrorCodeEnum Error = Error_Param;
- #ifdef RVC_OS_LINUX
- if (NULL != m_pAudioCap) {
- int icountmic = m_pAudioCap->audio_get_device_count(true);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("audio input devices(%d):", icountmic);
- int i = 0;
- for (; i < icountmic; i++) {
- char strname[MAX_PATH] = { 0 };
- m_pAudioCap->audio_get_device_name(strname, MAX_PATH, true, i);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("%d = %s", i, strname);
- }
- int icountspeaker = m_pAudioCap->audio_get_device_count(false);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("audio output devices(%d):", icountspeaker);
- for (i = 0; i < icountspeaker; i++) {
- char strname[MAX_PATH] = { 0 };
- m_pAudioCap->audio_get_device_name(strname, MAX_PATH, false, i);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("%d = %s", i, strname);
- }
- Error = Error_Succeed;
- }
- #endif
- return Error;
- }
- DeviceTypeEnum CMediaControllerEntity::RvcGetDeviceType()
- {
- DeviceTypeEnum eType = eStand2sType;
- CSmartPointer<IEntityFunction> spFunction = GetFunction();
- CSystemStaticInfo stStaticinfo;
- spFunction->GetSystemStaticInfo(stStaticinfo);
- if (_stricmp(stStaticinfo.strMachineType, "RVC.Stand1SPlus") == 0) {
- eType = eStand1SPlusType;
- }
- else if (_stricmp(stStaticinfo.strMachineType, "RVC.CardStore") == 0 || _stricmp(stStaticinfo.strMachineType, "RVC.CardPrinter") == 0) {
- eType = eCardStore;
- }
- else {
- eType = eStand2sType;
- }
- if (eType >= 0 && eType < sizeof(Device_Type_Table) / sizeof(char*)) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("device type is %s.", Device_Type_Table[eType]);
- }
- return eType;
- }
- DeviceTypeEnum CMediaControllerEntity::RvcDeviceType()
- {
- return m_eDeviceType;
- }
- ErrorCodeEnum CMediaControllerEntity::GetSalesRecordAudioParam()
- {
- ErrorCodeEnum Error = Error_Succeed;
- #ifdef RVC_OS_WIN
- CSmartPointer<IConfigInfo> spConfig;
- SpIniMappingTable table;
- int iPlayType = 0;
- Error = GetFunction()->OpenConfig(Config_CenterSetting, spConfig);
- if (Error == Error_Succeed) {
- table.AddEntryInt("LocalMediaPlay", "PlayType", iPlayType, 0);
- Error = table.Load(spConfig);
- }
- if (0 != iPlayType) {
- m_bSpeakerCap = false;
- }
- #endif // RVC_OS_WIN
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::GetMediaConfig()
- {
- ErrorCodeEnum Error = Error_Succeed;
- CSmartPointer<IConfigInfo> spConfig;
- SpIniMappingTable table;
- int itimeout = CAMERA_TIMEOUT;
- int iDelayTime = RVC_MAX_DELAY_TIME;
- unsigned int intervaltime = RVC_CAM_INTERVAL_TIME;
- Error = GetFunction()->OpenConfig(Config_CenterSetting, spConfig);
- if (Error == Error_Succeed){
- table.AddEntryInt("MediaController", "CamTimeOut", itimeout, CAMERA_TIMEOUT);
- table.AddEntryInt("MediaController", "MaxDelayTime", iDelayTime, RVC_MAX_DELAY_TIME);
- table.AddEntryUInt("MediaController", "InterValTime", intervaltime, RVC_CAM_INTERVAL_TIME);
- Error= table.Load(spConfig);
- }
-
- if (Error_Succeed != Error){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get entity config from config failed!");
- }
- else{
- if (itimeout >= CAMERA_MIN_TIMEOUT && itimeout <= CAMERA_TIMEOUT) {
- m_iCamTimeout = itimeout;
- }
- if (iDelayTime > 0) {
- m_iDelayTime = iDelayTime;
- }
- if (intervaltime <= RVC_CAM_INTERVAL_TIME && intervaltime >= RVC_CAM_INTERVAL_TIME / 3) {
- m_interValTime = intervaltime;
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::SetCameraSysVar(const CSimpleStringA &newVal)
- {
- CSmartPointer<IEntityFunction> spFunction = this->GetFunction();
-
- CSimpleStringA val = newVal;
- if('B' == val[0]){
- LogWarn(Severity_Middle, Error_Debug, ERROR_MOD_MEDIACONTROLLER_CONFIG_ALLERROR, "all config cameras error");
- }
- return spFunction->SetSysVar(SYSVAR_CAMERASTATE, newVal.GetData());
- }
- void CMediaControllerEntity::OnPreClose(EntityCloseCauseEnum eCloseCause,CSmartPointer<ITransactionContext> pTransactionContext)
- {
- CSmartPointer<IEntityFunction> spFunction = GetFunction();
- for (int i = 0; i < m_arrListener.GetCount(); ++i) {
- spFunction->UnsubscribeLog(m_arrListener[i]);
- }
- spFunction->UnregistSysVarEvent(SYSVAR_CALLSTATE);
- if (m_capture) {
- capture_stop(m_capture);
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- if (m_salesaudio_capture){
- salesrecord_audio_capture_stop(m_salesaudio_capture);
- salesaudio_capture_destroy(m_salesaudio_capture);
- m_salesaudio_capture = NULL;
- }
- #ifdef RVC_OS_WIN
- if (NULL != m_pAudioRenderObj) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("destroy audio render obj,and it's addr is 0x%08x.", m_pAudioRenderObj);
- DestroyIAudioRenderObj(m_pAudioRenderObj);
- }
- #else
- if (NULL != m_pAudioCap){
- m_pAudioCap->audio_mgr_terminate();
- DestroyIAudioMgrObj(m_pAudioCap);
- m_pAudioCap = NULL;
- }
- #endif // RVC_OS_WIN
- capture_lib_term();
- pTransactionContext->SendAnswer(Error_Succeed);
- }
- void CMediaControllerEntity::OnTimeout(DWORD dwTimerID)
- {
- if (dwTimerID == 1) {
- if (!m_capture) {
- return;
- }
- if (!m_bStartCamera) {
- return;
- }
- OnTimeCameraStatusCheck();
- }
- else if (2 == dwTimerID) {
- if (false == m_bConnectedAssist) {
- if (Error_Succeed == ConnectAssistChannel()) {
- m_bConnectedAssist = true;
- }
- }
- if (true == m_bConnectedAssist) {
- GetFunction()->KillTimer(2);
- }
- }
- else if (RVC_CAMERA_OFF_TIMER == dwTimerID) {
- if (m_bStartCamera) {
- CSimpleStringA strCallState("");
- if (Error_Succeed == GetFunction()->GetSysVar(SYSVAR_CALLSTATE, strCallState)) {
- if (strCallState.Compare("O") == 0) {
- if (m_capture) {
- GetFunction()->KillTimer(1);
- capture_stop(m_capture);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode("QLR0402208V5")("关闭摄像头");
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- OnCameraStopped();
- m_bStartCamera = false;
- if (m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->KillTimer(RVC_CAMERA_OFF_TIMER)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "stop camera, kill camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = false;
- }
- }
- }
- }
- }
- }
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- else if (RVC_CAMERA_CAP_PROCESS == dwTimerID) {
- GetEnvCamCaptureProcess();
- }
- #endif
- #endif
- }
- void CMediaControllerEntity::OnTimeCameraStatusCheck()
- {
- int env_n = -1, opt_n = -1;
- unsigned int nLastEnvTime = 0, nLastOptTime = 0;
- static bool bEnvTimeout = false, bOptTimeout = false;
- static int iEnvEmptyTimes(0), iOptEmptyTimes(0), iEnvCameraRestartNum(0), iOptCameraRestartNum(0);
- bool bSingleCamera = false;
- if (eStand1SPlusType == m_eDeviceType){
- bSingleCamera = true;
- }
- capture_detect_camera_bug(m_capture, &env_n, &opt_n, bSingleCamera);
- capture_get_last_frametime(m_capture, &nLastEnvTime, &nLastOptTime);
- if (env_n == 0) {
- if (iEnvEmptyTimes < CAMERA_BUG_THRESHOLD){
- iEnvEmptyTimes++;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("get env camera picture fail, times=%d.",iEnvEmptyTimes);
- }
- }
- else if (env_n == -1){
- iEnvEmptyTimes = CAMERA_BUG_THRESHOLD;
- }
- else {
- if (iEnvEmptyTimes == CAMERA_BUG_THRESHOLD){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("env camera get video right again.");
- }
- iEnvEmptyTimes = 0;
- }
- //env图像是否超时
- if(nLastEnvTime > 0)
- {
- if(((y2k_time_now()-nLastEnvTime) > m_iCamTimeout)&&!bEnvTimeout)
- {
- bEnvTimeout = true;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("bEnvTimeout.");
- }
- else if (((y2k_time_now()-nLastEnvTime) < m_iCamTimeout)&&bEnvTimeout)
- {
- bEnvTimeout = false;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("change env camera from bEnvTimeout to ok.");
- }
- }
- //env是否30S没有图像或者图像15秒没有更新
- if(((iEnvEmptyTimes == CAMERA_BUG_THRESHOLD)||bEnvTimeout)&&(m_nCameraErrorCode!=Error_EnvCamera)&&(m_nCameraErrorCode!=Error_AllCamera))
- {
- char strMessage[MAX_PATH*2] = {0};
- get_camera_exception_message(strMessage, MAX_PATH*2, conf.strVideoEnv, "Env camera bug detected!");
- char strInfo[MAX_PATH*2] = {0};
- if ((NULL != m_capture) && (NULL != m_capture->env_video)) {
- snprintf(strInfo, MAX_PATH * 2, "%s and current time = %u, env last capture time = %u, video queue LastEnvTime = %u.", strMessage, y2k_time_now(), m_capture->env_video->ulastcaptime, nLastEnvTime);
- }
- else {
- snprintf(strInfo, MAX_PATH * 2, "%s", strMessage);
- }
-
- LogWarn(Severity_Middle, Error_Hardware, ERROR_MOD_MEDIACONTROLLER_ENVCAMERA_BUG, strInfo);
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V4").setResultCode("RTA2805")("上摄像头故障,采集不到图像");
- if (eStand1SPlusType == m_eDeviceType){
- m_nCameraErrorCode = Error_AllCamera;
- }
- else{
- if (m_nCameraErrorCode == Error_Succeed){
- m_nCameraErrorCode = Error_EnvCamera;
- }
- else if (m_nCameraErrorCode == Error_OptCamera){
- m_nCameraErrorCode = Error_AllCamera;
- }
- }
- ChangeSysvar(m_nCameraErrorCode);
- }
- else if((iEnvEmptyTimes != CAMERA_BUG_THRESHOLD)&&!bEnvTimeout&&((m_nCameraErrorCode == Error_EnvCamera)||(m_nCameraErrorCode == Error_AllCamera)))
- {
- if (eStand1SPlusType == m_eDeviceType){
- m_nCameraErrorCode = Error_Succeed;
- }
- else{
- if (m_nCameraErrorCode == Error_EnvCamera){
- m_nCameraErrorCode = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("changeSysvar to No_Error");
- }
- else if (m_nCameraErrorCode == Error_AllCamera){
- m_nCameraErrorCode = Error_OptCamera;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("changeSysvar to Opt_Error");
- }
- }
- ChangeSysvar(m_nCameraErrorCode);
- }
- //opt是否没有图像
- if (eStand2sType == m_eDeviceType)
- {
- if (opt_n == 0)
- {
- if (iOptEmptyTimes < CAMERA_BUG_THRESHOLD)
- {
- iOptEmptyTimes++;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("get opt camera picture fail, times = %d.",iOptEmptyTimes);
- }
- }
- else if (opt_n == -1)
- {
- iOptEmptyTimes = CAMERA_BUG_THRESHOLD;
- }
- else
- {
- if (iOptEmptyTimes == CAMERA_BUG_THRESHOLD)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("opt camera get video right again!");
- }
- iOptEmptyTimes = 0;
- }
- }
- //opt图像是否超时
- if (eStand2sType == m_eDeviceType) {
- if (nLastOptTime > 0)
- {
- if (((y2k_time_now() - nLastOptTime) > m_iCamTimeout) && !bOptTimeout)
- {
- bOptTimeout = true;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("bOptTimeout");
- }
- else if (((y2k_time_now() - nLastOptTime) < m_iCamTimeout) && bOptTimeout)
- {
- bOptTimeout = false;
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("change opt camera from bOptTimeout to ok");
- }
- }
- }
- //opt是否100S没有图像或者图像20秒没有更新
- if(((iOptEmptyTimes == CAMERA_BUG_THRESHOLD)||bOptTimeout)&&(m_nCameraErrorCode!=Error_OptCamera)&&(m_nCameraErrorCode!=Error_AllCamera)&&(eStand2sType == m_eDeviceType))
- {
- char strMessage[MAX_PATH*2] = {0};
- get_camera_exception_message(strMessage, MAX_PATH*2, conf.strVideoOpt, "Opt camera bug detected!");
- char strInfo[MAX_PATH*2] = {0};
- if (NULL != m_capture && NULL != m_capture->opt_video) {
- snprintf(strInfo, MAX_PATH * 2, "%s and current time = %u, opt last capture time = %u, video queue LastOptTime = %u.", strMessage, y2k_time_now(), m_capture->opt_video->ulastcaptime, nLastOptTime);
- }
- else {
- snprintf(strInfo, MAX_PATH * 2, "%s.", strMessage);
- }
-
- LogWarn(Severity_Middle, Error_Hardware, ERROR_MOD_MEDIACONTROLLER_OPECAMERA_BUG, strInfo);
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V4").setResultCode("RTA2806")("下摄像头故障,采集不到图像");
- if (m_nCameraErrorCode == Error_Succeed)
- {
- m_nCameraErrorCode = Error_OptCamera;
- }
- else if (m_nCameraErrorCode == Error_EnvCamera)
- {
- m_nCameraErrorCode = Error_AllCamera;
- }
- ChangeSysvar(m_nCameraErrorCode);
- }
- else if((iOptEmptyTimes != CAMERA_BUG_THRESHOLD)&&!bOptTimeout&&((m_nCameraErrorCode == Error_OptCamera)||(m_nCameraErrorCode == Error_AllCamera))&&(eStand2sType == m_eDeviceType))
- {
- if (m_nCameraErrorCode == Error_OptCamera)
- {
- m_nCameraErrorCode = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("changeSysvar to No_Error");
- }
- else if (m_nCameraErrorCode == Error_AllCamera)
- {
- m_nCameraErrorCode = Error_EnvCamera;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("changeSysvar to Env_Error");
- }
- ChangeSysvar(m_nCameraErrorCode);
- }
- //重新打开摄像头
- if((m_nCameraErrorCode == Error_EnvCamera)&&(iEnvCameraRestartNum<CAMERA_RESTARTNUM))
- {
- if (ReStartCamera(ENVCAMERA) != Error_Succeed){
- iEnvCameraRestartNum++;
- }
- else
- {
- iEnvCameraRestartNum = 0;
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- iEnvEmptyTimes = 0;
- bEnvTimeout = false;
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_RESTART_CAME_SUCCESS, "restart env camera success.");
- }
- }
- else if((m_nCameraErrorCode == Error_OptCamera)&&(iOptCameraRestartNum<CAMERA_RESTARTNUM)&&(eStand2sType == m_eDeviceType))
- {
- if (ReStartCamera(OPTCAMERA) != Error_Succeed) {
- iOptCameraRestartNum++;
- }
- else
- {
- iOptCameraRestartNum = 0;
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- iOptEmptyTimes = 0;
- bOptTimeout = false;
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_RESTART_CAME_SUCCESS, "restart opt camera success.");
- }
- }
- else if (m_nCameraErrorCode == Error_AllCamera)
- {
- if (iEnvCameraRestartNum<CAMERA_RESTARTNUM)
- {
- if (ReStartCamera(ENVCAMERA) != Error_Succeed) {
- iEnvCameraRestartNum++;
- }
- else
- {
- iEnvCameraRestartNum = 0;
- m_nCameraErrorCode = Error_OptCamera;
- ChangeSysvar(m_nCameraErrorCode);
- iEnvEmptyTimes = 0;
- bEnvTimeout = false;
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_RESTART_CAME_SUCCESS, "restart env camera success.");
- }
- }
- if((iOptCameraRestartNum<CAMERA_RESTARTNUM)&&(eStand2sType == m_eDeviceType))
- {
- if (ReStartCamera(OPTCAMERA) != Error_Succeed) {
- iOptCameraRestartNum++;
- }
- else
- {
- iOptCameraRestartNum = 0;
- iOptEmptyTimes = 0;
- bOptTimeout = false;
- if (m_nCameraErrorCode == Error_AllCamera)
- {
- m_nCameraErrorCode = Error_EnvCamera;
- }
- else
- {
- m_nCameraErrorCode = Error_Succeed;
- }
- ChangeSysvar(m_nCameraErrorCode);
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_RESTART_CAME_SUCCESS, "restart opt camera success.");
- }
- }
- }
- }
- bool CMediaControllerEntity::SetAutoBright(ErrorCodeEnum nCode)
- {
- return capture_set_autobrightness(m_capture,nCode);
- }
- //camera gain adjust
- void CMediaControllerEntity::OnReceivePkt(int sub_type, const char *buffer, int size)
- {
- if (sub_type == ACM_SET_CAMERABRIGHT)
- {
- if (m_bStartCamera)
- {
- if (eStand2sType == m_eDeviceType || eStand1SPlusType == m_eDeviceType)
- {
- //vamera bright adj
- CCameraBrightValue num;
- SpBuffer buf;
- buf.OpenRead(buffer, size);
- num.Serialize(buf);
- if (capture_adj_brightness(m_capture, num.nValue, m_nCameraErrorCode) == true)
- {
- SendCameraBright();
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_SET_CAMERA_BRIGHTNESS_INFO, CSimpleStringA::Format("set camera brightness to %d success.", num.nValue).GetData());
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ACM_SET_CAMERABRIGHT fail!");
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_SET_CAMERA_BRIGHTNESS_FAILED, CSimpleStringA::Format("set camera brightness to %d failed.", num.nValue).GetData());
- }
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("pad type cannot adj brightness");
- }
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("the camera not start!");
- }
- }
- }
- ErrorCodeEnum CMediaControllerEntity::RealSelfCheck()
- {
- ErrorCodeEnum Error = Error_Succeed;
- if (m_pHMClient)
- {
- HealthManagerService_RealCheck_Req req;
- req.name = GetEntityName();
- HealthManagerService_RealCheck_Ans ans;
- DWORD Timeout = 500;
- Error = m_pHMClient->RealCheck(req,ans,Timeout);
- if (Error!=Error_Succeed)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("RealSelfcheck fail!");
- }
- else
- {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_REAL_SELF_CHECK, "media controller entity auto restart.");
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::GetEnvCamRawBrightnessInfo(int* iMin, int* iMax)
- {
- ErrorCodeEnum Error = Error_Failed;
- #ifdef DEVOPS_ON_PRD
- #else
- if (m_bStartCamera) {
- if (0 == capture_get_env_rawbrightnessinfo(m_capture, m_nCameraErrorCode, iMin, iMax)) {
- Error = Error_Succeed;
- }
- }
- #endif
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::SetEnvCamRawBrightness(int iBrightness)
- {
- ErrorCodeEnum Error = Error_Failed;
- #ifdef DEVOPS_ON_PRD
- #else
- if (m_bStartCamera) {
- if (0 == capture_set_env_rawbrightness(m_capture, m_nCameraErrorCode, iBrightness)) {
- Error = Error_Succeed;
- }
- }
- #endif
- return Error;
- }
- void CMediaControllerEntity::SendCameraBright()
- {
- ChannelService_Send_Info Info;
- Info.compress = false;
- Info.encrypt = false;
- Info.type = ACM_TYPE_DEVICE;
- Info.id = 0;
- Info.sub_type = ACM_CAMERA_BRIGHT;
- Info.data.Alloc(sizeof(int));
- SpBuffer buf;
- buf.OpenWrite();
- int nValue = 0;
- nValue = capture_get_brightness(m_capture,m_nCameraErrorCode);
- if (nValue >= 0)
- {
- buf & nValue;
- Info.data = buf.ToBlob();
- m_pMediaControllerChannel->Send(Info);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("send cur camera bright value is %d.", nValue);
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("send cur camera bright value Fail!");
- }
- }
- ErrorCodeEnum CMediaControllerEntity::GetEnvCameraVideoCaptureInfo(CSimpleStringA& strnotice, CSimpleStringA& strcmd)
- {
- ErrorCodeEnum Error = Error_NotImpl;
- #ifdef DEVOPS_ON_PRD
- #else
- int ienvid = capture_get_video_device_id(conf.strVideoEnv.GetData());
- if (-1 != ienvid) {
- #ifdef RVC_OS_WIN
- #else
- char strCmd[256] = { 0 };
- snprintf(strCmd, 256, "v4l2-ctl -d%d --list-formats-ext", ienvid);
- strnotice = "在终端输入以下命令获取摄像头支持的图像格式信息,检查输出图像格式是否包含YUYV,图像分辨率是否包含640*360,该分辨率对应的帧率是否包含15fps.";
- strcmd = strCmd;
- #endif
- Error = Error_Succeed;
- }
- #endif
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::StartAllCameras()
- {
- ErrorCodeEnum Error = Error_Succeed;
- if (false == m_bStartCamera){
- Error = StartCamera();
- SetCameraStateInfo(Error);
- if (m_bStartCamera) {
- OnCameraStarted();
- }
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("camera already start.");
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::StopAllCameras()
- {
- if (m_capture){
- GetFunction()->KillTimer(1);
- capture_stop(m_capture);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode("QLR0402208V5")("关闭摄像头");
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- m_bStartCamera = false;
- OnCameraStopped();
- if (m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->KillTimer(RVC_CAMERA_OFF_TIMER)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "stop camera, kill camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = false;
- }
- }
- return Error_Succeed;
- }
- ErrorCodeEnum CMediaControllerEntity::StopCamerasAndRecord()
- {
- LogTransactionRecordCtrEvt(0);
- ErrorCodeEnum CamRet = StopAllCameras();
- return CamRet;
- }
- ErrorCodeEnum CMediaControllerEntity::StartCamerasAndRecord()
- {
- ErrorCodeEnum CamRet = StartAllCameras();
- LogTransactionRecordCtrEvt(1);
- return CamRet;
- }
-
- ErrorCodeEnum CMediaControllerEntity::CheckConfigCameraName(capture_config_t *conf, DeviceTypeEnum eType)
- {
- ErrorCodeEnum Error = Error_Succeed;
- int EnvConfigNameError = 0; //0:环境摄像头配置名能成功打开 -1:环境摄像头配置名不能打开 1:未配置环境摄像头名字
- int OptConfigNameError = 0; //0:操作摄像头配置名能成功打开 -1:操作摄像头配置名不能打开 1:未配置操作摄像头名字
- //check env device
- if (conf->strVideoEnv.GetLength() > 1){ // is not "$"
- conf->video_env_dev = capture_get_video_device_id(conf->strVideoEnv.GetData());
- if (conf->video_env_dev == -1) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("find strVideoEnv:%s(-1)",conf->strVideoEnv.GetData());
- EnvConfigNameError = -1;
- }
- }
- else {
- conf->video_env_dev = -1;
- EnvConfigNameError = 1;
- }
- //check opt device
- if (conf->strVideoOpt.GetLength() > 1) { // is not "$"
- conf->video_opt_dev = capture_get_video_device_id(conf->strVideoOpt.GetData());
- if (conf->video_opt_dev == -1) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("find strVideoOpt:%s(-1)",conf->strVideoOpt.GetData());
- OptConfigNameError = -1;
- }
- }
- else {
- conf->video_opt_dev = -1;
- OptConfigNameError = 1;
- }
- if (eStand2sType == eType) {
- //配置的环境摄像头能识别到
- if (0 == EnvConfigNameError) {
- //配置的操作摄像头识别不到or未配置操作摄像头,此时表明只有环境摄像头OK
- if (0 != OptConfigNameError) {
- Error = Error_OptCamera;
- }
- }
- //配置的环境摄像头识别不到or未配置环境摄像头
- else {
- //配置的操作摄像头识别不到or未配置操作摄像头,此时表明摄像头都不可用
- if (0 != OptConfigNameError) {
- Error = Error_AllCamera;
- }
- //操作摄像头配置名能打开,此时表明只有操作摄像头OK
- else {
- Error = Error_EnvCamera;
- }
- }
- }
- else if (eStand1SPlusType == eType) {
- if (0 != EnvConfigNameError) {
- Error = Error_AllCamera;
- }
- }
-
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::AutoGetVideoDeviceName(capture_config_t* conf)
- {
- ErrorCodeEnum Error = Error_Unexpect;
- bool benv = false;
- bool bopt = false;
- CSimpleStringA strLastCamera("");
- int icount = 0;
- #ifdef RVC_OS_WIN
- #else
- icount = rvc_videocap_get_device_count();
- int ifound = 0;
- for (int i = 0; i < 64 && ifound < icount; ++i) {
- char strfullname[2 * MAX_PATH] = { 0 };
- if (0 == rvc_videocap_get_device_fullpathname(i, strfullname, 2 * MAX_PATH)) {
- ifound++;
- if (NULL != strstr(strfullname, AUTOMATCH_CAMERA_ENV)) {
- conf->strVideoEnv = strfullname;
- benv = true;
- }
- if (NULL != strstr(strfullname, AUTOMATCH_CAMERA_OPT)) {
- conf->strVideoOpt = strfullname;
- bopt = true;
- }
- strLastCamera = strfullname;
- if (benv && bopt) {
- break;
- }
- }
- }
- #endif // RVC_OS_WIN
- if (eStand1SPlusType == m_eDeviceType && 1 == icount && strLastCamera.GetLength() > 0) {
- conf->strVideoEnv = strLastCamera;
- benv = true;
- }
- if (benv || bopt) {
- Error = Error_Succeed;
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::GetSalesAudioConfig(rvc_audio_capture_config_t* conf, bool bRemoteRecord)
- {
- CSmartPointer<IEntityFunction> spFunction = GetFunction();
- CSmartPointer<IConfigInfo> spConfig;
- SpIniMappingTable table;
- ErrorCodeEnum Error = spFunction->OpenConfig(Config_Root, spConfig);
- if (Error == Error_Succeed) {
- CSimpleStringA strAudioInDevice;
- table.AddEntryString("Audio", "sales_record_in_dev", strAudioInDevice, "$");
- Error = table.Load(spConfig);
- if (Error == Error_Succeed) {
- conf->audio_capture_period = CAPTURE_FRAME_TIME;
- conf->audio_capture_samplerate = CAPTURE_CLOCK;
- conf->strAudioIn = this->conf.strAudioIn;
- conf->strAudioOut = this->conf.strAudioOut;
- if (strAudioInDevice.GetLength() > 0) {
- conf->strAudioIn = strAudioInDevice;
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("load sales audio device config failed!");
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("open sales audio device config failed!");
- }
- if (Error_Succeed != Error) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get sales audio device info failed, now get from default value.");
- conf->strAudioIn = this->conf.strAudioIn;
- conf->audio_capture_period = CAPTURE_FRAME_TIME;
- conf->audio_capture_samplerate = CAPTURE_CLOCK;
- Error = Error_Succeed;
- }
- if (true == bRemoteRecord) {
- conf->audio_capture_samplerate = CAPTURE_CLOCK;
- }
- return Error;
- }
- static CSimpleStringA generateCameraInfosJson(CSimpleStringA strEnv, CSimpleStringA strOpt, int iEnv, int iOpt, int iMtu)
- {
- return CSimpleStringA::Format("{\"EnvCamera\":\"%s\",\"OptCamera\":\"%s\",\"EnvRotate\":\"%d\",\"OptRotate\":\"%d\",\"mtu\":\"%d\"}",
- strEnv.GetData(), strOpt.GetData(), iEnv, iOpt, iMtu);
- }
- ErrorCodeEnum CMediaControllerEntity::LoadConfig(capture_config_t *conf)
- {
- CSmartPointer<IEntityFunction> spFunction = GetFunction();
- CSmartPointer<IConfigInfo> spConfig;
- SpIniMappingTable table;
- ErrorCodeEnum Error = spFunction->OpenConfig(Config_Root, spConfig);
- if (Error == Error_Succeed) {
- int imtu = 1500;
- int ienvfps = REC_COMMON_VIDEO_RAW_FPS;
- int ioptfps = REC_COMMON_VIDEO_RAW_FPS;
- table.AddEntryString("Audio", "handfree_in_dev", conf->strAudioIn, "$");
- table.AddEntryString("Audio", "handfree_out_dev", conf->strAudioOut, "$");
- table.AddEntryString("Video", "EnvCamera", conf->strVideoEnv, "$");
- table.AddEntryString("Video", "OptCamera", conf->strVideoOpt, "$");
- table.AddEntryInt("Video", "EnvRotate", conf->video_env_rotate, 0);
- table.AddEntryInt("Video", "OptRotate", conf->video_opt_rotate, 270);
- table.AddEntryInt("Video", "EnvFps", ienvfps, REC_COMMON_VIDEO_RAW_FPS);
- table.AddEntryInt("Video", "OptFps", ioptfps, REC_COMMON_VIDEO_RAW_FPS);
- table.AddEntryInt("Video", "mtu", imtu, 1500);
- Error = table.Load(spConfig);
- if (Error == Error_Succeed)
- {
- if (0 != conf->video_env_rotate) {
- conf->video_env_rotate = 0;
- }
- if (270 != conf->video_opt_rotate) {
- conf->video_opt_rotate = 270;
- }
- conf->video_env_fps = REC_COMMON_VIDEO_RAW_FPS;
- if (ienvfps <= 30 && ienvfps >= 5) {
- conf->video_env_fps = ienvfps;
- }
- conf->video_opt_fps = REC_COMMON_VIDEO_RAW_FPS;
- if (ioptfps <= 30 && ioptfps >= 5) {
- conf->video_opt_fps = ioptfps;
- }
- LogWarn(Severity_Low, Error_Debug, ERROR_MOD_MEDIACONTROLLER_ENV_CAMERA_INFO, conf->strVideoEnv.GetData());
- LogWarn(Severity_Low, Error_Debug, ERROR_MOD_MEDIACONTROLLER_OPT_CAMERA_INFO, conf->strVideoOpt.GetData());
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_CAMERA_INFOS, generateCameraInfosJson(conf->strVideoEnv, conf->strVideoOpt, conf->video_env_rotate, conf->video_opt_rotate, imtu).GetData());
- #ifdef RVC_OS_WIN
- #else
- Error = AutoGetVideoDeviceName(conf);
- CSimpleStringA strInfo = CSimpleStringA::Format("env = %s,opt = %s", conf->strVideoEnv.GetData(), conf->strVideoOpt.GetData());
- if (Error_Succeed == Error){
- LogWarn(Severity_Low, Error_Debug, ERROR_MOD_MEDIACONTROLLER_VIDEO_AUTO_MATHED_SUCCESS, strInfo.GetData());
- }
- else {
- LogWarn(Severity_Middle, Error_Debug, ERROR_MOD_MEDIACONTROLLER_VIDEO_AUTO_MATHED_FAILED, strInfo.GetData());
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V2").setResultCode("RTA2807")("摄像头名称不符合硬件要求,请联系厂商处理");
- }
- #endif // RVC_OS_WIN
- Error = CheckConfigCameraName(conf, m_eDeviceType);
- if (Error == Error_EnvCamera){
- char strMessage[MAX_PATH*2] = {0};
- get_camera_exception_message(strMessage, MAX_PATH*2, conf->strVideoEnv ,"env camera config error,please check config file or device.");
- LogWarn(Severity_Middle,Error_DevMedia,ERROR_MOD_MEDIACONTROLLER_ENVCAM_INITFAIL,strMessage);
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V2").setResultCode("RTA2801")("上摄像头配置错误,请检查摄像头配置");
- } else if (Error == Error_OptCamera){
- char strMessage[MAX_PATH*2] = {0};
- get_camera_exception_message(strMessage, MAX_PATH*2, conf->strVideoOpt, "operation camera config error,please check config file or device.");
- LogWarn(Severity_Middle,Error_DevMedia,ERROR_MOD_MEDIACONTROLLER_OPTCAM_INITFAIL, strMessage);
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V2").setResultCode("RTA2802")("下摄像头配置错误,请检查摄像头配置");
- }
- else if (Error == Error_AllCamera) {
- LogWarn(Severity_Middle, Error_DevMedia, ERROR_MOD_MEDIACONTROLLER_CONFIG_ALLERROR, "all config cameras error");
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V2").setResultCode("RTA280B")("上下摄像头配置都错误,请检查摄像头配置");
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode("QLR0402208V2")("摄像头配置正确");
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("load config failed!");
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("open config failed!");
- }
- return Error;
- }
- void CMediaControllerEntity::OnExternalCameraSwitchFailed(const char* pszFailedMsg)
- {
- CSmartPointer<IEntityFunction> Func = GetFunction();
- CSimpleStringA strValue;
- Func->GetSysVar("DesktopType", strValue);
- if (strValue == CSimpleStringA("U")) {
- #ifdef RVC_OS_WIN
- MessageBoxA(NULL, pszFailedMsg, NULL, MB_SYSTEMMODAL);
- #else
- #endif // RVC_OS_WIN
- }
- }
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- void CMediaControllerEntity::OnBrocastEnvCameraCapInfo(int icaptime, int irealframes, float frealfps, float fstable)
- {
-
- EnvCameraCapInfo ret;
- CSimpleStringA strMsg = CSimpleStringA::Format("摄像头已打开%d秒, 输出图像%d帧, 实际帧率为%.2ffps, 稳定性偏差为%.4f.", icaptime, irealframes, frealfps, fstable);
- ret.cameracapmsg = CSimpleStringA2W(strMsg);
- SpSendBroadcast(GetFunction(), eMsg_EnvCameraCapInfo, eMsgSig_EnvCameraCapInfo, ret);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("spsendbroadcast envcamera cap info is %s", strMsg.GetData());
- }
- ErrorCodeEnum CMediaControllerEntity::GetEnvCamCaptureProcess()
- {
- ErrorCodeEnum Error = Error_Failed;
- if (m_bStartCamera) {
- if (m_capture && m_capture->env_video) {
- unsigned int istarttime = m_capture->env_video->ustarttime;
- int irealframes = m_capture->env_video->frame_id;
- unsigned int icaptime = y2k_time_now() - istarttime;
- float fenvframerate = (float)((float)irealframes / (float)icaptime);
- int icalcfps = icaptime * 15;
- float fenvstable = (float)(irealframes - icalcfps) / (float)icalcfps;
- OnBrocastEnvCameraCapInfo(icaptime, irealframes, fenvframerate, fenvstable);
- Error = Error_Succeed;
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("env capture param is invalid.");
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::StartSaveEnvCamPhoto(const char* pname, const int interval)
- {
- ErrorCodeEnum Error = Error_Failed;
- if (m_bStartCamera) {
- if (m_capture && m_capture->env_video) {
- m_capture->env_video->bsavephoto = true;
- snprintf(m_capture->env_video->strsavedir, MAX_PATH, "%s", m_PhotoSaveDir.GetData());
- snprintf(m_capture->env_video->strphotoname, MAX_PATH, "%s", pname);
- m_capture->env_video->isaveinterval = interval;
- Error = Error_Succeed;
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("env capture param is invalid.");
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::StopSaveEnvCamPhoto()
- {
- ErrorCodeEnum Error = Error_Failed;
- if (m_bStartCamera) {
- if (m_capture && m_capture->env_video) {
- m_capture->env_video->bsavephoto = false;
- memset(m_capture->env_video->strphotoname, 0, MAX_PATH);
- Error = Error_Succeed;
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("env camera capture param is invalid.");
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("env camera already stop.");
- Error = Error_Succeed;
- }
- return Error;
- }
- #endif
- #endif
- void CMediaControllerEntity::OnLog( const CAutoArray<CUUID> &SubIDs, const CUUID nLogID,const LogTypeEnum eLogType, const SeverityLevelEnum eLevel,
- const DWORD dwSysError,const DWORD dwUserCode,const DWORD dwEntityInstanceID, const WORD wEntityDevelID,
- const CAutoArray<DWORD> &Param, const char *pszEntityName, const char *pszModuleName,const char *pszMessage, const linkContext& pLinkInfo)
- {
- switch (dwUserCode)
- {
- case MOD_EVENT_SNAPSHOT_START_CAPTURE_ENVOPT:
- {
- #ifdef RVC_OS_WIN
- InterlockedCompareExchange(&m_lCaptureEnvOptCount, 3, 0);
- #else
- pthread_mutex_lock(&m_envopt_mutex);
- LONG* plTemp = &m_lCaptureEnvOptCount;
- if (0 == *plTemp) {
- *plTemp = 3;
- }
- pthread_mutex_unlock(&m_envopt_mutex);
- #endif // RVC_OS_WIN
- }
- break;
- case MOD_EVENT_SNAPSHOT_START_CAPTURE_ENV:
- {
- #ifdef RVC_OS_WIN
- InterlockedCompareExchange(&m_lCaptureEnvCount, 1, 0);
- #else
- pthread_mutex_lock(&m_env_mutex);
- LONG* plTemp = &m_lCaptureEnvCount;
- if (0 == *plTemp) {
- *plTemp = 1;
- }
- pthread_mutex_unlock(&m_env_mutex);
- #endif // RVC_OS_WIN
- }
- break;
- case MOD_EVENT_SNAPSHOT_START_CAPTURE_OPT:
- {
- #ifdef RVC_OS_WIN
- InterlockedCompareExchange(&m_lCaptureOptCount, 1, 0);
- #else
- pthread_mutex_lock(&m_opt_mutex);
- LONG* plTemp = &m_lCaptureOptCount;
- if (0 == *plTemp) {
- *plTemp = 1;
- }
- pthread_mutex_unlock(&m_opt_mutex);
- #endif // RVC_OS_WIN
- }
- break;
- case LOG_EVT_MOD_ASSISCHAN_STARTED_SUCCESS:
- {
- Sleep(800);
- if (m_pMediaControllerChannel != NULL){
- m_pMediaControllerChannel->GetFunction()->CloseSession();
- #ifdef RVC_OS_WIN
- m_pMediaControllerChannel->SafeDelete();
- #endif
- m_pMediaControllerChannel = NULL;
- m_bConnectedAssist = false;
- }
- if (Error_Succeed == ConnectAssistChannel()){
- m_bConnectedAssist = true;
- }
- else {
- GetFunction()->SetTimer(2, this, 3350);
- }
- }
- break;
- case LOG_EVT_BEGIN_HANDLE_BUSINESS:
- if (!m_bJsOccupyCamera) {
- if (!m_bStartCamera) {
- StartCameraAndSetSysVar();
- if (m_bStartCamera) {
- OnCameraStarted();
- }
- }
- else {
- if (m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->KillTimer(RVC_CAMERA_OFF_TIMER)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "begin handle business, and camera is already on, kill camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = false;
- }
- }
- }
- }
- m_bOnBusiness = true;
- break;
- case LOG_EVT_END_HANDLE_BUSINESS:
- if (m_bStartCamera) {
- if (false == m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->SetTimer(RVC_CAMERA_OFF_TIMER, this, m_iDelayTime * 1000)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_SETTIMER_ERROR, "end handle business, set camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = true;
- }
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("end handle business, and camera is not on.");
- }
- m_bOnBusiness = false;
- break;
- case LOG_EVT_RECORDFAILED:
- {
- GetFunction()->KillTimer(1);
- char FaildFlag = pszMessage[0];
- if (FaildFlag == '0')
- {
- GetFunction()->SetTimer(1, this, 5000);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("本地录音录像失败,已停止!");
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("本地录音录像设备故障,尝试恢复中(预计10s内),请稍等");
- if (false == m_bIsRemoteRecord) {
- m_nCameraErrorCode = Error_AllCamera;
- }
- }
- }
- break;
- case LOG_EVT_UI_RECORDFAILED:
- {
- OnExternalCameraSwitchFailed(pszMessage);
- GetFunction()->KillTimer(1);
- if (m_bIsRemoteRecord){
- LogEvent(Severity_Middle, LOG_EVT_UI_STOPREMOTERECORD, NULL);
- }
-
- GetFunction()->SetTimer(1, this, 5000);
- }
- break;
- case LOG_EVT_MOD_SALESRECORDER_STARTED_SUCCESS:
- m_bIsRemoteRecord = false;
- break;
- case LOG_EVT_UI_STARTREMOTERECORD:
- {
- m_bIsRemoteRecord = true;
- HandleRemoteRecord(pszMessage);
- }
- break;
- case LOG_EVT_UI_STOPREMOTERECORD:
- {
- m_bIsRemoteRecord = false;
- if (Error_Succeed == StopSalesRecordAudioCapture()){
- }
- if (true == m_bHasStartSpeakerRender){
- StopSpeakerAudioRender();
- }
- }
- break;
- case EVENT_MOD_CONNECT_BEGAIN_RECORD_CALL:
- {
- if (true == m_bHasStartSpeakerRender) {
- StopSpeakerAudioRender();
- }
- }
- break;
- case LOG_EVT_MOD_FACETRACKING_STARTED_SUCCESS:
- {
- if (false == m_bStartCamera) {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_RESET_ACTIVECAMERA, "reset active camera.");
- }
- }
- break;
- case LOG_EVT_UI_STARTCAMERACAPTURE:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv LOG_EVT_UI_STARTCAMERACAPTURE event");
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- HandleStartCameraCapture(pszMessage);
- #endif
- #endif
- }
- break;
- case LOG_EVT_UI_STOPCAMERACAPTURE:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv LOG_EVT_UI_STOPCAMERACAPTURE event");
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- HandleStopCameraCapture();
- #endif
- #endif
- }
- break;
- default:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("unknown event.");
- break;
- }
- }
- void CMediaControllerEntity::OnSelfTest(EntityTestEnum eTestType,CSmartPointer<ITransactionContext> pTransactionContext)
- {
- if (Test_ShakeHand == eTestType)
- {
- if (m_nCameraErrorCode == Error_AllCamera)
- {
- pTransactionContext->SendAnswer(Error_DevMedia);
- }
- else
- {
- pTransactionContext->SendAnswer(Error_Succeed);
- }
- }
- }
- //获取当前使用摄像头,30分钟轮休一次
- int CMediaControllerEntity::GetActiveCamera()
- {
- #ifdef RVC_OS_WIN
- SYSTEMTIME st;
- GetLocalTime(&st);
- if (st.wMinute <= CAMERA_CHANGE_TIMER)
- {
- return ENVCAMERA;
- }
- else
- {
- return OPTCAMERA;
- }
- #else
- return ENVCAMERA;
- #endif // RVC_OS_WIN
- }
- ErrorCodeEnum CMediaControllerEntity::ChangeSysvar(ErrorCodeEnum op)
- {
- switch (op)
- {
- case Error_Succeed:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to No_Error");
- SetCameraSysVar(CAMERA_NO_ERROR);
- break;
- case Error_EnvCamera:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Env_Error");
- SetCameraSysVar(CAMERA_ENV_ERROR);
- capture_clearsnapshotvideo(m_capture,ENVCAMERA);
- break;
- case Error_OptCamera:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Opt_Error");
- SetCameraSysVar(CAMERA_OPT_ERROR);
- capture_clearsnapshotvideo(m_capture,OPTCAMERA);
- break;
- case Error_AllCamera:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Both_Error");
- SetCameraSysVar(CAMERA_BOTH_ERROR);
- capture_clearsnapshotvideo(m_capture,AlLCAMERA);
- break;
- default:
- break;
- }
- return Error_Succeed;
- }
- //开始销售双录音频采集函数
- ErrorCodeEnum CMediaControllerEntity::StartSalesRecordAudioCapture(bool bRemoteRecord)
- {
- ErrorCodeEnum Error = Error_Succeed;
- if (NULL == m_salesaudio_capture){
- memset(&m_sales_audio_conf, 0, sizeof(m_sales_audio_conf));
- GetSalesAudioConfig(&m_sales_audio_conf, bRemoteRecord);
- Error = (ErrorCodeEnum)salesaudio_capture_create(&m_sales_audio_conf, &m_salesaudio_capture);
- }
- if (Error_Succeed == Error){
- Error = salesrecord_audio_capture_start(m_salesaudio_capture);
- if (Error_Succeed != Error){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("sales record audio capture start failed for param error.");
- }
- }
- return Error;
- }
- //停止销售双录音频采集函数
- ErrorCodeEnum CMediaControllerEntity::StopSalesRecordAudioCapture()
- {
- salesrecord_audio_capture_stop(m_salesaudio_capture);
- salesaudio_capture_destroy(m_salesaudio_capture);
- m_salesaudio_capture = NULL;
- return Error_Succeed;
- }
- ErrorCodeEnum CMediaControllerEntity::StartCamera()
- {
- if (m_capture == NULL)
- {
- ErrorCodeEnum Error = Error_Succeed;
- conf.ref_env_capture_count = &m_lCaptureEnvCount;
- conf.ref_opt_capture_count = &m_lCaptureOptCount;
- conf.ref_envopt_capture_count = &m_lCaptureEnvOptCount;
- #ifdef RVC_OS_WIN
- #else
- conf.env_mutex = &m_env_mutex;
- conf.opt_mutex = &m_opt_mutex;
- conf.envopt_mutex = &m_envopt_mutex;
- #endif
- conf.uintervaltime = m_interValTime;
- Error = (ErrorCodeEnum)capture_create(&conf, &m_capture);
- if (Error == Error_Succeed)
- {
- #ifdef RVC_OS_WIN
- #else
- m_capture->handfree_audio->paudiocap = m_pAudioCap;
- #endif
- CSmartPointer<IEntityFunction> Func = GetFunction();
- CSimpleStringA strValue("");
- Func->GetSysVar(SYSVAR_SOUNDCARDSTATE, strValue);
- m_capture->config.strAudioState = strValue;
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Sound Card State is %s.", strValue.GetData());
- Error = capture_start(m_capture);
- if (Error != Error_Succeed)
- {
- if((Error == Error_AudioIN)||(Error == Error_AudioOut))
- {
- return Error;
- }
- else if (Error == Error_AllCamera)
- {
- capture_stop(m_capture);
- capture_destroy(m_capture);
- m_capture = NULL;
- return Error;
- }
- else
- {
- SetAutoBright(Error);
- GetFunction()->SetTimer(1, this, 5000);
- if((Error == Error_OptCamera)&&(eStand1SPlusType == m_eDeviceType))
- {
- return Error_Succeed;
- }
- else
- {
- return Error;
- }
- }
- }
- else
- {
- SetAutoBright(Error);
- GetFunction()->SetTimer(1, this, 5000);
- return Error_Succeed;
- }
- }
- else if(Error_Unexpect == Error)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("create capture failed! 0x%08x", Error);
- m_capture = NULL;
- return Error_Unexpect;
- }
- return Error;
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("m_capture == NULL");
- return Error_Unexpect;
- }
- }
- void CMediaControllerEntity::SetCameraStateInfo(ErrorCodeEnum errorcode)
- {
- if (Error_Succeed == errorcode) {
- SetCameraSysVar(CAMERA_NO_ERROR);
- m_bStartCamera = true;
- m_nCameraErrorCode = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_USER).setLogCode("QLR0402208V3")("摄像头打开成功");
- }
- else {
- if (Error_EnvCamera == errorcode) {
- SetCameraSysVar(CAMERA_ENV_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_ENV_ERROR");
- m_bStartCamera = true;
- m_nCameraErrorCode = Error_EnvCamera;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V3").setResultCode("RTA2803")("上摄像头故障,打开失败");
- }
- else if (Error_OptCamera == errorcode) {
- SetCameraSysVar(CAMERA_OPT_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_OPT_ERROR");
- m_bStartCamera = true;
- m_nCameraErrorCode = Error_OptCamera;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V3").setResultCode("RTA2804")("下摄像头故障,打开失败");
- }
- else if (Error_AllCamera == errorcode) {
- SetCameraSysVar(CAMERA_BOTH_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_BOTH_ERROR");
- m_nCameraErrorCode = Error_AllCamera;
- m_bStartCamera = false;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V3").setResultCode("RTA2808")("上下摄像头都故障");
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Other Error");
- m_nCameraErrorCode = errorcode;
- m_bStartCamera = false;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V3").setResultCode("RTA2809")("打开摄像头时出现其它异常");
- }
- }
- }
- void CMediaControllerEntity::StartCameraAndSetSysVar()
- {
- CheckAutoVideoConfig(&conf);
- ErrorCodeEnum Error = StartCamera();
- SetCameraStateInfo(Error);
- }
- ErrorCodeEnum CMediaControllerEntity::ReStartCamera(int nCamera)
- {
- if (m_capture != NULL)
- {
- if((stopcamera(m_capture,nCamera)==-1)){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ReStartCamera %d,stop camera fail!", nCamera);
- }
- #ifdef RVC_OS_WIN
- Sleep(2000);
- #else
- sleep(2);
- #endif
- ErrorCodeEnum Error = Error_Succeed;
- Error = capture_create(&conf, m_capture, nCamera);
- if (Error == Error_Succeed)
- {
- Error = capture_start(m_capture,nCamera);
- if (Error != Error_Succeed)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ReStartCamera %d,capture_start fail!", nCamera);
- capture_destroy(m_capture,nCamera);
- return Error;
- }
- else
- {
- return Error_Succeed;
- }
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ReStartCamera %d,capture_create fail!", nCamera);
- capture_destroy(m_capture,nCamera);
- return Error;
- }
- }
- else
- {
- return Error_Unexpect;
- }
- }
-
- CServerSessionBase *CMediaControllerEntity::OnNewSession(const char* pszRemoteEntityName, const char * pszClass)
- {
- return new MediaServiceSession(this);
- }
- ErrorCodeEnum CMediaControllerEntity::HandleSalesRecordPCMAudio(bool bRemoteRecord, const char *pszMessage, audio_frame* pFrame)
- {
- ErrorCodeEnum Error = Error_Succeed;
- char strSwiftName[MAX_PATH] = {0};
- if (NULL != pszMessage){
- size_t ulen = strlen(pszMessage);
- char *tmp = new char[ulen+1];
- memset(tmp, 0, ulen + 1);
- memcpy(tmp, pszMessage, ulen);
- char *result[16] = {0};
- auto arr1 = CSimpleStringA2W(tmp).Split('@');
- auto arr2 = CAutoArray<CSimpleStringA>(arr1.GetCount());
- for (int i = 0; i < arr1.GetCount(); ++i){
- arr2[i] = CSimpleStringW2A(arr1[i]);
- result[i] = const_cast<char*>(arr2[i].GetData());
- }
- if (arr1.GetCount() > 4){
- snprintf(strSwiftName, MAX_PATH, "%s", result[4]);
- }
- delete tmp;
- tmp = NULL;
- }
- CSimpleStringA strTempDir;
- if (Error_Succeed == GetFunction()->GetPath("Temp", strTempDir)){
- }
-
- if (Error_Succeed == StartSalesRecordAudioCapture(bRemoteRecord)){
- }
- #ifdef RVC_OS_WIN
- if (true == bRemoteRecord){
- char strSpeakerName[MAX_PATH] = {0};
- if ("" != strTempDir){
- snprintf(strSpeakerName, MAX_PATH, "%s/remote_speaker_%s.pcm", strTempDir.GetData(), strSwiftName);
- }
- else{
- snprintf(strSpeakerName, MAX_PATH, "remote_speaker_%s.pcm", strSwiftName);
- }
- StartSpeakerAudioRender(0, pFrame, strSpeakerName);
- }
- #endif
-
- return Error;
- }
- void CMediaControllerEntity::HandleRemoteRecord(const char *pszMessage)
- {
- audio_frame frame;
- frame.bitspersample = 16;
- frame.format = 1;
- frame.framesize = 320;
- frame.nchannels = 1;
- frame.samplespersec = 8000;
- if (Error_Succeed == StartSalesRecordAudioCapture(true)){
- }
- StartSpeakerAudioRender(0, &frame, NULL);
- }
- ErrorCodeEnum CMediaControllerEntity::StartSpeakerAudioRender(int iQueue, audio_frame* pFrame, const char* strName)
- {
- auto rc = Error_Succeed;
- #ifdef RVC_OS_WIN
- if (m_bSpeakerCap){
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("start speak audio render.");
- if (NULL != m_pAudioRenderObj){
- if(0 == m_pAudioRenderObj->StartRender(0, pFrame, strName)){
- m_bHasStartSpeakerRender = true;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("start speak audio render success.");
- }
- }
- }
- #endif // RVC_OS_WIN
- return rc;
- }
- ErrorCodeEnum CMediaControllerEntity::StopSpeakerAudioRender()
- {
- auto rc = Error_Succeed;
- #ifdef RVC_OS_WIN
- if (m_bSpeakerCap){
- if (NULL != m_pAudioRenderObj){
- m_pAudioRenderObj->StopRender();
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Stop Speaker Audio Render.");
- m_bHasStartSpeakerRender = false;
- }
- }
- #endif // RVC_OS_WIN
- return rc;
- }
- ErrorCodeEnum CMediaControllerEntity::ConnectAssistChannel()
- {
- if (NULL == m_pMediaControllerChannel) {
- m_pMediaControllerChannel = new ChannelMediaControllerClient(this);
- }
- ErrorCodeEnum Error = m_pMediaControllerChannel->Connect();
- if (Error != Error_Succeed) {
- #ifdef RVC_OS_WIN
- m_pMediaControllerChannel->SafeDelete();
- #endif
- m_pMediaControllerChannel = NULL;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ChannelMediaControllerClient connect fail!");
- return Error;
- }
- if (Error_Succeed == Error)
- {
- ChannelService_BeginState_Sub Sub;
- Error = (*m_pMediaControllerChannel)(EntityResource::getLink().upgradeLink())->BeginState(Sub);
- if (Error != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("BeginState biz channel failed!");
- m_pMediaControllerChannel->GetFunction()->CloseSession();
- #ifdef RVC_OS_WIN
- m_pMediaControllerChannel->SafeDelete();
- #endif
- m_pMediaControllerChannel = NULL;
- return Error;
- }
- }
- if (Error_Succeed == Error)
- {
- ChannelService_BeginRecv_Sub Sub;
- Sub.type = ACM_TYPE_DEVICE;
- Error = (*m_pMediaControllerChannel)(EntityResource::getLink().upgradeLink())->BeginRecv(Sub);
- if (Error != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Begin BeginRecv ACM_TYPE_DEVICE failed!");
- m_pMediaControllerChannel->GetFunction()->CloseSession();
- #ifdef RVC_OS_WIN
- m_pMediaControllerChannel->SafeDelete();
- #endif
- m_pMediaControllerChannel = NULL;
- return Error;
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::GetAudioDevices(int& iAudioCount, CSimpleStringA& strAudioDev, int iAudioType)
- {
- ErrorCodeEnum Error = Error_Param;
- #ifdef RVC_OS_WIN
- if (0 == iAudioType) {
- iAudioCount = capture_get_audio_device_list(0, strAudioDev);
- }
- else {
- iAudioCount = capture_get_audio_device_list(1, strAudioDev);
- }
- #else
- if (NULL != m_pAudioCap) {
- strAudioDev = "[";
- if (1 == iAudioType) {
- int icountmic = m_pAudioCap->audio_get_device_count(true);
- for (int i = 0; i < icountmic; i++) {
- char strname[MAX_PATH] = { 0 };
- m_pAudioCap->audio_get_device_name(strname, MAX_PATH, true, i);
- CSimpleStringA str = CSimpleStringA::Format("\"%s\"", strname);
- if (i > 0) {
- strAudioDev += ",";
- }
- strAudioDev += str;
- }
- iAudioCount = icountmic;
- }
- else {
- int icountspeaker = m_pAudioCap->audio_get_device_count(false);
- for (int i = 0; i < icountspeaker; i++) {
- char strname[MAX_PATH] = { 0 };
- m_pAudioCap->audio_get_device_name(strname, MAX_PATH, false, i);
- CSimpleStringA str = CSimpleStringA::Format("\"%s\"", strname);
- if (i > 0) {
- strAudioDev += ",";
- }
- strAudioDev += str;
- }
- iAudioCount = icountspeaker;
- }
-
- strAudioDev += "]";
- Error = Error_Succeed;
- }
- #endif
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::GetVideoDevices(int& iVideoCount, CSimpleStringA& strVideoDev)
- {
- ErrorCodeEnum Error = Error_Succeed;
- iVideoCount = capture_get_video_device_list(strVideoDev);
- return Error;
- }
- void CMediaControllerEntity::CheckAutoVideoConfig(capture_config_t* conf)
- {
- if (conf) {
- if (0 == conf->strVideoEnv.GetLength() || 0 == conf->strVideoOpt.GetLength()) {
- AutoGetVideoDeviceName(conf);
- }
- }
- }
- void CMediaControllerEntity::OnCameraStarted()
- {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_CAMERA_STARTED, "camera started.");
- }
- void CMediaControllerEntity::OnCameraStopped()
- {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_CAMERA_STOPPED, "camera stopped.");
- }
- void CMediaControllerEntity::LogTransactionRecordCtrEvt(int iEvtType)
- {
- if (0 == iEvtType) {
- LogEvent(Severity_Middle, EVENT_MOD_PAUSE_RECORD, "pause record.");
- }
- else {
- LogEvent(Severity_Middle, EVENT_MOD_CONTINUE_RECORD, "continue record.");
- }
- }
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- void CMediaControllerEntity::HandleStartCameraCapture(const char* pszMessage)
- {
- int local_view_x = 0;
- int local_view_y = 0;
- int local_view_cx = 0;
- int local_view_cy = 0;
- char strphotoname[256] = { 0 };
- int isecond = 0;
- sscanf(pszMessage, "%d@%d@%d@%d@%d@%s", &local_view_x, &local_view_y, &local_view_cx, &local_view_cy, &isecond, strphotoname);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("photo name is %s, picture interval time is %d.", strphotoname, isecond);
- if (isecond <= 5) {
- isecond = 5;
- }
- if (!ExistsDirA(m_PhotoSaveDir.GetData())) {
- CreateDirA(m_PhotoSaveDir.GetData(), true);
- }
- if (Error_Succeed == StartSaveEnvCamPhoto(strphotoname, isecond)) {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Start Save EnvCam Photo success.");
- }
- else {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Start Save EnvCam Photo failed.");
- }
- }
- void CMediaControllerEntity::HandleStopCameraCapture()
- {
- if (Error_Succeed == StopSaveEnvCamPhoto()) {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Stop Save EnvCam Photo success.");
- }
- else {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Stop Save EnvCam Photo failed.");
- }
- }
- #endif
- #endif
- ChannelMediaControllerClient::ChannelMediaControllerClient( CMediaControllerEntity *pEntity ) : ChannelService_ClientBase(pEntity)
- {
- }
- void ChannelMediaControllerClient::OnMessage(ErrorCodeEnum Error, ChannelService_State_Info &Msg, CSmartPointer<IReleasable> pData)
- {
- if (Error == Error_Succeed)
- {
- CMediaControllerEntity *pEntity = static_cast<CMediaControllerEntity*>(m_pEntityBase);
- if (Msg.state == eChannelState_Idle)
- {
- if (pEntity->m_bStartCamera)
- {
- if (pEntity->SetAutoBright(pEntity->m_nCameraErrorCode)==false)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("SetAutoBright Fail!");
- }
- }
- }
- else if (Msg.state == eChannelState_Connected)
- {
- if (pEntity->m_bStartCamera)
- {
- pEntity->SendCameraBright();
- }
- }
- }
- }
- void ChannelMediaControllerClient::OnMessage( ErrorCodeEnum Error, ChannelService_Packet_Info &Msg, CSmartPointer<IReleasable> pData )
- {
- if (Error == Error_Succeed)
- {
- CMediaControllerEntity *pEntity = static_cast<CMediaControllerEntity*>(m_pEntityBase);
- pEntity->OnReceivePkt(Msg.sub_type, (const char*)Msg.data.m_pData, Msg.data.m_iLength);
- }
- }
-
- void MediaServiceSession::Handle_GetAudioDevices(SpReqAnsContext<MediaService_GetAudioDevices_Req, MediaService_GetAudioDevices_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_NotImpl;
- Error = m_pEntity->GetAudioDevices(ctx->Ans.deviceCount, ctx->Ans.strNames, ctx->Req.audioType);
- ctx->Ans.retCode = (int)Error;
- ctx->Answer(Error_Succeed);
- }
- void MediaServiceSession::Handle_GetVideoDevices(SpReqAnsContext<MediaService_GetVideoDevices_Req, MediaService_GetVideoDevices_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_NotImpl;
- Error = m_pEntity->GetVideoDevices(ctx->Ans.deviceCount, ctx->Ans.strNames);
- ctx->Ans.retCode = (int)Error;
- ctx->Answer(Error_Succeed);
- }
- void MediaServiceSession::Handle_GetCameraInfos(SpReqAnsContext<MediaService_GetCameraInfos_Req, MediaService_GetCameraInfos_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_Succeed;
- char strEnvCamera[MAX_PATH] = { 0 };
- char strEnvUsbPort[MAX_PATH] = { 0 };
- char strOptCamera[MAX_PATH] = { 0 };
- char strOptUsbPort[MAX_PATH] = { 0 };
- char cWord = ';';
- #ifdef RVC_OS_LINUX
- cWord = ':';
- #endif // RVC_OS_LINUX
- if (0 == GetFormatString(strEnvCamera, MAX_PATH, strEnvUsbPort, MAX_PATH, m_pEntity->conf.strVideoEnv.GetData(), m_pEntity->conf.strVideoEnv.GetLength(), cWord)){
- ctx->Ans.EnvCamera = strEnvCamera;
- ctx->Ans.EnvUsbPort = strEnvUsbPort;
- ctx->Ans.EnvReserved = "";
- }
- else {
- ctx->Ans.EnvCamera = "";
- ctx->Ans.EnvUsbPort = "";
- ctx->Ans.EnvReserved = "";
- }
- if (0 == GetFormatString(strOptCamera, MAX_PATH, strOptUsbPort, MAX_PATH, m_pEntity->conf.strVideoOpt.GetData(), m_pEntity->conf.strVideoOpt.GetLength(), cWord)) {
- ctx->Ans.OptCamera = strOptCamera;
- ctx->Ans.OptUsbPort = strOptUsbPort;
- ctx->Ans.OptReserved = "";
- }
- else {
- ctx->Ans.OptCamera = "";
- ctx->Ans.OptUsbPort = "";
- ctx->Ans.OptReserved = "";
- }
- ctx->Ans.retCode = (int)Error;
- ctx->Answer(Error_Succeed);
- }
- void MediaServiceSession::Handle_ManipulateCameras(SpReqAnsContext<MediaService_ManipulateCameras_Req, MediaService_ManipulateCameras_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_NotImpl;
- DeviceTypeEnum eType = m_pEntity->RvcDeviceType();
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("rvc Device Type is %s, and cmdType is %d.", Device_Type_Table[eType], ctx->Req.cmdType);
-
- if (ctx->Req.cmdType == 0) {
- LogTransToCMSEvt();
- if (m_pEntity->m_bStartCamera) {
- Error = m_pEntity->StopCamerasAndRecord();
- #ifdef RVC_OS_WIN
- Sleep(200);
- #else
- usleep(200*1000);
- #endif
- }
- else {
- m_pEntity->LogTransactionRecordCtrEvt(0);
- Error = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("current is not on business, camera is not on.");
- }
- m_pEntity->m_bJsOccupyCamera = true;
- }
- else {
- #ifdef RVC_OS_WIN
- Sleep(100);
- #else
- usleep(100*1000);
- #endif
- if (m_pEntity->m_bOnBusiness) {
- Error = m_pEntity->StartCamerasAndRecord();
- }
- else {
- Error = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("current is not on business, not start camera.");
- }
- m_pEntity->m_bJsOccupyCamera = false;
- }
- ctx->Ans.retCode = (int)Error;
- ctx->Answer(Error_Succeed);
- }
- void MediaServiceSession::Handle_IsCameraOnStatus(SpReqAnsContext<MediaService_IsCameraOnStatus_Req, MediaService_IsCameraOnStatus_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ctx->Ans.biscameraon = m_pEntity->m_bStartCamera;
- ctx->Answer(Error_Succeed);
- }
- void MediaServiceSession::Handle_GetEnvCameraVideoCaptureInfo(SpReqAnsContext<MediaService_GetEnvCameraVideoCaptureInfo_Req, MediaService_GetEnvCameraVideoCaptureInfo_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_Succeed;
- #ifdef DEVOPS_ON_PRD
- #else
- Error = m_pEntity->GetEnvCameraVideoCaptureInfo(ctx->Ans.strnotice, ctx->Ans.strcmd);
- if (Error_Succeed != Error) {
- Error = Error_Failed;
- }
- #endif
- ctx->Answer(Error);
- }
- void MediaServiceSession::Handle_GetEnvCamRawBrightnessInfo(SpReqAnsContext<MediaService_GetEnvCamRawBrightnessInfo_Req, MediaService_GetEnvCamRawBrightnessInfo_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_Succeed;
- int iMin = 0;
- int iMax = 0;
- #ifdef DEVOPS_ON_PRD
- #else
- if (Error_Succeed == m_pEntity->GetEnvCamRawBrightnessInfo(&iMin, &iMax)) {
- ctx->Ans.iMinBrightness = iMin;
- ctx->Ans.iMaxBrightness = iMax;
- }
- else {
- ctx->Ans.iMinBrightness = 0;
- ctx->Ans.iMaxBrightness = 0;
- Error = Error_Failed;
- }
- #endif
- ctx->Answer(Error);
- }
- void MediaServiceSession::Handle_SetEnvCamRawBrightness(SpReqAnsContext<MediaService_SetEnvCamRawBrightness_Req, MediaService_SetEnvCamRawBrightness_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = Error_Succeed;
- #ifdef DEVOPS_ON_PRD
- #else
- if (Error_Succeed != m_pEntity->SetEnvCamRawBrightness(ctx->Req.iBrightness)) {
- Error = Error_Failed;
- }
- #endif
- ctx->Answer(Error);
- }
- void MediaServiceSession::Handle_TurnOnCamera(SpReqAnsContext<MediaService_TurnOnCamera_Req, MediaService_TurnOnCamera_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- ErrorCodeEnum Error = m_pEntity->StartAllCameras();
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- m_pEntity->GetFunction()->SetTimer(RVC_CAMERA_CAP_PROCESS, m_pEntity, 5 * 1000);
- #endif
- #endif
- ctx->Answer(Error);
- }
- void MediaServiceSession::Handle_TurnOffCamera(SpReqAnsContext<MediaService_TurnOffCamera_Req, MediaService_TurnOffCamera_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- m_pEntity->GetFunction()->KillTimer(RVC_CAMERA_CAP_PROCESS);
- #endif
- #endif
- ErrorCodeEnum CamRet = m_pEntity->StopAllCameras();
- ctx->Answer(CamRet);
- }
- SP_BEGIN_ENTITY_MAP()
- SP_ENTITY(CMediaControllerEntity)
- SP_END_ENTITY_MAP()
|