video analysis2.0拆分,ffmpeg封装go接口库
zhangmeng
2020-07-24 f93ee1a42e8c47e472332287b7350b66a6b0fa11
csrc/wrapper.cpp
@@ -56,7 +56,7 @@
    ,logit_(false)
    ,fps_(25)
    ,file_finished_(false)
    ,min_duration_(60)
    ,min_duration_(0)
    {
        makeTheWorld();
    }
@@ -77,7 +77,7 @@
    ,logit_(true)
    ,fps_(25)
    ,file_finished_(false)
    ,min_duration_(60)
    ,min_duration_(0)
    {
        makeTheWorld();
        logif::CreateLogger(logfile, true);
@@ -193,7 +193,8 @@
    void Wrapper::run_stream_thread(){
        
        int64_t rebootime = -1;
        int64_t file_rebootime = 0;
        int64_t file_frame = 0;
        while(!stop_stream_.load()){
            auto in = init_reader(input_url_.c_str());
@@ -203,8 +204,6 @@
                sleep(2);
                continue;
            }
            rebootime++;
            fps_ = in->getFPS();
            
@@ -223,9 +222,9 @@
            bool exist = access(input_url_.c_str(), 0) == 0;
            if (exist){
                wTime <<= 1;
                wTime += wTime/2;
                file_rebootime++;
            }
            int64_t file_frame = 0;
            logIt("WAIT TIME PER FRAME: %d", wTime);
@@ -260,24 +259,29 @@
                id++;
                //本地文件太快sleep一下
                if (exist){
                    usleep(wTime);
                if (exist && in->isVideoPkt(&data->getAVPacket())){
                    // 记录解码的文件有多少帧
                    file_frame++;
                    usleep(wTime);
                }
            }
            deinit_worker();
            if (exist) {
                if (file_frame == 0 && rebootime > 3){
                    file_finished_ = true;
                    break;
                }
                if (file_frame < min_duration_ * fps_){
                // 三次一帧都没解出来,退出
                if (file_frame == 0 && file_rebootime < 3){
                    logIt("libcffmpeg.so-> run %lld time, current frames %lld", file_rebootime, file_frame);
                    continue;
                }
                logIt("libcffmpeg.so-> local file %s run %lld time, all frames %lld", input_url_.c_str(), rebootime, file_frame);
                // 最小需要解出多少帧
                if (file_frame < min_duration_ * fps_){
                    logIt("libcffmpeg.so-> run %lld time, current frames %lld, mind %d, fps: %d",
                     file_rebootime, file_frame, min_duration_, fps_);
                    continue;
                }
                logIt("libcffmpeg.so-> local file %s run %lld time, all frames %lld, mind %d, fps: %d",
                    input_url_.c_str(), file_rebootime, file_frame, min_duration_, fps_);
                file_finished_ = true;
                break;
            }