我是靠谱客的博主 俏皮小蝴蝶,最近开发中收集的这篇文章主要介绍C++ OPENCV 获得两矩形的交集矩形,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

获得两个矩形的交集,该交集类型也是矩形

在这里插入图片描述
这种情况就范围交集的矩形,蓝色部分;

在这里插入图片描述
这种情况返回 cv::Rect(cv::Point(0,0),cv::Point(0,0) );

欢迎测试,提BUG;


/** @brief 获得两个矩形的交集
@param rect1; rect2 is lds range.
@output cv::Rect 交集
 */
cv::Rect get_IOU(cv::Rect rect1, cv::Rect rect2){


    // 横向和纵向距离
    cout <<"input " << rect1 << rect2 << endl;
    cv::Point center_rect1 = (rect1.tl()+rect1.br()) * 0.5;
    cv::Point center_rect2 = (rect2.tl()+rect2.br()) * 0.5;
    cout <<"input center" << rect1 << rect2 << endl;
    auto verti_dis = abs(center_rect1.x - center_rect2.x);
    auto horiz_dis = abs(center_rect1.y - center_rect2.y);
    // 高度和宽度之和的一半
    auto half_w = (rect1.width + rect2.width) / 2;
    auto half_y = (rect1.height + rect2.height) / 2;
    cout << verti_dis << " " << half_y << " " << verti_dis << " " << half_w << endl;

    if ( horiz_dis < half_y && verti_dis < half_w) {
        int x_tl , x_br, y_tl, y_br;

        if(rect1.tl().x > rect2.tl().x){
            if(rect1.br().x > rect2.br().x){
                x_tl = rect1.tl().x;
                x_br = rect2.br().x;
            } else{
                x_tl = rect1.tl().x;
                x_br = rect1.br().x;
            }
        } else{
            if(rect1.br().x > rect2.br().x){
                x_tl = rect2.tl().x;
                x_br = rect2.br().x;
            } else{
                x_tl = rect2.tl().x;
                x_br = rect1.br().x;
            }
        }


        if(rect1.tl().y > rect2.tl().y){
            if(rect1.br().y > rect2.br().y){
                y_tl = rect1.tl().y;
                y_br = rect2.br().y;
            } else{
                y_tl = rect1.tl().y;
                y_br = rect1.br().y;
            }
        } else{
            if(rect1.br().x > rect2.br().y){
                y_tl = rect2.tl().y;
                y_br = rect2.br().y;
            } else{
                y_tl = rect2.tl().y;
                y_br = rect1.br().y;
            }
        }

        cv::Point tl(x_tl, y_tl);
        cv::Point br(x_br, y_br);
        return cv::Rect(tl, br);

    }
    return cv::Rect(cv::Point(0,0),cv::Point(0,0) );


}

最后

以上就是俏皮小蝴蝶为你收集整理的C++ OPENCV 获得两矩形的交集矩形的全部内容,希望文章能够帮你解决C++ OPENCV 获得两矩形的交集矩形所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部