opencv HSV找颜色,找轮廓用最小旋转矩形框出

#include <opencv2/opencv.hpp>
#include<iostream>
#include<string>
using namespace cv;
using namespace std;
//输入图像
Mat img;
//灰度值归一化
Mat bgr;
//HSV图像
Mat hsv;
//色相

string windowName = "src";
//输出图像的显示窗口
string dstName = "dst";
//输出图像
Mat dst;
Mat mask;
//回调函数
int main(int argc, char** argv)
{
    //输入图像
    img = imread("G:\\text.jpg");
    if (!img.data || img.channels() != 3)
        return -1;
    dst = Mat::zeros(img.size(), img.type());
    bgr = img.clone();
    //颜色空间转换
    cvtColor(bgr, hsv, CV_BGR2HSV);
    inRange(hsv, Scalar(35, 43, 46), Scalar(77, 255,255), mask);
    //掩模到原图的转换
    for (int r = 0; r < bgr.rows; r++)
    {
        for (int c = 0; c < bgr.cols; c++)
        {
            if (mask.at<uchar>(r, c) == 255)
            {
                dst.at<Vec3b>(r, c) = bgr.at<Vec3b>(r, c);
            }
        }
    }
    //定义输出图像的显示窗口
    namedWindow(dstName, WINDOW_GUI_EXPANDED);
    
    /*Mat gay;
    
    cvtColor(gay, gay, COLOR_RGB2GRAY);*/

    vector<vector<Point> > contours;
    vector<Vec4i> hierarchy;
    findContours(mask, contours, hierarchy, RETR_CCOMP, CHAIN_APPROX_SIMPLE);
    for (int i = 0; i < contours.size(); i++)
    {

        RotatedRect box = minAreaRect(contours[i]);
        Point2f vertex[4];
        box.points(vertex);
        for (int i = 0; i < 4; i++)
            line(img, vertex[i], vertex[(i + 1) % 4], Scalar(100, 200, 211), 2, LINE_AA);
    }
    imshow(windowName, img);
    imshow(dstName, dst);
    waitKey(0);
    return 0;
}

转载于:https://www.cnblogs.com/xingkongcanghai/p/11217634.html

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值