<< " --visualize | -v[delay_ms]\n"
<< " --output | -o <output.txt>\n"
<< " --debug | -d\n"
- << " --fit | -f[WxH]\n";
+ << " --fit | -f[W[xH]]\n";
exit(0);
break;
case 'o':
break;
case 'f':
if (!optarg) {
- fit_size_x = fit_size_y = 128;
+ fit_size_x = fit_size_y = 0;
} else {
char tail;
if (sscanf(optarg, "%d%c", &fit_size_x, &tail) == 1) {
return 1;
}
}
- int min_size = 2 * tracker.p_cell_size;
- if (fit_size_x < min_size || fit_size_x < min_size) {
- fprintf(stderr, "Fit size %dx%d too small. Minimum is %dx%d.\n",
- fit_size_x, fit_size_y, min_size, min_size);
- return 1;
- }
break;
}
}
std::cout << std::endl;
if (visualize_delay >= 0) {
- cv::rectangle(image, bb_rect, CV_RGB(0,255,0), 2);
+ cv::Point pt(bb.cx, bb.cy);
+ cv::Size size(bb.w, bb.h);
+ cv::RotatedRect rotatedRectangle(pt, size, bb.a);
+
+ cv::Point2f vertices[4];
+ rotatedRectangle.points(vertices);
+
+ for (int i = 0; i < 4; i++)
+ cv::line(image, vertices[i], vertices[(i + 1) % 4], cv::Scalar(0, 255, 0), 2);
cv::imshow("output", image);
int ret = cv::waitKey(visualize_delay);
if (visualize_delay > 0 && ret != -1 && ret < 128)