| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157 |
- #include "stdafx.h"
- #include "y2k_time.h"
- #include "capture.h"
- #include "Event.h"
- #include "../mod_snapshot/Event.h"
- #include "mod_mediacontroller.h"
- #include "../mod_interactivecontrol/Event.h"
- #include "../mod_recorder/Event.h"
- #define AUTOMATCH_CAMERA_ENV "ENV_"
- #define AUTOMATCH_CAMERA_OPT "OPT_"
- static void __audiomgrlog(void* user_data, const char* fmt, va_list arg)
- {
- int n = _vscprintf(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);
- }
- }
- CMediaControllerEntity::CMediaControllerEntity(): m_capture(NULL), m_salesaudio_capture(NULL), m_lCaptureEnvCount(0), m_nCameraErrorCode(Error_Succeed),
- m_lCaptureEnvOptCount(0), m_lCaptureOptCount(0), m_iEnvEmptyTimes(0), m_iOptEmptyTimes(0), m_bSendCameraError(false),
- m_nEnvCameraRestartNum(0), m_nOptCameraRestartNum(0), m_nCameraCount(2), m_pSelfcheckClient(NULL),
- strFrontCam("$"), strRearCam("$"), strEnvCam("$"), strUSBCam("$"), m_bCustomerwareBegin(false),
- m_bRecordPCM(false), m_bIsRemoteRecord(false), m_bHasStartSpeakerRender(false), m_bConnectedAssist(FALSE){
- #ifdef RVC_OS_LINUX
- 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_iCamOnMode = 0;
- m_iDelayTime = RVC_MAX_DELAY_TIME;
- }
- void CMediaControllerEntity::OnSysVarEvent(const char *pszKey, const char *pszValue,const char *pszOldValue,const char *pszEntityName)
- {
- if (_stricmp(pszKey, SYSVAR_CALLTYPE) == 0)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("sys call type from: %c to %c", pszOldValue[0], pszValue[0]);
- if(pszValue[0] == CALLTYPE_NORMAL)
- {
- m_nSysCallType = 0;
- }
- else if(pszValue[0] == CALLTYPE_MOBILE)
- {
- m_nSysCallType = 1;
- }
- else
- {
- m_nSysCallType = -1;
- }
- }
- else if (_stricmp(pszKey, SYSVAR_CALLSTATE) == 0)
- {
- CSimpleStringA strState;
- GetFunction()->GetSysVar("UIState", strState);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("sys call state from: %c to %c, and UIState is %s.", pszOldValue[0], pszValue[0], strState.GetData());
- if ('C' == pszValue[0]) {
- if (1 == m_iCamOnMode) {
- if (!m_bStartCamera) {
- StartCameraAndSetSysVar();
- if (m_bStartCamera) {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_BEGIN_FACETRACKING, "start facetracking.");
- }
- }
- else {
- if (strState.GetLength() > 0 && strState[0] == 'M') {
- if (Error_Succeed == GetFunction()->KillTimer(3)) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("KillTimer 3 success.");
- }
- else {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "Call State is Connecting, and UIState is M, KillTimer 3 failed.");
- }
- }
- }
- }
- }
- else if ('O' == pszValue[0]){
- if (1 == m_iCamOnMode) {
- if (strState.GetLength() > 0 && strState[0] == 'M') {
- if (m_bStartCamera) {
- if (Error_Succeed == GetFunction()->SetTimer(3, this, m_iDelayTime * 1000)) {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("SetTimer 3 success.");
- }
- else {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_SETTIMER_ERROR, "Call State is OffLine, and UIState is M, SetTimer 3 failed.");
- }
- }
- }
- }
- }
- }
- }
- 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;
- CSmartPointer<IEntityFunction> Func = GetFunction();
- CSimpleStringA strValue;
- Func->RegistSysVarEvent(SYSVAR_CALLTYPE, this);
- Func->GetSysVar(SYSVAR_CALLTYPE, strValue);
- if (strValue[0] == CALLTYPE_NORMAL) {
- m_nSysCallType = 0;
- }
- else if (strValue[0] == CALLTYPE_MOBILE) {
- m_nSysCallType = 1;
- }
- else {
- assert(0);
- }
-
- #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 success!");
- }
- else {
- 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);
- }
- 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_Middle, Error_IgnoreAll, EVENT_MOD_CUSTOMERAWARE_BEGIN, NULL, false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_Middle, Error_IgnoreAll, EVENT_MOD_CUSTOMERAWARE_END, 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_UI_STARTRECORD,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_STOPRECORD,NULL,false);
- GetFunction()->SubscribeLog(m_arrListener[i++], this, Log_Event, Severity_None, Error_IgnoreAll, LOG_EVT_UI_STARTRECORDPREVIEW,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);
- pTransactionContext->SendAnswer(Error_Succeed);
- }
- void CMediaControllerEntity::OnStarted()
- {
- m_bStartCamera = FALSE;
- m_bExternControlCam = FALSE;
- m_nSysCallType =0;
- ErrorCodeEnum Error = Error_Succeed;
- //MessageBoxA(0,0,0,0);
- m_pMediaControllerChannel = new ChannelMediaControllerClient(this);
- if (Error_Succeed == ConnectAssistChannel()) {
- m_bConnectedAssist = TRUE;
- }
- m_pSelfcheckClient = new SelfChekerClient(this);
- Error = m_pSelfcheckClient->Connect();
- if (Error != Error_Succeed){
- m_pSelfcheckClient->SafeDelete();
- m_pSelfcheckClient = NULL;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("SelfcheckClient connect fail!");
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("SelfcheckClient connect success!");
- }
- if (Error_Succeed == GetMediaConfig()) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("cam timeout time is %d.", m_iCamTimeout);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("CamOnMode is %d, and max delay time is %d.", m_iCamOnMode, m_iDelayTime);
- }
- memset(&conf, 0, sizeof(capture_config_t));
- memset(&m_sales_audio_conf, 0, sizeof(rvc_audio_capture_config_t));
- Error = (ErrorCodeEnum)capture_lib_init();
- if (Error == Error_Succeed)
- {
- #ifdef RVC_OS_LINUX
- RvcGetAudioDevice();
- #endif
- 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;
- GetFunction()->SetUserDefineState(USER_MEDIA_ENVERRROR);
- }
- 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;
- GetFunction()->SetUserDefineState(USER_MEDIA_OPTERROR);
- }
- }
- 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;
- GetFunction()->SetUserDefineState(USER_MEDIA_ALLERROR);
- }
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Load Config failed!");
- }
- }
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("capture_lib_init failed!");
- }
- //PAD版获取客户感知状态
- CSimpleStringA strCustomerAware;
- if (Error != Error_AllCamera)
- {
- CSmartPointer<IEntityFunction> Func = GetFunction();
- if (Func->RegistSysVarEvent("CustomerHandle", this) != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("register sys var %s failed!", "CustomerHandle");
- }
- else{
- Func->GetSysVar("CustomerHandle", strCustomerAware);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("CustomerHandle = %s",strCustomerAware.GetData());
- }
- }
- //启动摄像头
- if ((Error!=Error_AllCamera)&&(strCustomerAware.GetLength()>0)&&(strCustomerAware[0] != 'N')&&(1 != m_iCamOnMode))
- {
- Error = StartCamera();
- if (Error == Error_Succeed)
- {
- m_bStartCamera = TRUE;
- SetCameraSysVar(CAMERA_NO_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_NO_ERROR");
- m_nCameraErrorCode = Error_Succeed;
- GetFunction()->SetUserDefineState(USER_MEDIA_IDLE);
- }
- else
- {
- if((Error == Error_EnvCamera)||(Error == Error_OptCamera))
- {
- m_bStartCamera = TRUE;
- if (Error == Error_EnvCamera)
- {
- SetCameraSysVar(CAMERA_ENV_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_ENV_ERROR");
- m_nCameraErrorCode = Error_EnvCamera;
- GetFunction()->SetUserDefineState(USER_MEDIA_ENVERRROR);
- Error = Error_Succeed;
- }
- else if (Error == Error_OptCamera)
- {
- SetCameraSysVar(CAMERA_OPT_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("StartCamera = Error_OptCamera");
- m_nCameraErrorCode = Error_OptCamera;
- GetFunction()->SetUserDefineState(USER_MEDIA_OPTERROR);
- Error = Error_Succeed;
- }
- }
- else if(Error == Error_AllCamera)
- {
- SetCameraSysVar(CAMERA_BOTH_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_BOTH_ERROR");
- m_nCameraErrorCode = Error_AllCamera;
- m_bStartCamera = FALSE;
- GetFunction()->SetUserDefineState(USER_MEDIA_ALLERROR);
- }
- else
- {
- SetCameraSysVar(Error);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Other Error");
- m_nCameraErrorCode = Error;
- m_bStartCamera = FALSE;
- }
- }
- if (m_bStartCamera) {
- CSimpleStringA strSessionId;
- CSmartPointer<IEntityFunction> Func = GetFunction();
- Func->GetSysVar("SessionID", strSessionId);
- LogEvent(Severity_Middle, EVENT_MOD_BEGIN_RECORD, strSessionId);
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_BEGIN_FACETRACKING, "start facetracking.");
- }
- }
- if (1 == m_iCamOnMode) {
- SetCameraSysVar(CAMERA_NO_ERROR);
- }
- LogEvent(Severity_Middle, LOG_EVT_MOD_MEDIACONTROLLER_STARTED_SUCCESS, "mediacontroller entity started successfully.");
- }
- #ifdef RVC_OS_LINUX
- ErrorCodeEnum CMediaControllerEntity::RvcGetAudioDevice()
- {
- ErrorCodeEnum Error = Error_Param;
- if (NULL != m_pAudioCap){
- int icountmic = m_pAudioCap->audio_get_device_count(true);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("audio input device(%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 device(%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;
- }
- return Error;
- }
- #endif
- DeviceTypeEnum CMediaControllerEntity::RvcGetDeviceType()
- {
- DeviceTypeEnum eType = eStand2sType;
- CSmartPointer<IEntityFunction> spFunction = GetFunction();
- CSystemStaticInfo stStaticinfo;
- spFunction->GetSystemStaticInfo(stStaticinfo);
- if (_stricmp(stStaticinfo.strMachineType, "RVC.PAD") == 0) {
- if (_stricmp(stStaticinfo.strSite, "CMB.FLB") == 0) {
- eType = eMobilePadType;
- }
- else {
- eType = ePadtype;
- }
- }
- else if (_stricmp(stStaticinfo.strMachineType, "RVC.Desk2S") == 0) {
- eType = eDesk2SType;
- WORD nMajor = stStaticinfo.MachineVersion.GetMajor();
- WORD nMinor = stStaticinfo.MachineVersion.GetMinor();
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("MachineVersion is %d.%d", nMajor, nMinor);
- if (2 == nMajor) {
- eType = eDesk2SIntegratedType;
- }
- }
- else if (_stricmp(stStaticinfo.strMachineType, "RPM.Stand1S") == 0) {
- eType = eRpm1sType;
- }
- else if (_stricmp(stStaticinfo.strMachineType, "RVC.Desk1S") == 0) {
- eType = eDesk1SType;
- }
- 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;
- }
- void CMediaControllerEntity::SetCameraSysVar(int n)
- {
- if (n==0){
- SetCameraSysVar(CAMERA_OPT_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_OPT_ERROR");
- }
- else if (n==1){
- SetCameraSysVar(CAMERA_ENV_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_ENV_ERROR");
- }
- else if (n==-1){
- SetCameraSysVar(CAMERA_BOTH_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_BOTH_ERROR");
- }
- else if (n==3){
- SetCameraSysVar(CAMERA_NO_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_NO_ERROR");
- }
- }
- ErrorCodeEnum CMediaControllerEntity::GetSalesRecordAudioParam()
- {
- CSmartPointer<IConfigInfo> spConfig;
- SpIniMappingTable table;
- ErrorCodeEnum Error = GetFunction()->OpenConfig(Config_CenterSetting, spConfig);
- if (Error == Error_Succeed){
- table.AddEntryInt("SalesRecorder", "AudioSampleRate", m_nSalesAudioSmpPsec, 8);
- table.AddEntryBoolean("SalesRecorder", "IsRecordPCM", m_bRecordPCM, false);
- Error= table.Load(spConfig);
- }
-
- if (m_nSalesAudioSmpPsec != 8 && m_nSalesAudioSmpPsec != 16){
- m_nSalesAudioSmpPsec = 8;
- }
- m_nSalesAudioSmpPsec *= 1000;
- #ifdef RVC_OS_WIN
- #else
- m_nSalesAudioSmpPsec = 44100;
- #endif
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::GetMediaConfig()
- {
- ErrorCodeEnum Error = Error_Succeed;
- CSmartPointer<IConfigInfo> spConfig;
- SpIniMappingTable table;
- int itimeout = CAMERA_TIMEOUT;
- int iCamOnMode = 0;
- int iDelayTime = RVC_MAX_DELAY_TIME;
- int iRecordMode = 0;
- Error = GetFunction()->OpenConfig(Config_CenterSetting, spConfig);
- if (Error == Error_Succeed){
- table.AddEntryInt("MediaController", "CamTimeOut", itimeout, CAMERA_TIMEOUT);
- table.AddEntryInt("MediaController", "CamOnMode", iCamOnMode, 0);
- table.AddEntryInt("MediaController", "MaxDelayTime", iDelayTime, RVC_MAX_DELAY_TIME);
- table.AddEntryInt("InteractiveControl", "RecordMode", iRecordMode, 0);
- Error = table.Load(spConfig);
- }
- if (Error_Succeed != Error) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get entity config from config failed!");
- }
- else {
- if (1 == iCamOnMode && 1 == iRecordMode) {
- m_iCamOnMode = 1;
- }
- if (iDelayTime > 0) {
- m_iDelayTime = iDelayTime;
- }
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::SetEnvCameraOnSysVar(const CSimpleStringA strOnState)
- {
- ErrorCodeEnum Error = Error_Succeed;
- CSmartPointer<IEntityFunction> spFunction = this->GetFunction();
- Error = spFunction->SetSysVar(SYSVAR_ENVCAMERAON, strOnState.GetData());
- 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");
- }
- if (eStand2sType == m_eDeviceType)
- {
- return spFunction->SetSysVar(SYSVAR_CAMERASTATE, (LPCTSTR)newVal);
- }
- switch (val[0])
- {
- case 'E':
- {
- if (!strstr((LPCTSTR)strFrontCam,";"))
- {
- val = val.Append((LPCTSTR)strFrontCam);
- }
- else
- {
- val = val.Append((LPCTSTR)strFrontCam.SubString(0,strFrontCam.IndexOf(";")));
- }
- }
- break;
- case 'O':
- if (!strstr((LPCTSTR)strRearCam,";"))
- {
- val = val.Append((LPCTSTR)strRearCam);
- }
- else
- {
- val = val.Append((LPCTSTR)strRearCam.SubString(0,strRearCam.IndexOf(";")));
- }
- break;
- case 'B':
- val = val.Append("内置前、后");
- break;
- case 'N':
- case 'I':
- default:
- break;
- }
-
- return spFunction->SetSysVar(SYSVAR_CAMERASTATE, (LPCTSTR)val);
- }
- 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_CALLTYPE);
- 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) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("m_capture =Null");
- return;
- }
- if (!m_bStartCamera) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("m_bStartCamera =false");
- 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 (3 == dwTimerID) {
- CSimpleStringA strCallState;
- GetFunction()->GetSysVar(SYSVAR_CALLSTATE, strCallState);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Timer 3 strCallState = %s", strCallState.GetData());
- if ('O' == strCallState[0] && m_bStartCamera) {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_END_FACETRACKING, "stop facetracking.");
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("stop camera.");
- if (m_capture){
- GetFunction()->KillTimer(1);
- capture_stop(m_capture);
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- m_bStartCamera = FALSE;
- if (Error_Succeed == GetFunction()->KillTimer(3)) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Stop Camera, KillTimer 3 success.");
- }
- else {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "Stop Camera, KillTimer 3 failed.");
- }
- }
- }
- }
- void CMediaControllerEntity::OnTimeCameraStatusCheck()
- {
- int env_n = -1, opt_n = -1;
- unsigned int nLastEnvTime = 0, nLastOptTime = 0;
- bool bEnvTimeout = false;
- bool bOptTimeout = false;
- BOOL bIsPadType = FALSE;
- if ((ePadtype == m_eDeviceType)||(eMobilePadType == m_eDeviceType)||(eDesk2SType == m_eDeviceType)||(eDesk1SType == m_eDeviceType)||(eDesk2SIntegratedType == m_eDeviceType)){
- bIsPadType = TRUE;
- }
- capture_detect_camera_bug(m_capture, &env_n, &opt_n, bIsPadType);
- //DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("capture_detect_camera_bug env_n = %d, opt_n = %d.",env_n, opt_n);
- capture_get_last_frametime(m_capture, &nLastEnvTime, &nLastOptTime, bIsPadType);
- if (env_n == 0) {
- if (m_iEnvEmptyTimes < CAMERA_BUG_THRESHOLD){
- m_iEnvEmptyTimes++;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get env camera picture fail,Times=%d",m_iEnvEmptyTimes);
- }
- }
- else if (env_n == -1){
- m_iEnvEmptyTimes = CAMERA_BUG_THRESHOLD;
- }
- else {
- if (m_iEnvEmptyTimes == CAMERA_BUG_THRESHOLD){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("env camera get right!");
- }
- m_iEnvEmptyTimes = 0;
- }
- //env图像是否超时
- if(nLastEnvTime > 0)
- {
- //DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("now=%d,nLastEnvTime=%d",y2k_time_now(),nLastEnvTime);
- if(((y2k_time_now()-nLastEnvTime) > m_iCamTimeout)&&!bEnvTimeout)
- {
- bEnvTimeout = true;
- DbgWithLink(LOG_LEVEL_INFO, 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没有图像或者图像20秒没有更新
- if(((m_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);
- if ((ePadtype == m_eDeviceType)||(eMobilePadType == m_eDeviceType)||(eDesk2SType == m_eDeviceType)||(eDesk1SType == m_eDeviceType)||(eDesk2SIntegratedType == m_eDeviceType))
- {
- m_nCameraErrorCode = Error_AllCamera;
- ChangeSysvar(Error_EnvCamera);
- if (!m_bIsRemoteRecord) {
- RealSelfCheck();
- }
- return;
- }
- else{
- if (m_nCameraErrorCode == Error_Succeed){
- m_nCameraErrorCode = Error_EnvCamera;
- ChangeSysvar(m_nCameraErrorCode);
- }
- else if (m_nCameraErrorCode == Error_OptCamera){
- m_nCameraErrorCode = Error_AllCamera;
- ChangeSysvar(m_nCameraErrorCode);
- if (!m_bIsRemoteRecord) {
- RealSelfCheck();
- }
- return;
- }
- }
- }
- else if((m_iEnvEmptyTimes != CAMERA_BUG_THRESHOLD)&&!bEnvTimeout&&((m_nCameraErrorCode == Error_EnvCamera)||(m_nCameraErrorCode == Error_AllCamera)))
- {
- if ((ePadtype == m_eDeviceType)||(eMobilePadType == m_eDeviceType)||(eDesk2SType == m_eDeviceType)||(eDesk1SType == m_eDeviceType)||(eDesk2SIntegratedType == m_eDeviceType))
- {
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- }
- else{
- if (m_nCameraErrorCode == Error_EnvCamera){
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("changeSysvar to No_Error");
- }
- else if (m_nCameraErrorCode == Error_AllCamera){
- m_nCameraErrorCode = Error_OptCamera;
- ChangeSysvar(m_nCameraErrorCode);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("changeSysvar to Opt_Error");
- }
- }
- }
- //opt是否没有图像
- if (eStand2sType == m_eDeviceType)
- {
- if (opt_n == 0)
- {
- if (m_iOptEmptyTimes < CAMERA_BUG_THRESHOLD)
- {
- m_iOptEmptyTimes++;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("get opt camera picture fail, Times=%d",m_iOptEmptyTimes);
- }
- }
- else if (opt_n == -1)
- {
- m_iOptEmptyTimes = CAMERA_BUG_THRESHOLD;
- }
- else
- {
- if (m_iOptEmptyTimes == CAMERA_BUG_THRESHOLD)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("opt camera get right!");
- }
- m_iOptEmptyTimes = 0;
- }
- }
- //opt图像是否超时
- if((nLastOptTime > 0)&&(eStand2sType == m_eDeviceType))
- {
- if(((y2k_time_now()-nLastOptTime) > m_iCamTimeout)&&!bOptTimeout)
- {
- bOptTimeout = true;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("bOptTimeout");
- }
- else if (((y2k_time_now()-nLastOptTime) < m_iCamTimeout)&&bOptTimeout)
- {
- bOptTimeout = false;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("change opt camera from bOptTimeout to OK");
- }
- }
- //opt是否100S没有图像或者图像20秒没有更新
- if(((m_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);
- if (m_nCameraErrorCode == Error_Succeed)
- {
- m_nCameraErrorCode = Error_OptCamera;
- ChangeSysvar(m_nCameraErrorCode);
- }
- else if (m_nCameraErrorCode == Error_EnvCamera)
- {
- m_nCameraErrorCode = Error_AllCamera;
- ChangeSysvar(m_nCameraErrorCode);
- if (!m_bIsRemoteRecord) {
- RealSelfCheck();
- }
- return;
- }
- }
- else if((m_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;
- ChangeSysvar(m_nCameraErrorCode);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("changeSysvar to No_Error");
- }
- else if (m_nCameraErrorCode == Error_AllCamera)
- {
- m_nCameraErrorCode = Error_EnvCamera;
- ChangeSysvar(m_nCameraErrorCode);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("changeSysvar to Env_Error");
- }
- }
- //重启摄像头
- if((m_nCameraErrorCode == Error_EnvCamera)&&(m_nEnvCameraRestartNum<CAMERA_RESTARTNUM))
- {
- if (ReStartCamera(ENVCAMERA) != Error_Succeed){
- m_nEnvCameraRestartNum++;
- }
- else
- {
- m_nEnvCameraRestartNum = 0;
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- m_iEnvEmptyTimes = 0;
- bEnvTimeout = false;
- //重置上次取图像时间,防止出现重启摄像头5s内取不到图像不断重启摄像头问题
- nLastEnvTime = y2k_time_now();
- }
- }
- else if((m_nCameraErrorCode == Error_OptCamera)&&(m_nOptCameraRestartNum<CAMERA_RESTARTNUM)&&(eStand2sType == m_eDeviceType))
- {
- if (ReStartCamera(OPTCAMERA) != Error_Succeed) {
- m_nOptCameraRestartNum++;
- }
- else
- {
- m_nOptCameraRestartNum = 0;
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- m_iOptEmptyTimes = 0;
- bOptTimeout = false;
- //重置上次取图像时间,防止出现重启摄像头5s内取不到图像不断重启摄像头问题
- nLastOptTime = y2k_time_now();
- }
- }
- else if (m_nCameraErrorCode == Error_AllCamera)
- {
- if (m_nEnvCameraRestartNum<CAMERA_RESTARTNUM)
- {
- if (ReStartCamera(ENVCAMERA) != Error_Succeed)
- m_nEnvCameraRestartNum++;
- else
- {
- m_nEnvCameraRestartNum = 0;
- m_nCameraErrorCode = Error_OptCamera;
- ChangeSysvar(m_nCameraErrorCode);
- m_iEnvEmptyTimes = 0;
- bEnvTimeout = false;
- }
- }
- if((m_nOptCameraRestartNum<CAMERA_RESTARTNUM)&&(eStand2sType == m_eDeviceType))
- {
- if (ReStartCamera(OPTCAMERA) != Error_Succeed)
- m_nOptCameraRestartNum++;
- else
- {
- m_nOptCameraRestartNum = 0;
- m_iOptEmptyTimes = 0;
- bOptTimeout = false;
- if (m_nCameraErrorCode == Error_AllCamera)
- {
- m_nCameraErrorCode = Error_EnvCamera;
- ChangeSysvar(m_nCameraErrorCode);
- }
- else
- {
- m_nCameraErrorCode = Error_Succeed;
- ChangeSysvar(m_nCameraErrorCode);
- }
- }
- }
- }
- }
- 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)
- {
- //vamera bright adj
- CCameraBrightValue num;
- SpBuffer buf;
- buf.OpenRead(buffer,size);
- num.Serialize(buf);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv ACM_SET_CAMERABRIGHT = %d",num.nValue);
- if (capture_adj_brightness(m_capture,num.nValue,m_nCameraErrorCode) == true)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ACM_SET_CAMERABRIGHT success!");
- SendCameraBright();
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ACM_SET_CAMERABRIGHT fail!");
- }
- }
- 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_pSelfcheckClient)
- {
- SelfCheckerService_RealCheck_Req req;
- req.name = GetEntityName();
- SelfCheckerService_RealCheck_Ans ans;
- DWORD Timeout = 500;
- Error = m_pSelfcheckClient->RealCheck(req,ans,Timeout);
- if (Error!=Error_Succeed)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("RealSelfcheck fail!");
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("RealSelfcheck");
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_REAL_SELF_CHECK, "media controller entity auto restart.");
- }
- }
- return Error;
- }
- void CMediaControllerEntity::SendCameraBright()
- {
- if (m_nSysCallType == 0)
- {
- 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;
- bool rslt = true;
- 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 = %d",nValue);
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("send cur camera bright value Fail!");
- }
- }
- else
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("cur call type cannot send pkt");
- }
- }
- ErrorCodeEnum CMediaControllerEntity::StartEnvCamera()
- {
- ErrorCodeEnum Error = Error_Succeed;
- if (FALSE == m_bStartCamera){
- Error = StartCamera();
- if (Error_Succeed == Error){
- SetCameraSysVar(CAMERA_NO_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_NO_ERROR");
- m_bStartCamera = TRUE;
- }
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("camera already start.");
- }
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::StopEnvCamera()
- {
- if (m_capture){
- GetFunction()->KillTimer(1);
- capture_stop(m_capture);
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- m_bStartCamera = FALSE;
- return Error_Succeed;
- }
- ErrorCodeEnum CMediaControllerEntity::LoadRunConfig(CSimpleStringA& frontcam, CSimpleStringA& rearcam)
- {
- CSmartPointer<IEntityFunction> spFunction = GetFunction();
- CSmartPointer<IConfigInfo> spConfig;
- ErrorCodeEnum Error = spFunction->OpenConfig(Config_Run, spConfig);
- if (Error == Error_Succeed) {
- SpIniMappingTable table;
- table.AddEntryString("Video", "FrontCamera", frontcam, "$");
- table.AddEntryString("Video", "RearCamera", rearcam, "$");
- Error = table.Load(spConfig);
- if (Error != Error_Succeed)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("[dbg] failed to load run config.");
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("[dbg] failed to open run config.");
- }
- return Error;
- }
-
- 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)",(LPCTSTR)conf->strVideoEnv);
- 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)",(LPCTSTR)conf->strVideoOpt);
- 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;
- }
- }
- }
-
- return Error;
- }
- ErrorCodeEnum CMediaControllerEntity::AutoGetVideoDeviceName(capture_config_t* conf)
- {
- ErrorCodeEnum Error = Error_Unexpect;
- int icount = rvc_videocap_get_device_count();
- int ifound = 0;
- bool benv = false;
- bool bopt = false;
- 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;
- }
- if (benv && bopt){
- break;
- }
- }
- }
- if (benv || bopt) {
- Error = Error_Succeed;
- }
- if (benv) {
- if (bopt) {
- m_nCameraErrorCode = Error_Succeed;
- }
- else {
- m_nCameraErrorCode = Error_OptCamera;
- }
- }
- else {
- if (bopt) {
- m_nCameraErrorCode = Error_EnvCamera;
- }
- else {
- m_nCameraErrorCode = Error_AllCamera;
- }
- }
- 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) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("sales_record_in_dev configure update conf strAudioIn.");
- 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;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("remote record, reset audio sample rate to %d.", conf->audio_capture_samplerate);
- }
- 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 = 0;
- 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, 0);
- table.AddEntryInt("Video", "EnvFps", conf->video_env_fps, 0);
- table.AddEntryInt("Video", "OptFps", conf->video_opt_fps, 0);
- table.AddEntryInt("Video", "mtu", imtu, 0);
- Error = table.Load(spConfig);
- if (Error == Error_Succeed)
- {
- 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());
- char strInfo[MAX_PATH * 2] = { 0 };
- Error = AutoGetVideoDeviceName(conf);
- snprintf(strInfo, MAX_PATH * 2, "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);
- }
- else {
- LogWarn(Severity_Low, Error_Debug, ERROR_MOD_MEDIACONTROLLER_VIDEO_AUTO_MATHED_FAILED, strInfo);
- }
- Error = CheckConfigCameraName(conf, m_eDeviceType);
- if (Error == Error_EnvCamera || Error == Error_AllCamera){
- char strMessage[MAX_PATH*2] = {0};
- get_camera_exception_message(strMessage, MAX_PATH*2, conf->strVideoEnv ,"env camera start error,please check config file or device.");
- LogWarn(Severity_Middle,Error_DevMedia,ERROR_MOD_MEDIACONTROLLER_ENVCAM_INITFAIL,strMessage);
- } else if (Error == Error_OptCamera){
- char strMessage[MAX_PATH*2] = {0};
- get_camera_exception_message(strMessage, MAX_PATH*2, conf->strVideoOpt, "operation camera start error,please check config file or device.");
- LogWarn(Severity_Middle,Error_DevMedia,ERROR_MOD_MEDIACONTROLLER_OPTCAM_INITFAIL, strMessage);
- }
- }
- 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)
- {
- // 广播给业务系统
- //ExternalCameraSwitchFailed evt;
- //evt.failedmsg = CSimpleStringA2W(pszFailedMsg);
- //SpSendBroadcast(GetFunction(), SP_MSG_OF(ExternalCameraSwitchFailed), SP_MSG_SIG_OF(ExternalCameraSwitchFailed), evt);
- //DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("[dbg] ExternalCameraSwitchFailed broadcast sent!");
- 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
- }
- }
- 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)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("user_code = 0x%08x", dwUserCode);
- switch (dwUserCode)
- {
- case MOD_EVENT_SNAPSHOT_START_CAPTURE_ENVOPT:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv 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:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv MOD_EVENT_SNAPSHOT_START_CAPTURE_ENV");
- #ifdef RVC_OS_WIN
- InterlockedCompareExchange(&m_lCaptureEnvOptCount, 1, 0);
- #else
- pthread_mutex_lock(&m_envopt_mutex);
- LONG* plTemp = &m_lCaptureEnvOptCount;
- if (0 == *plTemp) {
- *plTemp = 1;
- }
- pthread_mutex_unlock(&m_envopt_mutex);
- #endif // RVC_OS_WIN
- }
- break;
- case MOD_EVENT_SNAPSHOT_START_CAPTURE_OPT:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv MOD_EVENT_SNAPSHOT_START_CAPTURE_OPT");
- #ifdef RVC_OS_WIN
- InterlockedCompareExchange(&m_lCaptureEnvOptCount, 1, 0);
- #else
- pthread_mutex_lock(&m_envopt_mutex);
- LONG* plTemp = &m_lCaptureEnvOptCount;
- if (0 == *plTemp) {
- *plTemp = 1;
- }
- pthread_mutex_unlock(&m_envopt_mutex);
- #endif // RVC_OS_WIN
- }
- break;
- case LOG_EVT_MOD_ASSISCHAN_STARTED_SUCCESS:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("recv LOG_EVT_MOD_ASSISCHAN_STARTED_SUCCESS");
- Sleep(800);
- if (m_pMediaControllerChannel != NULL){
- m_pMediaControllerChannel->GetFunction()->CloseSession();
- m_pMediaControllerChannel = NULL;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Close AssistChannel Session ");
- m_bConnectedAssist = FALSE;
- }
- if (Error_Succeed == ConnectAssistChannel()){
- m_bConnectedAssist = TRUE;
- }
- else {
- GetFunction()->SetTimer(2, this, 3350);
- }
- }
- break;
- case EVENT_MOD_CUSTOMERAWARE_BEGIN:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("customeraware begin.");
- m_bCustomerwareBegin = true;
- if (1 != m_iCamOnMode)
- {
- if (!m_bStartCamera && !m_bExternControlCam)
- {
- if (eDesk2SIntegratedType != m_eDeviceType) {
- StartCameraAndSetSysVar();
- }
- else {
- CSimpleStringA strOccupy;
- if (Error_Succeed == GetFunction()->GetSysVar(SYSVAR_CAMERAOCCUPY, strOccupy)) {
- if (strOccupy.IsNullOrEmpty()) {
- StartCameraAndSetSysVar();
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera is Occupying by Entity[%s].", strOccupy.GetData());
- }
- }
- }
- if (m_bStartCamera) {
- LogEvent(Severity_Middle, EVENT_MOD_BEGIN_RECORD, pszMessage);
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_BEGIN_FACETRACKING, "start facetracking.");
- }
- }
- }
- }
- break;
- case LOG_EVT_BEGIN_HANDLE_BUSINESS:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("begin handle business.");
- if (1 == m_iCamOnMode){
- if (!m_bStartCamera){
- StartCameraAndSetSysVar();
- if (m_bStartCamera) {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_BEGIN_FACETRACKING, "start facetracking.");
- }
- }
- else {
- if (Error_Succeed == GetFunction()->KillTimer(3)) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("begin handle business, and camera is already on, KillTimer 3 success.");
- }
- else {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_KILLTIMER_ERROR, "begin handle business, and camera is already on, KillTimer 3 failed.");
- }
- }
- }
- break;
- case LOG_EVT_END_HANDLE_BUSINESS:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("end handle business.");
- if (1 == m_iCamOnMode) {
- if (m_bStartCamera) {
- if (Error_Succeed == GetFunction()->SetTimer(3, this, m_iDelayTime * 1000)) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("end handle business, SetTimer 3 success.");
- }
- else {
- LogWarn(Severity_Low, Error_Debug, LOG_EVT_MEDIACONTROLLER_SETTIMER_ERROR, "end handle business, SetTimer 3 failed.");
- }
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("end handle business, and camera is not on.");
- }
- }
- break;
- case EVENT_MOD_CUSTOMERAWARE_END:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("customeraware end.");
- m_bCustomerwareBegin = false;
- if (1 != m_iCamOnMode) {
- if (m_bStartCamera && !m_bExternControlCam)
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("stop camera.");
- if (m_capture)
- {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_END_FACETRACKING, "customeraware end, stop facetracking.");
- LogEvent(Severity_Middle, EVENT_MOD_END_RECORD, pszMessage);
- GetFunction()->KillTimer(1);
- capture_stop(m_capture);
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- m_bStartCamera = FALSE;
- }
- }
- }
- break;
- case LOG_EVT_RECORDFAILED:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("[dbg] record failed event.");
- GetFunction()->KillTimer(1);
- LogEvent(Severity_Middle, EVENT_MOD_END_RECORD, NULL);
- char FaildFlag = pszMessage[0];
- if (FaildFlag == '0')
- {
- GetFunction()->SetTimer(1, this, 5000);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("本地录音录像失败,已停止!");
- }
- else //if (FaildFlag == '1')
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("本地录音录像设备故障,尝试恢复中(预计10s内),请稍等");
- if (false == m_bIsRemoteRecord) {
- m_nCameraErrorCode = Error_AllCamera;
- }
- //RealSelfCheck(); // 录音录像失败,强行kill实体
- }
- }
- break;
- case LOG_EVT_UI_RECORDFAILED:
- {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("[dbg] sales record failed event.");
- OnExternalCameraSwitchFailed(pszMessage);
- GetFunction()->KillTimer(1);
- if (m_bIsRemoteRecord){
- LogEvent(Severity_Middle, LOG_EVT_UI_STOPREMOTERECORD, NULL);
- }
- else{
- LogEvent(Severity_Middle, LOG_EVT_UI_STOPRECORD, 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;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("start remote sales record and set remote record flag to true.");
- HandleRemoteRecord(pszMessage);
- }
- break;
- case LOG_EVT_UI_STOPREMOTERECORD:
- {
- m_bIsRemoteRecord = false;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("stop remote sales record and set remote record flag to false.");
- if (Error_Succeed == StopSalesRecordAudioCapture()){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("stop remote sales record audio capture.");
- }
- if (true == m_bHasStartSpeakerRender){
- StopSpeakerAudioRender();
- }
- }
- 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 if (st.wMinute > CAMERA_CHANGE_TIMER)
- {
- 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);
- GetFunction()->SetUserDefineState(USER_MEDIA_IDLE);
- break;
- case Error_EnvCamera:
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Env_Error");
- SetCameraSysVar(CAMERA_ENV_ERROR);
- GetFunction()->SetUserDefineState(USER_MEDIA_ENVERRROR);
- 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);
- GetFunction()->SetUserDefineState(USER_MEDIA_OPTERROR);
- 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);
- GetFunction()->SetUserDefineState(USER_MEDIA_ALLERROR);
- capture_clearsnapshotvideo(m_capture,AlLCAMERA);
- break;
- default:
- break;
- }
- return Error_Succeed;
- }
- //开始销售双录音频采集函数
- ErrorCodeEnum CMediaControllerEntity::StartSalesRecordAudioCapture(bool bRemoteRecord, eRvcPCMTransType eType, void* pData)
- {
- 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 = SetSalesRecordAudioCaptureTransActionData(eType, pData);
- }
- }
- if (Error_Succeed == Error){
- Error = salesrecord_audio_capture_start(m_salesaudio_capture);
- if (Error_Succeed == Error){
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("sales record audio capture start success.");
- }
- else{
- 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;
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("set m_salesaudio_capture to 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
- Error = (ErrorCodeEnum)capture_create(&conf, &m_capture);
- if (Error == Error_Succeed)
- {
- #ifdef RVC_OS_WIN
- #else
- m_capture->audio->paudiocap = m_pAudioCap;
- #endif
- Error = capture_start(m_capture);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("capture_start Error code=0x%08x",Error);
- if (Error != Error_Succeed)
- {
- if((Error == Error_AudioIN)||(Error == Error_AudioOut))
- {
- return Error;
- }
- else if (Error == Error_AllCamera)
- {
- capture_destroy(m_capture);
- m_capture = NULL;
- return Error;
- }
- else
- {
- SetAutoBright(Error);
- GetFunction()->SetTimer(1, this, 5000);
- if((Error == Error_OptCamera)&&((ePadtype == m_eDeviceType)||(eMobilePadType == m_eDeviceType)||(eDesk2SType == m_eDeviceType)||(eDesk1SType == m_eDeviceType)||(eDesk2SIntegratedType == m_eDeviceType)))
- {
- return Error_Succeed;
- }
- else
- {
- return Error;
- }
- }
- }
- else
- {
- SetAutoBright(Error);
- GetFunction()->SetTimer(1, this, 5000);
- return Error_Succeed;
- }
- }
- else
- {
- 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::StartCameraAndSetSysVar()
- {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("start camera");
- CheckAutoVideoConfig(&conf);
- ErrorCodeEnum Error = StartCamera();
- if (Error == Error_Succeed){
- SetCameraSysVar(CAMERA_NO_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_NO_ERROR");
- m_bStartCamera = TRUE;
- m_nCameraErrorCode = Error_Succeed;
- }
- else{
- if (Error == Error_EnvCamera){
- SetCameraSysVar(CAMERA_ENV_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_ENV_ERROR");
- m_bStartCamera = TRUE;
- m_nCameraErrorCode = Error_EnvCamera;
- }
- else if (Error == Error_OptCamera){
- SetCameraSysVar(CAMERA_OPT_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_OPT_ERROR");
- m_bStartCamera = TRUE;
- m_nCameraErrorCode = Error_OptCamera;
- }
- else if (Error == Error_AllCamera){
- SetCameraSysVar(CAMERA_BOTH_ERROR);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to CAMERA_BOTH_ERROR");
- m_nCameraErrorCode = Error_AllCamera;
- m_bStartCamera = FALSE;
- GetFunction()->SetUserDefineState(USER_MEDIA_ALLERROR);
- }
- else{
- SetCameraSysVar(Error);
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Camera State to Other Error");
- m_nCameraErrorCode = Error;
- m_bStartCamera = FALSE;
- }
- }
- }
- 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);
- }
- else {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("ReStartCamera %d,stop camera success!", nCamera);
- }
- Sleep(2000);
-
- 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
- {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("ReStartCamera,camera = %d,success!",nCamera);
- 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)
- {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("%s connected class = %s!", pszRemoteEntityName, pszClass);
- return new MediaServiceSession(this);
- }
- ErrorCodeEnum CMediaControllerEntity::ExternStartCamera()
- {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Extern start camera");
- CSimpleStringA strSessionId;
- CSmartPointer<IEntityFunction> Func = GetFunction();
- Func->GetSysVar("SessionID", strSessionId);
- if (!m_bStartCamera){
- StartCameraAndSetSysVar();
- if (m_bStartCamera) {
- LogEvent(Severity_Middle, EVENT_MOD_BEGIN_RECORD, strSessionId);
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_BEGIN_FACETRACKING, "extern start camera, start facetracking.");
- }
- }
- m_bExternControlCam = FALSE;
- return Error_Succeed;
- }
- ErrorCodeEnum CMediaControllerEntity::ExternStopCamera()
- {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("Extern stop camera");
- if (m_capture) {
- LogEvent(Severity_Middle, LOG_EVT_MEDIACONTROLLER_END_FACETRACKING, "extern stop camera, stop facetracking.");
- LogEvent(Severity_Middle, EVENT_MOD_END_RECORD,NULL);
- GetFunction()->KillTimer(1);
- capture_stop(m_capture);
- capture_destroy(m_capture);
- m_capture = NULL;
- }
- m_bStartCamera = FALSE;
- m_bExternControlCam = TRUE;
- return Error_Succeed;
- }
- 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<LPSTR>(arr2[i].GetData());
- }
- if (arr1.GetCount() > 4){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("remote record swift number is %s.", result[4]);
- snprintf(strSwiftName, MAX_PATH, "%s", result[4]);
- }
- delete tmp;
- tmp = NULL;
- }
- char strMicroName[MAX_PATH] = {0};
- CSimpleStringA strTempDir;
- if (Error_Succeed == GetFunction()->GetPath("Temp", strTempDir)){
- snprintf(strMicroName, MAX_PATH, "%s/local_micro_%s.pcm", strTempDir.GetData(), strSwiftName);
- }
- else{
- snprintf(strMicroName, MAX_PATH, "local_micro_%s.pcm", strSwiftName);
- }
-
- FILE *pRecord = fopen(strMicroName, "wb+");
- if (NULL != pRecord){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("fopen %s success.", strMicroName);
- if (Error_Succeed == StartSalesRecordAudioCapture(bRemoteRecord, eSingleWriteLocal, pRecord)){
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("begin remote sales record audio capture and record local PCM.");
- }
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("fopen %s failed.",strMicroName);
- }
- 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);
- }
-
- 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 (true == m_bRecordPCM){
- HandleSalesRecordPCMAudio(true, pszMessage, &frame);
- }
- else{
- if (Error_Succeed == StartSalesRecordAudioCapture(true)){
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("begin remote sales record audio capture.");
- }
- StartSpeakerAudioRender(0, &frame, NULL);
- }
- }
- ErrorCodeEnum CMediaControllerEntity::StartSpeakerAudioRender(int iQueue, audio_frame* pFrame, const char* strName)
- {
- auto rc = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("start speak audio render.");
- #ifdef RVC_OS_WIN
- 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.");
- }
- }
- #else
- //m_salesaudio_capture->rvc_audio->bputremote = true;
- #endif // RVC_OS_WIN
- return rc;
- }
- ErrorCodeEnum CMediaControllerEntity::StopSpeakerAudioRender()
- {
- auto rc = Error_Succeed;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("stop speak audio render.");
- #ifdef RVC_OS_WIN
- if (NULL != m_pAudioRenderObj) {
- m_pAudioRenderObj->StopRender();
- m_bHasStartSpeakerRender = false;
- }
- #else
- //m_salesaudio_capture->rvc_audio->bputremote = false;
- //salesrecord_speaker_audio_capture_stop(m_salesaudio_capture);
- #endif // RVC_OS_WIN
- return rc;
- }
- ErrorCodeEnum CMediaControllerEntity::SetSalesRecordAudioCaptureTransActionData(eRvcPCMTransType eType, void* pData)
- {
- auto rc = Error_Param;
- if (NULL != m_salesaudio_capture){
- if (NULL != m_salesaudio_capture->rvc_audio){
- m_salesaudio_capture->rvc_audio->eType = eType;
- m_salesaudio_capture->rvc_audio->pdata = pData;
- rc = Error_Succeed;
- }
- }
- return rc;
- }
- ErrorCodeEnum CMediaControllerEntity::ConnectAssistChannel()
- {
- if (NULL == m_pMediaControllerChannel) {
- m_pMediaControllerChannel = new ChannelMediaControllerClient(this);
- }
- ErrorCodeEnum Error = m_pMediaControllerChannel->Connect();
- if (Error != Error_Succeed) {
- m_pMediaControllerChannel = NULL;
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("ChannelMediaControllerClient connect fail!");
- return Error;
- }
- else {
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("ChannelMediaControllerClient connect success!");
- }
- if (Error_Succeed == Error)
- {
- ChannelService_BeginState_Sub Sub;
- Error = m_pMediaControllerChannel->BeginState(Sub);
- if (Error != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("BeginState biz channel failed!");
- m_pMediaControllerChannel->GetFunction()->CloseSession();
- m_pMediaControllerChannel = NULL;
- return Error;
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("BeginState biz channel success!");
- }
- }
- if (Error_Succeed == Error)
- {
- ChannelService_BeginRecv_Sub Sub;
- Sub.type = ACM_TYPE_DEVICE;
- Error = m_pMediaControllerChannel->BeginRecv(Sub);
- if (Error != Error_Succeed) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Begin BeginRecv ACM_TYPE_DEVICE failed!");
- m_pMediaControllerChannel->GetFunction()->CloseSession();
- m_pMediaControllerChannel = NULL;
- return Error;
- }
- else {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("Begin BeginRecv ACM_TYPE_DEVICE success!");
- }
- }
- return Error;
- }
- void CMediaControllerEntity::CheckAutoVideoConfig(capture_config_t* conf)
- {
- if (conf) {
- if (0 == conf->strVideoEnv.GetLength() || 0 == conf->strVideoOpt.GetLength()) {
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("AutoGetVideoDeviceName agin.");
- AutoGetVideoDeviceName(conf);
- }
- }
- }
- SelfChekerClient::SelfChekerClient( CMediaControllerEntity *pEntity ) : SelfCheckerService_ClientBase(pEntity)
- {
- }
- 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 )
- {
- LOG_FUNCTION();
- 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_GetVideoDeviceName(SpReqAnsContext<MediaService_GetVideoDeviceName_Req, MediaService_GetVideoDeviceName_Ans>::Pointer ctx)
- {
- CSimpleStringA frontcam = m_pEntity->strFrontCam;
- CSimpleStringA rearcam = m_pEntity->strRearCam;
- if (frontcam.GetLength() > 1 && rearcam.GetLength() > 1)
- {
- ctx->Ans.frontcam = frontcam;
- if (strstr((LPCTSTR)frontcam,";"))
- {
- ctx->Ans.frontcam = frontcam.SubString(0, frontcam.IndexOf(";"));
- }
- ctx->Ans.rearcam = rearcam;
- if (strstr((LPCTSTR)rearcam,";"))
- {
- ctx->Ans.rearcam = rearcam.SubString(0, rearcam.IndexOf(";"));
- }
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("get camera1 name:%s",m_pEntity->strFrontCam);
- DbgWithLink(LOG_LEVEL_DEBUG, LOG_TYPE_SYSTEM)("get camera2 name:%s",m_pEntity->strRearCam);
- }
- ctx->Answer(Error_Succeed);
- }
- void MediaServiceSession::Handle_StartCamera(SpOnewayCallContext<MediaService_StartCamera_Info>::Pointer ctx)
- {
- m_pEntity->ExternStartCamera();
- }
- void MediaServiceSession::Handle_StopCamera(SpOnewayCallContext<MediaService_StopCamera_Info>::Pointer ctx)
- {
- m_pEntity->ExternStopCamera();
- }
- void MediaServiceSession::Handle_StartEnvCamera(SpReqAnsContext<MediaService_StartEnvCamera_Req, MediaService_StartEnvCamera_Ans>::Pointer ctx)
- {
- ErrorCodeEnum Error = m_pEntity->StartEnvCamera();
- ctx->Ans.returncod = Error;
- ctx->Answer(Error);
- }
- void MediaServiceSession::Handle_StopEnvCamera(SpOnewayCallContext<MediaService_StopEnvCamera_Info>::Pointer ctx)
- {
- m_pEntity->StopEnvCamera();
- }
- void MediaServiceSession::Handle_StartSpeakerRender(SpOnewayCallContext<MediaService_StartSpeakerRender_Info>::Pointer ctx)
- {
- }
- void MediaServiceSession::Handle_StopSpeakerRender(SpOnewayCallContext<MediaService_StopSpeakerRender_Info>::Pointer ctx)
- {
- if (true == m_pEntity->m_bHasStartSpeakerRender){
- m_pEntity->StopSpeakerAudioRender();
- }
- else{
- DbgWithLink(LOG_LEVEL_INFO, LOG_TYPE_SYSTEM)("speaker audio render already stopped.");
- }
-
- }
- SP_BEGIN_ENTITY_MAP()
- SP_ENTITY(CMediaControllerEntity)
- SP_END_ENTITY_MAP()
|