| | |
| | | ,rec_(new rec) |
| | | ,logit_(false) |
| | | ,fps_(25) |
| | | ,file_finished_(false) |
| | | { |
| | | makeTheWorld(); |
| | | } |
| | |
| | | ,decoder_(nullptr) |
| | | ,rec_(new rec) |
| | | ,logit_(true) |
| | | ,fps_(25) |
| | | ,file_finished_(false) |
| | | { |
| | | makeTheWorld(); |
| | | logif::CreateLogger(logfile, true); |
| | |
| | | |
| | | fps_ = in->getFPS(); |
| | | |
| | | int wTime = 1000000.0 / in->getFPS() ; |
| | | if (fps_ < 1 || fps_ > 200){ |
| | | fps_ = 25; |
| | | } |
| | | |
| | | int wTime = 1000000.0 / fps_ ; |
| | | wTime >>= 1; |
| | | logIt("WAIT TIME PER FRAME: %d", wTime); |
| | | |
| | | init_worker(in.get()); |
| | | |
| | |
| | | int64_t a_id = id; |
| | | |
| | | bool exist = access(input_url_.c_str(), 0) == 0; |
| | | if (exist){ |
| | | wTime <<= 1; |
| | | } |
| | | |
| | | logIt("WAIT TIME PER FRAME: %d", wTime); |
| | | |
| | | while(!stop_stream_.load()){ |
| | | auto data(std::make_shared<CodedData>()); |
| | |
| | | } |
| | | |
| | | deinit_worker(); |
| | | if (exist) break; |
| | | if (exist) { |
| | | logIt("local file exist"); |
| | | file_finished_ = true; |
| | | break; |
| | | } |
| | | } |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | void Wrapper::GetPicDecoder(unsigned char **data, int *w, int *h, int *format, int *length, int64_t *id){ |
| | | if (file_finished_){ |
| | | *data = (unsigned char*)this; |
| | | *w = 1080; |
| | | *h = 720; |
| | | *format = 23; |
| | | *length = 12; |
| | | *id = -10802020; |
| | | return; |
| | | } |
| | | if (decoder_){ |
| | | decoder_->GetFrame(data, w, h, format, length, id); |
| | | } |
| | |
| | | std::function<void()> fn_rec_lazy_; |
| | | bool logit_; |
| | | int fps_; |
| | | bool file_finished_; |
| | | }; |
| | | |
| | | void *CreateEncoder(const int w, const int h, const int fps, const int br, |