| | |
| | | void draw_detections_cv_v3(IplImage* show_img, detection *dets, int num, float thresh, char **names, image **alphabet, int classes, int ext_output); |
| | | void show_image_cv_ipl(IplImage *disp, const char *name); |
| | | image get_image_from_stream_resize(CvCapture *cap, int w, int h, int c, IplImage** in_img, int cpp_video_capture, int dont_close); |
| | | image get_image_from_stream_letterbox(CvCapture *cap, int w, int h, int c, IplImage** in_img, int cpp_video_capture, int dont_close); |
| | | int get_stream_fps(CvCapture *cap, int cpp_video_capture); |
| | | IplImage* in_img; |
| | | IplImage* det_img; |
| | | IplImage* show_img; |
| | | |
| | | static int flag_exit; |
| | | static int letter_box = 0; |
| | | |
| | | void *fetch_in_thread(void *ptr) |
| | | { |
| | | //in = get_image_from_stream(cap); |
| | | int dont_close_stream = 0; // set 1 if your IP-camera periodically turns off and turns on video-stream |
| | | in_s = get_image_from_stream_resize(cap, net.w, net.h, net.c, &in_img, cpp_video_capture, dont_close_stream); |
| | | if(letter_box) |
| | | in_s = get_image_from_stream_letterbox(cap, net.w, net.h, net.c, &in_img, cpp_video_capture, dont_close_stream); |
| | | else |
| | | in_s = get_image_from_stream_resize(cap, net.w, net.h, net.c, &in_img, cpp_video_capture, dont_close_stream); |
| | | if(!in_s.data){ |
| | | //error("Stream closed."); |
| | | printf("Stream closed.\n"); |
| | |
| | | |
| | | free_image(det_s); |
| | | |
| | | int letter = 0; |
| | | int nboxes = 0; |
| | | detection *dets = get_network_boxes(&net, det_s.w, det_s.h, demo_thresh, demo_thresh, 0, 1, &nboxes, letter); |
| | | detection *dets = NULL; |
| | | if (letter_box) |
| | | dets = get_network_boxes(&net, in_img->width, in_img->height, demo_thresh, demo_thresh, 0, 1, &nboxes, 1); // letter box |
| | | else |
| | | dets = get_network_boxes(&net, det_s.w, det_s.h, demo_thresh, demo_thresh, 0, 1, &nboxes, 0); // resized |
| | | //if (nms) do_nms_obj(dets, nboxes, l.classes, nms); // bad results |
| | | if (nms) do_nms_sort(dets, nboxes, l.classes, nms); |
| | | |
| | |
| | | return im; |
| | | } |
| | | |
| | | image get_image_from_stream_letterbox(CvCapture *cap, int w, int h, int c, IplImage** in_img, int cpp_video_capture, int dont_close) |
| | | { |
| | | c = c ? c : 3; |
| | | IplImage* src; |
| | | if (cpp_video_capture) { |
| | | static int once = 1; |
| | | if (once) { |
| | | once = 0; |
| | | do { |
| | | src = get_webcam_frame(cap); |
| | | if (!src) return make_empty_image(0, 0, 0); |
| | | } while (src->width < 1 || src->height < 1 || src->nChannels < 1); |
| | | printf("Video stream: %d x %d \n", src->width, src->height); |
| | | } |
| | | else |
| | | src = get_webcam_frame(cap); |
| | | } |
| | | else src = cvQueryFrame(cap); |
| | | |
| | | if (cpp_video_capture) |
| | | if (!wait_for_stream(cap, src, dont_close)) return make_empty_image(0, 0, 0); |
| | | *in_img = cvCreateImage(cvSize(src->width, src->height), IPL_DEPTH_8U, c); |
| | | cvResize(src, *in_img, CV_INTER_LINEAR); |
| | | image tmp = ipl_to_image(src); |
| | | image im = letterbox_image(tmp, w, h); |
| | | free_image(tmp); |
| | | if (cpp_video_capture) cvReleaseImage(&src); |
| | | if (c>1) rgbgr_image(im); |
| | | return im; |
| | | } |
| | | |
| | | int get_stream_fps(CvCapture *cap, int cpp_video_capture) |
| | | { |
| | | int fps = 25; |