1 sprintf(imagepath, "/mnt/md/test/mtcnn/images/%d.jpg", i); 4 printf("imagepath:%s\n", imagepath); 5 cv::Mat cv_img = cv::imread(imagepath, 3); 6 if (cv_img.empty()) 7 { 8 fprintf(stderr, "cv::imread %s failed\n", imagepath); 9 return -1; 10 } 11 printf("cv_img.rows:%d\n", cv_img.rows); 12 printf("cv_img.cols:%d\n", cv_img.cols); 13 14 cv::Mat cv_yuv; 15 cv::cvtColor(cv_img, cv_yuv, COLOR_BGR2YUV_I420); 16 pFrame = (unsigned char *)malloc((cv_img.rows)*(cv_img.cols)*3/2); 17 if(NULL == pFrame) 18 { 19 printf("malloc pFrame memory error\n"); 20 } 21 memset(pFrame, 0,(cv_img.rows)*(cv_img.cols)*3/2); 22 memcpy(pFrame, cv_yuv.data, (cv_img.rows)*(cv_img.cols)*3/2); 23 24 //如果想得到YUV图片,可以写下来。 25 fp = fopen("./a.yuv", "wb+"); 26 if(NULL == fp) 27 { 28 printf("file open error\n"); 29 return -1; 30 } 31 fwrite(pFrame, 1, (cv_img.rows)*(cv_img.cols)*3/2, fp);