123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703 |
- #include "stdafx.h"
- #include "y2k_time.h"
- #include "capture.h"
- #include "Event.h"
- #include "CommEntityUtil.hpp"
- #include "SpUtility.h"
- #include "fileutil.h"
- #include "brightnessinfo.h"
- #include "SpDefine.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_MEDIADEV_STATUS_CHECK_TIMER
- #define RVC_MEDIADEV_STATUS_CHECK_TIMER 1
- #endif // !RVC_MEDIADEV_STATUS_CHECK_TIMER
- #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
- #ifndef RVC_MIN_CAMERA_BRIGHNESS
- #define RVC_MIN_CAMERA_BRIGHNESS 30
- #endif // !RVC_MIN_CAMERA_BRIGHNESS
- #ifndef RVC_DEFAULT_CAMERA_BRIGHNESS
- #define RVC_DEFAULT_CAMERA_BRIGHNESS 50
- #endif // !RVC_DEFAULT_CAMERA_BRIGHNESS
- #ifndef RVC_DEFAULT_KERNEL_VERSION
- #define RVC_DEFAULT_KERNEL_VERSION "4.19.0-arm64-desktop"
- #endif
- #ifdef RVC_OS_WIN
- static void __audio_render_log(audiorender_loglevel elevel, 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_E)elevel, LOG_TYPE_SYSTEM)("%s", buf);
- free(buf);
- }
- else{
- char strlog[MAX_PATH] = {0};
- vsnprintf(strlog, MAX_PATH, fmt, arg);
- DbgWithLink((LOG_LEVEL_E)elevel, 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_iAudioTimeout = AUDIO_BUG_THRESHOLD_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 = "";
- m_bPostCapInfo = false;
- #endif
- #endif
- m_strHttpServerAddr = SpDefine::CenterConfigTotal;
- m_strHttpServerAPI = RVC_UPDATE_CAMERABRIGHNESS_HTTP_API;
- m_iHttpTimeOut = RVC_HTTPTIMEOUT;
- m_strAppVersion = NULL;
- m_strTerminalId = NULL;
- m_bsynchronized = false;
- }
- 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]) {
- StartAllCameras(true);
- }
- else if ('O' == pszValue[0]){
- if (strState.GetLength() > 0 && strState[0] == 'M') {
- if (m_bStartCamera) {
- DelayCloseCameras();
- }
- }
- }
- }
- }
- 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(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(16);
- 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);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_MEDIACONTROLLER_NOMATCHED_RESOLUTION, NULL, false);
-
- pTransactionContext->SendAnswer(Error_Succeed);
- }
- #ifdef RVC_OS_WIN
- #else
- static void GetOSKernelVersionInfo()
- {
- std::string sucContent, failedContent;
- CSimpleStringA strCmd("uname -r");
- bool ret = SP::Module::Util::ShellExecute(strCmd.GetData(), sucContent, failedContent);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("{%s}:{%s}{%s}", strCmd.GetData(), sucContent.c_str(), failedContent.c_str());
- if (ret) {
- LogWarn(Severity_Low, Error_Debug, LOG_INFO_KERNEL_VERSION, sucContent.c_str() ? sucContent.c_str() : "get kernel version failed.");
- if (0 != sucContent.compare(RVC_DEFAULT_KERNEL_VERSION)) {
- LogWarn(Severity_Low, Error_Debug, LOG_INFO_UNEXPECTED_KERNEL_VERSION, CSimpleStringA::Format("unexpected kernel version %s.", sucContent.c_str() ? sucContent.c_str() : "get kernel version failed.").GetData());
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("获取系统内核版本信息失败");
- }
- }
- #endif
- 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);
- if (uiState.GetLength() > 0 && uiState[0] == 'F') {
- StartAllCameras(true);
- }
- }
- #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;
- #endif
- #endif
- CSystemStaticInfo si;
- Error = GetFunction()->GetSystemStaticInfo(si);
- if (Error == Error_Succeed) {
- m_strAppVersion = si.InstallVersion.ToString();
- m_strTerminalId = si.strTerminalID;
- }
- }
- 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_DEBUG, 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;
- int iaudiotimeout = AUDIO_BUG_THRESHOLD_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);
- table.AddEntryInt("MediaController", "AudioTimeOut", iaudiotimeout, AUDIO_BUG_THRESHOLD_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;
- }
- if (iaudiotimeout > 0) {
- m_iAudioTimeout = iaudiotimeout;
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::SetCameraSysVar(const CSimpleStringA &newVal)
- {
- CSmartPointer<IEntityFunction> spFunction = this->GetFunction();
-
- CSimpleStringA val = newVal;
- if('B' == val[0]){
- LogWarn(Severity_Middle, Error_DevMedia, 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) {
- 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 (RVC_MEDIADEV_STATUS_CHECK_TIMER == dwTimerID) {
- if (!m_capture) {
- return;
- }
- if (!m_bStartCamera) {
- return;
- }
- OnTimeCameraStatusCheck();
- OnTimeHandfreeMicroStatusCheck();
- }
- 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(RVC_MEDIADEV_STATUS_CHECK_TIMER);
- 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::OnTimeHandfreeMicroStatusCheck()
- {
- CSimpleStringA strValue = m_capture->config.strAudioState;
- if ('B' == strValue[0] || 'H' == strValue[0]) {
- return;
- }
- unsigned int nHandfreeinAudioTime = 0;
- static bool bTimeout = false;
- static bool bPost = false;
- capture_get_last_audio_frametime(m_capture, &nHandfreeinAudioTime);
- if (nHandfreeinAudioTime > 0)
- {
- if (((y2k_time_now() - nHandfreeinAudioTime) > m_iAudioTimeout) && !bTimeout)
- {
- bTimeout = true;
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM)("bTimeout.");
- }
- else if (((y2k_time_now() - nHandfreeinAudioTime) < m_iAudioTimeout) && bTimeout)
- {
- bTimeout = false;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("change handfree audio in from bTimeout to ok.");
- }
- }
- if (bTimeout){
- if (!bPost) {
- LogWarn(Severity_Middle, Error_Hardware, ERROR_MOD_MEDIACONTROLLER_HANDFREEIN_BUG, CSimpleStringA::Format("{%s}故障,采集不到音频", m_capture->config.strAudioIn.GetData()).GetData());
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setResultCode("RTA2820")("免提麦克风故障,采集不到音频");
- bPost = true;
- }
- }
- }
- 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)&&(NULL != m_capture->env_video))
- {
- 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)&&(NULL != m_capture->opt_video))
- {
- 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) && (NULL != m_capture->env_video))
- {
- 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)&&(NULL != m_capture->opt_video))
- {
- 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);
- }
- bool CMediaControllerEntity::SetConfigBright(ErrorCodeEnum nCode)
- {
- if (eStand2sType == m_eDeviceType) {
- if (m_capture) {
- capture_set_camera_brightness(m_capture->config.video_env_brightness, m_capture, nCode, 0);
- capture_set_camera_brightness(m_capture->config.video_opt_brightness, m_capture, nCode, 1);
- }
- }
- else {
- if (m_capture) {
- capture_set_camera_brightness(m_capture->config.video_env_brightness, m_capture, nCode, 0);
- }
- }
- return true;
- }
- //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);
- int ibrightness = num.nValue;
- if (ibrightness < RVC_MIN_CAMERA_BRIGHNESS) {
- ibrightness = RVC_MIN_CAMERA_BRIGHNESS;
- }
- if (eStand2sType == m_eDeviceType) {
- if (capture_adj_brightness(m_capture, ibrightness, m_nCameraErrorCode) == true){
- SendCameraBright(eStand2sType);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("set camera brightness to %d success.", ibrightness);
- PostCameraBrightnessInfos(ibrightness);
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ACM_SET_CAMERABRIGHT fail!");
- LogWarn(Severity_Middle, Error_Debug, LOG_EVT_SET_CAMERA_BRIGHTNESS_FAILED, CSimpleStringA::Format("set camera brightness to %d failed.", ibrightness).GetData());
- }
- }
- else {
- if (0 == capture_set_camera_brightness(ibrightness, m_capture, m_nCameraErrorCode, 0)) {
- SendCameraBright(eStand1SPlusType);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("set camera brightness to %d success.", ibrightness);
- PostCameraBrightnessInfos(ibrightness);
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ACM_SET_CAMERABRIGHT fail!");
- LogWarn(Severity_Middle, Error_Debug, LOG_EVT_SET_CAMERA_BRIGHTNESS_FAILED, CSimpleStringA::Format("set camera brightness to %d failed.", ibrightness).GetData());
- }
- }
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("device 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;
- Error = m_pHMClient->RealCheck(req,ans,500);
- 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(DeviceTypeEnum eType)
- {
- 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;
- if (eStand2sType == eType) {
- nValue = capture_get_brightness(m_capture, m_nCameraErrorCode);
- }
- else if(eStand1SPlusType == eType){
- capture_get_camera_brightness(&nValue, m_capture, m_nCameraErrorCode, 0);
- }
- if (nValue >= 0){
- buf & nValue;
- Info.data = buf.ToBlob();
- m_pMediaControllerChannel->Send(Info);
- }
- 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(bool bstartaudio)
- {
- ErrorCodeEnum Error = Error_Succeed;
- if (!m_bStartCamera) {
- CheckAutoVideoConfig(&conf);
- Error = StartCamera(bstartaudio);
- SetCameraState(Error);
- if (Error_Succeed == Error || Error_EnvCamera == Error || Error_OptCamera == Error) {
- m_bStartCamera = true;
- OnCameraStarted();
- }
- }
- else {
- if (m_bCameraOffTimerOn) {
- if (Error_Succeed != GetFunction()->KillTimer(RVC_CAMERA_OFF_TIMER)) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "start camera for it's already on, kill camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = false;
- }
- }
- }
- return Error;
- }
- void CMediaControllerEntity::DelayCloseCameras()
- {
- 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, "delay close camera, set camera off timer failed.");
- }
- else {
- m_bCameraOffTimerOn = true;
- }
- }
- }
- ErrorCodeEnum CMediaControllerEntity::StopAllCameras()
- {
- if (m_capture){
- GetFunction()->KillTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER);
- 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(true);
- 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;
- }
- if (0 != EnvConfigNameError) {
- 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")("上摄像头配置错误,请检查摄像头配置");
- }
- //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) && (0 != OptConfigNameError)) {
- 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")("下摄像头配置错误,请检查摄像头配置");
- }
- 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;
- }
- 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;
- int ienvbrightness = RVC_DEFAULT_CAMERA_BRIGHNESS;
- int ioptbrightness = RVC_DEFAULT_CAMERA_BRIGHNESS;
- 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);
- table.AddEntryInt("Video", "EnvBrightness", ienvbrightness, RVC_DEFAULT_CAMERA_BRIGHNESS);
- table.AddEntryInt("Video", "OptBrightness", ioptbrightness, RVC_DEFAULT_CAMERA_BRIGHNESS);
- 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;
- }
- conf->video_env_brightness = RVC_DEFAULT_CAMERA_BRIGHNESS;
- if (ienvbrightness <= 100 && ienvbrightness >= RVC_MIN_CAMERA_BRIGHNESS) {
- conf->video_env_brightness = ienvbrightness;
- }
- conf->video_opt_brightness = RVC_DEFAULT_CAMERA_BRIGHNESS;
- if (ioptbrightness <= 100 && ioptbrightness >= RVC_MIN_CAMERA_BRIGHNESS) {
- conf->video_opt_brightness = ioptbrightness;
- }
- 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_BRIGHTNESS, CSimpleStringA::Format("env camera brightness is %d, opt camera brightness is %d.", conf->video_env_brightness, conf->video_opt_brightness).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){
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("%s", 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_Succeed){
- 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;
- }
- #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);
- }
- 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) {
- StartAllCameras(true);
- }
- m_bOnBusiness = true;
- break;
- case LOG_EVT_END_HANDLE_BUSINESS:
- if (m_bStartCamera) {
- DelayCloseCameras();
- }
- m_bOnBusiness = false;
- break;
- case LOG_EVT_RECORDFAILED:
- {
- GetFunction()->KillTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER);
- char FaildFlag = pszMessage[0];
- if (FaildFlag == '0')
- {
- GetFunction()->SetTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER, 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:
- {
- GetFunction()->KillTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER);
- if (m_bIsRemoteRecord){
- LogEvent(Severity_Middle, LOG_EVT_UI_STOPREMOTERECORD, NULL);
- }
-
- GetFunction()->SetTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER, 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:
- {
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- HandleStartCameraCapture(pszMessage);
- #endif
- #endif
- }
- break;
- case LOG_EVT_UI_STOPCAMERACAPTURE:
- {
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- HandleStopCameraCapture();
- #endif
- #endif
- }
- break;
- case LOG_EVT_MEDIACONTROLLER_NOMATCHED_RESOLUTION:
- {
- if (pszMessage) {
- char cdevid = pszMessage[0];
- int idevid = cdevid - '0';
- if (idevid == capture_get_video_device_id(conf.strVideoEnv)) {
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V3").setResultCode("RTA2810")("上摄像分辨率不符合要求");
- }
- else if(idevid == capture_get_video_device_id(conf.strVideoOpt)){
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_USER).setLogCode("QLR0402208V3").setResultCode("RTA2811")("下摄像分辨率不符合要求");
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("no mathed device id.");
- }
- }
- }
- 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(bool bstartaudio)
- {
- 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, bstartaudio);
- if (Error == Error_Succeed)
- {
- #ifdef RVC_OS_WIN
- #else
- if (bstartaudio) {
- m_capture->handfree_audio->paudiocap = m_pAudioCap;
- }
- #endif
- CSmartPointer<IEntityFunction> Func = GetFunction();
- CSimpleStringA strValue("");
- Func->GetSysVar(SYSVAR_SOUNDCARDSTATE, strValue);
- m_capture->config.strAudioState = strValue;
- if ('N' != strValue[0]) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Sound Card State %s.", strValue.GetData());
- }
- Error = capture_start(m_capture, bstartaudio);
- 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);
- if (!m_bsynchronized) {
- SetConfigBright(Error);
- m_bsynchronized = true;
- }
- GetFunction()->SetTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER, this, 5000);
- if((Error == Error_OptCamera)&&(eStand1SPlusType == m_eDeviceType))
- {
- return Error_Succeed;
- }
- else
- {
- return Error;
- }
- }
- }
- else
- {
- //SetAutoBright(Error);
- if (!m_bsynchronized) {
- SetConfigBright(Error);
- m_bsynchronized = true;
- }
- GetFunction()->SetTimer(RVC_MEDIADEV_STATUS_CHECK_TIMER, 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::SetCameraState(ErrorCodeEnum errorcode)
- {
- if (Error_Succeed == errorcode) {
- SetCameraSysVar(CAMERA_NO_ERROR);
- 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_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_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;
- 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")("打开摄像头时出现其它异常");
- }
- }
- }
- ErrorCodeEnum CMediaControllerEntity::ReStartCamera(int nCamera)
- {
- if (m_capture != NULL)
- {
- if((stopcamera(m_capture,nCamera)==-1)){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("restart camera %d, stop camera failed!", nCamera);
- }
- //TODO: CrossPlaform [Gifur@2025730]
- #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)("restart camera %d, capture start failed!", nCamera);
- capture_destroy(m_capture, nCamera);
- return Error;
- }
- else
- {
- return Error_Succeed;
- }
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("restart camera %d, capture create failed!", 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){
- if (NULL != m_pAudioRenderObj){
- if(0 == m_pAudioRenderObj->StartRender(0, pFrame, strName)){
- m_bHasStartSpeakerRender = true;
- }
- }
- }
- #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();
- 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.");
- int ienvbrightness = 0;
- capture_get_camera_brightness(&ienvbrightness, m_capture, m_nCameraErrorCode, 0);
- int ioptbrightness = 0;
- capture_get_camera_brightness(&ioptbrightness, m_capture, m_nCameraErrorCode, 1);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("current env camera brightness is %d, opt camera brightness is %d.", ienvbrightness, ioptbrightness);
- }
- 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 failed.");
- }
- }
- void CMediaControllerEntity::HandleStopCameraCapture()
- {
- if (Error_Succeed != StopSaveEnvCamPhoto()) {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Stop Save EnvCam Photo failed.");
- }
- }
- void CMediaControllerEntity::SetPostCapInfoFlag(bool bpostcapinfo)
- {
- m_bPostCapInfo = bpostcapinfo;
- }
- bool CMediaControllerEntity::GetPostCapInfoFlag()
- {
- return m_bPostCapInfo;
- }
- #endif
- #endif
- void CMediaControllerEntity::GetCameraBrightness(SpReqAnsContext<MediaService_GetCameraBrightness_Req, MediaService_GetCameraBrightness_Ans>::Pointer ctx)
- {
- int ibrightness = 0;
- if (0 == capture_get_camera_brightness(&ibrightness, m_capture, m_nCameraErrorCode, ctx->Req.icameraid)) {
- ctx->Ans.result = 0;
- ctx->Ans.ibrightness = ibrightness;
- ctx->Answer(Error_Succeed);
- }
- else {
- ctx->Ans.result = -1;
- if (0 == ctx->Req.icameraid) {
- ctx->Answer(Error_EnvCamera, LOG_WARN_ENVCAMERA_ERROR);
- }
- else if (1 == ctx->Req.icameraid) {
- ctx->Answer(Error_OptCamera, LOG_WARN_OPTCAMERA_ERROR);
- }
- }
- }
- void CMediaControllerEntity::SetCameraBrightness(SpReqAnsContext<MediaService_SetCameraBrightness_Req, MediaService_SetCameraBrightness_Ans>::Pointer ctx)
- {
- int ibrightness = ctx->Req.ibrightness;
- if (0 == capture_set_camera_brightness(ibrightness, m_capture, m_nCameraErrorCode, ctx->Req.icameraid)) {
- ctx->Ans.result = 0;
- ctx->Answer(Error_Succeed);
- }
- else {
- ctx->Ans.result = -1;
- if (0 == ctx->Req.icameraid) {
- ctx->Answer(Error_EnvCamera, LOG_WARN_ENVCAMERA_ERROR);
- }
- else if (1 == ctx->Req.icameraid) {
- ctx->Answer(Error_OptCamera, LOG_WARN_OPTCAMERA_ERROR);
- }
- }
- }
- ErrorCodeEnum CMediaControllerEntity::PostCameraBrightnessInfos(int iBrightness)
- {
- ErrorCodeEnum Error = Error_Failed;
- brightness_info_t camera_brightness_params;
- camera_brightness_params.strServerURL = m_strHttpServerAddr;
- camera_brightness_params.strAPI = m_strHttpServerAPI;
- camera_brightness_params.strAppVersion = m_strAppVersion;
- camera_brightness_params.strTerminalNo = m_strTerminalId;
- brightness_item_t* item_env = new brightness_item_t();
- item_env->module = "Video";
- item_env->name = "EnvBrightness";
- item_env->value = CSimpleStringA::Format("%d", iBrightness).GetData();
- camera_brightness_params.vBrightnessList.push_back(item_env);
- if (eStand2sType == m_eDeviceType) {
- brightness_item_t* item_opt = new brightness_item_t();
- item_opt->module = "Video";
- item_opt->name = "OptBrightness";
- item_opt->value = CSimpleStringA::Format("%d", iBrightness).GetData();
- camera_brightness_params.vBrightnessList.push_back(item_opt);
- }
- unsigned int uposttime = 0;
- CSimpleStringA strErrorMsg("");
- if (0 == post_camera_brightness_info_list(uposttime, strErrorMsg, &camera_brightness_params, m_iHttpTimeOut, false)) {
- if (500 < uposttime) {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_POST_CAMERA_BRIGHTNESSINFO_COST_TIME, CSimpleStringA::Format("post camera brightness infos cost time is %ums.", uposttime).GetData());
- }
- Error = Error_Succeed;
- }
- else {
- LogWarn(Severity_Middle, Error_Exception, LOG_EVT_POST_CAMERA_BRIGHTNESSINFO_FAILED, strErrorMsg.GetData());
- }
- for (vector<brightness_item_t*>::iterator it = camera_brightness_params.vBrightnessList.begin(); it < camera_brightness_params.vBrightnessList.end(); ++it) {
- if (NULL != *it) {
- delete* it;
- *it = NULL;
- }
- }
- camera_brightness_params.vBrightnessList.clear();
- return Error;
- }
- bool CMediaControllerEntity::IsOnlineState()
- {
- bool bret = true;
- CSimpleStringA strCallState("");
- if (Error_Succeed == GetFunction()->GetSysVar(SYSVAR_CALLSTATE, strCallState)) {
- if (strCallState.Compare("O") == 0) {
- bret = false;
- }
- }
- return bret;
- }
- 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(pEntity->RvcDeviceType());
- }
- }
- }
- }
- 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 };
- //TODO: [Gifur@2025730]
- 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();
- //TODO: CrossPlaform [Gifur@2025730]
- #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 {
- //TODO: CrossPlaform [Gifur@2025730]
- #ifdef RVC_OS_WIN
- Sleep(100);
- #else
- usleep(100*1000);
- #endif
- if (m_pEntity->m_bOnBusiness) {
- Error = m_pEntity->StartCamerasAndRecord();
- }
- else {
- m_pEntity->LogTransactionRecordCtrEvt(1);
- 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_GetCameraBrightness(SpReqAnsContext<MediaService_GetCameraBrightness_Req, MediaService_GetCameraBrightness_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- m_pEntity->GetCameraBrightness(ctx);
- }
- void MediaServiceSession::Handle_SetCameraBrightness(SpReqAnsContext<MediaService_SetCameraBrightness_Req, MediaService_SetCameraBrightness_Ans>::Pointer ctx)
- {
- DbgToBeidou(ctx->link, __FUNCTION__)();
- m_pEntity->SetCameraBrightness(ctx);
- }
- 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__)();
-
- if (m_pEntity->m_bJsOccupyCamera || m_pEntity->IsOnlineState()) {
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setResultCode("RTA280C").setAPI(__FUNCTION__)("摄像头正在使用中,请断开连线后再试");
- ctx->Answer(Error_DevNotAvailable, LOG_WARN_CAMERAOCCUPYING);
- return;
- }
- ErrorCodeEnum Error = m_pEntity->StartAllCameras(false);
- if (Error_Unexpect == Error) {
- DbgWithLink(LOG_LEVEL_WARN, LOG_TYPE_SYSTEM).setResultCode("RTA280F").setAPI(__FUNCTION__)("摄像头实体异常,请联系总行开发人员排查");
- ctx->Answer(Error_Unexpect, LOG_ERROR_ENTITY_ALLOC_MEM_FAILED);
- return;
- }
- #ifdef DEVOPS_ON_PRD
- #else
- #ifdef RVC_OS_WIN
- #else
- if (ctx->Req.bPostCapInfo) {
- m_pEntity->GetFunction()->SetTimer(RVC_CAMERA_CAP_PROCESS, m_pEntity, 5 * 1000);
- m_pEntity->SetPostCapInfoFlag(true);
- }
- #endif
- #endif
- ErrorCodeEnum CameraErrorCode = m_pEntity->m_nCameraErrorCode;
- if ( Error_AllCamera != CameraErrorCode) {
- if (Error_Succeed == CameraErrorCode) {
- ctx->Ans.result = 0;
- }
- else if (Error_EnvCamera == CameraErrorCode) {
- ctx->Ans.result = -1;
- }
- else if (Error_OptCamera == CameraErrorCode) {
- ctx->Ans.result = -2;
- }
- ctx->Answer(Error_Succeed);
- }
- else {
- ctx->Ans.result = -3;
- ctx->Answer(Error_AllCamera, LOG_WARN_ALLCAMERA_ERRORS);
- }
- }
- 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
- if (m_pEntity->GetPostCapInfoFlag()) {
- m_pEntity->GetFunction()->KillTimer(RVC_CAMERA_CAP_PROCESS);
- m_pEntity->SetPostCapInfoFlag(false);
- }
- #endif
- #endif
- ErrorCodeEnum CamRet = m_pEntity->StopAllCameras();
- if (Error_Succeed == CamRet) {
- ctx->Ans.result = 0;
- }
- else {
- ctx->Ans.result = -1;
- }
- ctx->Answer(Error_Succeed);
- }
- SP_BEGIN_ENTITY_MAP()
- SP_ENTITY(CMediaControllerEntity)
- SP_END_ENTITY_MAP()
|