From e15c4888f720b8781260b901ac82d058f8f7c3b5 Mon Sep 17 00:00:00 2001
From: chenshijun <csj_sky@126.com>
Date: 星期三, 27 三月 2019 14:34:37 +0800
Subject: [PATCH] 移植nsq到项目中,将最短最长时长的参数修改成nsq配置

---
 QiaoJiaSystem/VideoToImageMulth/main.cpp |  159 ++++++++++++++++++++++++++++++++---------------------
 1 files changed, 96 insertions(+), 63 deletions(-)

diff --git a/QiaoJiaSystem/VideoToImageMulth/main.cpp b/QiaoJiaSystem/VideoToImageMulth/main.cpp
index 0a29848..cc8e031 100644
--- a/QiaoJiaSystem/VideoToImageMulth/main.cpp
+++ b/QiaoJiaSystem/VideoToImageMulth/main.cpp
@@ -45,6 +45,12 @@
     return std::move(str_ip);
 }
 
+/***
+ * arg1 涓�-1鏃跺惎鐢╣b28181
+ * @param argc
+ * @param argv
+ * @return
+ */
 int main(int argc, char **argv) {
     std::cout << __DATE__ << " " << __TIME__ << std::endl;
     SAVE_APP_ARGS
@@ -53,82 +59,109 @@
     ENABLEGLOG(GET_STR_CONFIG("logPath").c_str());
 #endif
 
-    int gindx = atoi(argv[1]) % 2;
-    DBG(gindx);
-    appPref.setLongData("gpu.index", gindx);
-    appPref.setIntData("show.image", 0);
-
-    //todo
-    appPref.setIntData("CamStart", atoi(argv[1]));
-    appPref.setIntData("CamStep", atoi(argv[2]));
-    appPref.setIntData("RpcServerPort", atoi(argv[3]));
-
-    //#todo search from db
-    MysqlDBServerCfg mysqlDBServerCfg;
-    mysqlDBServerCfg.Host = getLocalIp();
-    mysqlDBServerCfg.Port = 3306;
-    mysqlDBServerCfg.UserName = "root";
-    mysqlDBServerCfg.Passwd = "123456";
-    mysqlDBServerCfg.DBName = "EGEyesForVSS";
-    mysqlDBServerCfg.DBConnCount = 5;
-
-    LDBTool ldbTool;
-    BaseSqliteDao::setLDBTool(&ldbTool);
-
-    //#todo search from db
-    Json::Value t_value;
-    {
-        LDBTool ldbTool;
-        BaseSqliteDao::setLDBTool(&ldbTool);
-        t_value = VssLocalSettingTblSqliteDao::instance()->findAllVssLocalSettingTblList();
-    }
-    if (t_value.size() == 1 && t_value["data"].size() > 1) {
+    if (argc < 6) {
         assert("t_value.size()");
     }
-    DBG(t_value["data"].begin()->toStyledString());
-    auto &t_cfg = *t_value["data"].begin();
-    GBServerCfg gbServerCfg;
-    gbServerCfg.SvrIp = t_cfg["ServerIp"].asString(); // 鍥芥爣鏈嶅姟鐨刬p鍦板潃  (鏈満鐨刬p鍦板潃)
-    gbServerCfg.SvrPort = atoi(t_cfg["ServerPort"].asString().c_str());// 7060; // 鍥芥爣鏈嶅姟鐩戝惉鐨勭鍙�
-    gbServerCfg.SvrPubID = t_cfg["ServerId"].asString();// "44120000002000000001"; // 鍥芥爣鏈嶅姟鍣ㄧ殑ID
-    gbServerCfg.bMD5Auth = false; // 鏄惁闇�瑕丮D5鍔犲瘑
-    gbServerCfg.UserName = t_cfg["UserAuthId"].asString();// "44120100002000000002"; // 鍥芥爣鏈嶅姟鐨勭敤鎴峰悕	(涓嬬骇璁惧娉ㄥ唽鐨勭敤鎴峰悕)
-    gbServerCfg.Passwd = t_cfg["Password"].asString();// "123456"; // 鍥芥爣鏈嶅姟鐨勫瘑鐮�	(涓嬬骇璁惧娉ㄥ唽鐨勫瘑鐮�)
-    gbServerCfg.SubScribeTime = 3600; // 璁㈤槄鏃堕棿  濡傛灉涓�0 琛ㄧず涓嶈闃�
+    {
+//            std::string rtmpAddr = appConfig.getStringProperty("srsAddr");
+//            std::string publish_basepath = rtmpAddr + "" ;
+//            appPref.setStringData("publish.basepath", publish_basepath);
+        appPref.setIntData("pulish.width", 640);
+        appPref.setIntData("pulish.height", 360);
+    }
+//    int arg1 = atoi(argv[1]);
+//
+//    int gindx = abs(arg1) % 2;
+//    int GB28181_Enable = arg1 < 0 ? 1 : 0;
+//
+//    DBG(gindx);
+//    appPref.setIntData("GB28181_Enable", GB28181_Enable);
+//    appPref.setIntData("gpu.index", gindx);
+//
+//
+//    //todo
+//    appPref.setIntData("CamStart", arg1);
+//    appPref.setIntData("CamStep", atoi(argv[2]));
+//    appPref.setIntData("RpcVTIMPort", atoi(argv[3]));
 
-    SpinLock spinLock;
+    appPref.setIntData("GB28181_Enable", atoi(argv[1]));
+    appPref.setIntData("gpu.index", atoi(argv[2]));
+    appPref.setIntData("CamStartNO", atoi(argv[3]));
+    appPref.setIntData("CamEndNO", atoi(argv[4]));
+    appPref.setIntData("RpcVTIMPort", atoi(argv[5]));//瑙﹀彂褰曞儚
 
-    bool running = false;
-    bool serinit = false;
-    auto func = [&] {
-        spinLock.lock();
-        GB28181Server m_gbs;
-        m_gbs.setMysqlConnParam(mysqlDBServerCfg);
-        m_gbs.setGBServerParam(gbServerCfg);
-        DBG("initServer start before");
-        running = m_gbs.initServer();
-        DBG("initServer start after");
+    appPref.setIntData("show.image", 0);
 
-        spinLock.unlock();
-        while (running) {
-            usleep(4000);
+    int GB28181_Enable = appPref.getIntData("GB28181_Enable");
+    if (GB28181_Enable) {
+        //#todo search from db
+        MysqlDBServerCfg mysqlDBServerCfg;
+        mysqlDBServerCfg.Host = getLocalIp();
+        mysqlDBServerCfg.Port = 3306;
+        mysqlDBServerCfg.UserName = "root";
+        mysqlDBServerCfg.Passwd = "123456";
+        mysqlDBServerCfg.DBName = "EGEyesForVSS";
+        mysqlDBServerCfg.DBConnCount = 5;
+
+        LDBTool ldbTool;
+        BaseSqliteDao::setLDBTool(&ldbTool);
+
+        //#todo search from db
+        Json::Value t_value;
+        {
+            LDBTool ldbTool;
+            BaseSqliteDao::setLDBTool(&ldbTool);
+            t_value = VssLocalSettingTblSqliteDao::instance()->findAllVssLocalSettingTblList();
         }
+        if (t_value.size() == 1 && t_value["data"].size() > 1) {
+            assert("t_value.size()");
+        }
+        DBG(t_value["data"].begin()->toStyledString());
+        auto &t_cfg = *t_value["data"].begin();
+        GBServerCfg gbServerCfg;
+        gbServerCfg.SvrIp = t_cfg["ServerIp"].asString(); // 鍥芥爣鏈嶅姟鐨刬p鍦板潃  (鏈満鐨刬p鍦板潃)
+        gbServerCfg.SvrPort = atoi(t_cfg["ServerPort"].asString().c_str());// 7060; // 鍥芥爣鏈嶅姟鐩戝惉鐨勭鍙�
+        gbServerCfg.SvrPubID = t_cfg["ServerId"].asString();// "44120000002000000001"; // 鍥芥爣鏈嶅姟鍣ㄧ殑ID
+        gbServerCfg.bMD5Auth = false; // 鏄惁闇�瑕丮D5鍔犲瘑
+        gbServerCfg.UserName = t_cfg["UserAuthId"].asString();// "44120100002000000002"; // 鍥芥爣鏈嶅姟鐨勭敤鎴峰悕	(涓嬬骇璁惧娉ㄥ唽鐨勭敤鎴峰悕)
+        gbServerCfg.Passwd = t_cfg["Password"].asString();// "123456"; // 鍥芥爣鏈嶅姟鐨勫瘑鐮�	(涓嬬骇璁惧娉ㄥ唽鐨勫瘑鐮�)
+        gbServerCfg.SubScribeTime = 3600; // 璁㈤槄鏃堕棿  濡傛灉涓�0 琛ㄧず涓嶈闃�
 
-    };
+        SpinLock spinLock;
 
-    std::thread thd(func);
+        bool running = false;
+        bool serinit = false;
+        auto func = [&] {
+            spinLock.lock();
+            GB28181Server m_gbs;
+            m_gbs.setMysqlConnParam(mysqlDBServerCfg);
+            m_gbs.setGBServerParam(gbServerCfg);
+            DBG("initServer start before");
+            running = true;
+            m_gbs.initServer();
+            DBG("initServer start after");
 
-    usleep(400);
-    //      ---------------------娴嬭瘯------------------------
-    spinLock.lock();
-    if (!running) {
-        ERR("running is false   <<   DB init error");
-        exit(0);
+            spinLock.unlock();
+            while (running) {
+                usleep(4000);
+            }
+        };
+
+        std::thread thd(func);
+        thd.detach();
+
+        usleep(400);
+        //      ---------------------娴嬭瘯------------------------
+        spinLock.lock();
+//    if (!running) {
+//        ERR("running is false   <<   DB init error");
+//        exit(0);
+//    }
     }
     DBG("test start");
 
     appPref.setStringData("user.loop.absolute.path", appConfig.getStringProperty("cutPath"));
-    IceRpcServer<RtspAnalysManager> server("RtspAnalysServer", appPref.getIntData("RpcServerPort"), "tcp");
+    IceRpcServer<RtspAnalysManager> server("RtspAnalysServer", appPref.getIntData("RpcVTIMPort"), "tcp");
     server.setMessageSizeMax(1024 * 1024 * 50);
     server.setPoolInitSize(1);
     server.setPoolMaxSize(1);

--
Gitblit v1.8.0