From 93fcc2eb2db5038ca1944acde9f4c8b751aca930 Mon Sep 17 00:00:00 2001 From: xuxiuxi <554325746@qq.com> Date: 星期一, 04 三月 2019 16:27:14 +0800 Subject: [PATCH] add models, daos and controllers for tables. --- QiaoJiaSystem/StructureApp/AppPipeController.h | 79 +++++++++++++++++++++++++++------------ 1 files changed, 54 insertions(+), 25 deletions(-) diff --git a/QiaoJiaSystem/StructureApp/AppPipeController.h b/QiaoJiaSystem/StructureApp/AppPipeController.h index 648b766..2018f12 100644 --- a/QiaoJiaSystem/StructureApp/AppPipeController.h +++ b/QiaoJiaSystem/StructureApp/AppPipeController.h @@ -15,8 +15,26 @@ #include "PerimeterElement.h" #include "JudgmentRetrogradeTool.h" #include "NewRecordVideoElement.h" +#include "PersonElement.h" +#include "PerStaticElement.h" #include <jsoncpp/json/json.h> +#include "DBStruct.h" +#include "SaveVideoRpc.h" +class VideoCaptureElementNotDecoder : public ffmpeg::VideoCaptureElement { + using ffmpeg::VideoCaptureElement::VideoCaptureElement; +private: + virtual void timerFunc() override { + fireConnectors(); + } + + virtual void threadInitial() override {} + + virtual void threadClosing() override {} + +private: + bool m_decoderRet = {false}; +}; class AppPipeController : public PipeController { public: @@ -25,11 +43,14 @@ * @param folderPath 浠诲姟鏍圭洰褰曪紝鐢ㄤ簬鍋氬叡浜唴瀛榠d * @param json 鍙傛暟涓簉tsp娴佸湴鍧� sdk鏄惁鍚敤鐨勬爣璇� */ - AppPipeController(std::string folderPath, const Json::Value &json); + // AppPipeController(std::string folderPath, const Json::Value &json); + AppPipeController(std::string folderPath, const SdkRuleMap &ruleMap); - AppPipeController(int index, const Json::Value &json, bool RecordVideoEnable = false); + // AppPipeController(int index, const Json::Value &json, bool RecordVideoEnable = false); - AppPipeController(std::string camId, const Json::Value &json, bool RecordVideoEnable); + // AppPipeController(std::string camId, const Json::Value &json, bool RecordVideoEnable); + + AppPipeController(std::string camId, const SdkRuleMap &ruleMap, bool RecordVideoEnable); virtual ~AppPipeController(); @@ -41,12 +62,14 @@ void setfdfsClient(FastFdsWithLock *p_fdfsClient); + void setWeekRule(const std::map<int, std::vector<LActRuleWeekRecord>> &weekRuleMap); + private: void init(); private://Perimete PerimeterElement perimeterElement; - // TriggerElement peTriggerElement; + // TriggerElement peTriggerElement; void initPerimeter(); @@ -56,6 +79,8 @@ void initCrowd(); + void RecordVideo(); + private://KeepRight JudgmentRetrogradeTool leftJudgment; JudgmentRetrogradeTool rightJudgment; @@ -63,16 +88,30 @@ // TriggerElement leftTriggerElement; // TriggerElement rightTriggerElement; - void intKeepRight(); + void initKeepRight(); private: - ffmpeg::VideoCaptureElement videoCaptureElement; + PerStaticElement perStaticElement; + + void initPerStatic(); + +private://Perimete + PerimeterElement perHubElement; + // TriggerElement peTriggerElement; + + void initPerHub(); + +private: + SaveVideoRpcClient_t m_rpcClient; + VideoCaptureElementNotDecoder videoCaptureElement; +// ffmpeg::VideoCaptureElement videoCaptureElement; YoloRpcElement yoloRpcElement; FaceRpcElement faceRpcElement; FaceExtractElement faceExtractElement; ImageDrawElement imageDrawElement; - RecordVideoElement recordVideoElement; - NewRecordVideoElement newRecordVideoElement; +// RecordVideoElement recordVideoElement; +// NewRecordVideoElement newRecordVideoElement; + PersonElement personElement; int m_index; std::string m_camId; @@ -91,25 +130,15 @@ QDateTime m_dt; + std::map<int, std::vector<LActRuleWeekRecord>> m_weekRuleMap; + SdkRuleMap m_sdkRuleMap; + std::string m_localIp; + std::string getFullFileName(); - - void recordInit(int videoMin, int videoMax); - void setSdkTrigger(); - void doRecord(); - int fileMin; - int fileMax; - bool sdkTrigger; - int triggerDelay; - -#define RECORD_STOP (0) -#define RECORD_DOING (1) -#define RECORD_ENDING (2) - - int recordStatus; - int videoLength; - int recordDelay; - + std::mutex mutex; + bool m_bSetWH; + HiredisTool m_hiredisTool; }; -- Gitblit v1.8.0