2017-12-16 18 views
1

roi = img (rect)와 같은 함수를 직접 작성하는 사람이 있습니까? 나는 하나를 시도했지만 그것이 반환하는 것은 큰 그림과 아무런 관계가 없다는 것이다. roi_img를 변경하면 큰 그림의 동일한 위치가 전혀 변경되지 않습니다! 기억에 관한 것 같아요? 아무도 도와 줄 수 없나요?opencv2에서 손으로 Roi 함수를 작성하는 방법

Mat GetRoi(const Mat &src_image, const Rect &rect){ 
Mat roi_img(rect.height,rect.width,CV_8UC3); 
uchar* pxvec = roi_img.ptr<uchar>(0); 
int i, j; 
int x = rect.y; 
int y = rect.x; 
for (i = 0; i < roi_img.rows; i++) 
{ 
    pxvec = roi_img.ptr<uchar>(i); 
    //三通道数据都在第一行依次排列,按照BGR顺序 
    y = rect.x; 
    for (j = 0; j < roi_img.cols*roi_img.channels();y++) 
    { 
     pxvec[j++] = src_image.at<Vec3b>(x,y)[0]; 
     pxvec[j++] = src_image.at<Vec3b>(x, y)[1]; 
     pxvec[j++] = src_image.at<Vec3b>(x, y)[2]; 
     } 
    x++; 
} 

return roi_img; 
} 

답변

1

이것은 OpenCV 소스에서 Mat::Mat(const Mat& m, const Rect& roi)의 구현입니다. 혼자서 다시 쓰고 싶다면 그것을 참조해야합니다.

Mat::Mat(const Mat& m, const Rect& roi) 
    : flags(m.flags), dims(2), rows(roi.height), cols(roi.width), 
    data(m.data + roi.y*m.step[0]), 
    datastart(m.datastart), dataend(m.dataend), datalimit(m.datalimit), 
    allocator(m.allocator), u(m.u), size(&rows) 
{ 
    CV_Assert(m.dims <= 2); 
    flags &= roi.width < m.cols ? ~CONTINUOUS_FLAG : -1; 
    flags |= roi.height == 1 ? CONTINUOUS_FLAG : 0; 

    size_t esz = CV_ELEM_SIZE(flags); 
    data += roi.x*esz; 
    CV_Assert(0 <= roi.x && 0 <= roi.width && roi.x + roi.width <= m.cols && 
       0 <= roi.y && 0 <= roi.height && roi.y + roi.height <= m.rows); 
    if(u) 
     CV_XADD(&u->refcount, 1); 
    if(roi.width < m.cols || roi.height < m.rows) 
     flags |= SUBMATRIX_FLAG; 

    step[0] = m.step[0]; step[1] = esz; 

    if(rows <= 0 || cols <= 0) 
    { 
     release(); 
     rows = cols = 0; 
    } 
} 


그리고 솔직히 말해서, 그냥 ROI의 정의 된 상위,하지에, 작업의 모든 종류의 연결을 더 관련 :

MatExpr MatExpr::operator()(const Rect& roi) const

MatExpr MatExpr::operator()(const Rect& roi) const 
{ 
    MatExpr e; 
    op->roi(*this, Range(roi.y, roi.y + roi.height), Range(roi.x, roi.x + roi.width), e); 
    return e; 
} 

MatOp::roi

void MatOp::roi(const MatExpr& expr, const Range& rowRange, const Range& colRange, MatExpr& e) const 
{ 
    if(elementWise(expr)) 
    { 
     e = MatExpr(expr.op, expr.flags, Mat(), Mat(), Mat(), 
        expr.alpha, expr.beta, expr.s); 
     if(expr.a.data) 
      e.a = expr.a(rowRange, colRange); 
     if(expr.b.data) 
      e.b = expr.b(rowRange, colRange); 
     if(expr.c.data) 
      e.c = expr.c(rowRange, colRange); 
    } 
    else 
    { 
     Mat m; 
     expr.op->assign(expr, m); 
     e = MatExpr(&g_MatOp_Identity, 0, m(rowRange, colRange), Mat(), Mat()); 
    } 
} 

老 铁, 为什么想不开 要 手 寫 呢?

想 完备 实现 的 话, 可是 一个 烧 脑 的 任务.

刚把 碟