int angle, int arc_start, int arc_end,
const void* color, int thickness, int line_type )
{
- CV_Assert( axes.width >= 0 && axes.height >= 0 );
+ axes.width = std::abs(axes.width), axes.height = std::abs(axes.height);
int delta = (std::max(axes.width,axes.height)+(XY_ONE>>1))>>XY_SHIFT;
delta = delta < 3 ? 90 : delta < 10 ? 30 : delta < 15 ? 18 : 5;
if( windowIn.height <= 0 || windowIn.width <= 0 )
CV_Error( CV_StsBadArg, "Input window has non-positive sizes" );
- if( windowIn.x < 0 || windowIn.x + windowIn.width > mat->cols ||
- windowIn.y < 0 || windowIn.y + windowIn.height > mat->rows )
- CV_Error( CV_StsBadArg, "Initial window is not inside the image ROI" );
+ windowIn = cv::Rect(windowIn) & cv::Rect(0, 0, mat->cols, mat->rows);
criteria = cvCheckTermCriteria( criteria, 1., 100 );
eps = cvRound( criteria.epsilon * criteria.epsilon );
{
int dx, dy, nx, ny;
double inv_m00;
-
+ cur_rect = cv::Rect(cur_rect) & cv::Rect(0, 0, mat->cols, mat->rows);
+
cvGetSubRect( mat, &cur_win, cur_rect );
cvMoments( &cur_win, &moments );