将图像中感兴趣区域提取出来,非感兴趣区域设置为黑色


#include <opencv2/opencv.hpp>
#include <math.h>
using namespace cv;
Mat mask, img1, img2;
//全局变量
Mat g_ImageROI;
Mat g_ImageROI1;
Rect g_rectangle;
Point g_startPoint;
Mat g_srcImage;
RNG g_rng(12345);
bool click_flag = 0;

void onMouse(int event, int x, int y, int flags, void* param)
{
    //鼠标移动事件
    if (event == EVENT_MOUSEMOVE)
    {
        if (click_flag == 1)
        {
            g_rectangle.x = MIN(g_startPoint.x, x);
            g_rectangle.y = MIN(g_startPoint.y, y);
            g_rectangle.width = abs(x - g_startPoint.x);
            g_rectangle.height = abs(y - g_startPoint.y);
            g_rectangle = g_rectangle & Rect(0, 0, g_srcImage.cols, g_srcImage.rows);
        }
    }

    //左键按下事件
    if (event == EVENT_LBUTTONDOWN)
    {
        g_startPoint.x = x;
        g_startPoint.y = y;
        click_flag = 1;
    }

    //左键弹起事件
    if (event == EVENT_LBUTTONUP)
    {
        click_flag = 0;

        //显示感兴趣区域的图片
        g_ImageROI = g_srcImage(g_rectangle);
        //g_ImageROI1 = g_srcImage(g_rectangle);
        //namedWindow("截取的图片", 0);
        //imshow("截取的图片", g_ImageROI);
        mask = Mat::zeros(g_srcImage.size(), CV_8UC1);
        mask(g_rectangle).setTo(255);
        img1 = g_srcImage(g_rectangle);
        g_srcImage.copyTo(img2, mask);

        cv::Mat img_gray{};

        cv::cvtColor(img2, img_gray, cv::COLOR_RGB2GRAY);

        //使用高斯滤波
        cv::GaussianBlur(img_gray, img_gray, cv::Size(3, 3), 0, 0, cv::BORDER_DEFAULT);
        //使用canny算子
        double threshold1 = 120.0;
        double threshold2 = 55.0;
        int apertureSize = 3;
        cv::Canny(img_gray, img_gray, threshold1, threshold2, apertureSize);

        //imshow("mask", mask);
        //imshow("img2", img2);
        cv::imshow("Canny", img_gray);
        
    }

}
void main()
{


    namedWindow("摄像头", 0);
    setMouseCallback("摄像头", onMouse);


    g_srcImage = imread("0001.jpg");

    //画矩形,边框随机颜色
    rectangle(g_srcImage, g_rectangle, cv::Scalar(g_rng.uniform(0, 255), g_rng.uniform(0, 255), g_rng.uniform(0, 255)), 3);


    imshow("摄像头", g_srcImage);
    waitKey(0);
}

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要将提取感兴趣区域保存为图片进行处理,你可以将感兴趣区域保存为临时文件,并在处理完成后再进行删除。以下是一个示例代码: ```matlab % 读取图像 img = imread('image.png'); % 在图像上选择感兴趣区域 roi = imrect; position = wait(roi); % 提取感兴趣区域 x = round(position(1)); y = round(position(2)); width = round(position(3)); height = round(position(4)); roi_img = img(y:y+height-1, x:x+width-1, :); % 保存感兴趣区域为临时文件 temp_filename = 'temp_roi_image.png'; imwrite(roi_img, temp_filename); % 对感兴趣区域进行处理 % 在这里添加你的处理代码 % 可以使用imread函数读取temp_filename进行处理 % 处理完成后,删除临时文件 delete(temp_filename); ``` 在这个示例,我们首先读取图像。然后使用imrect函数在图像上选择感兴趣区域,这会弹出一个可调整大小和位的矩形框。你可以通过拖动和调整矩形框来选择感兴趣区域。当你完成选择后,关闭矩形框。 接下来,我们根据所选区域在原始图像提取感兴趣区域。这里使用了位信息来确定所选区域的坐标和尺寸。 然后,我们将感兴趣区域保存为临时文件,使用imwrite函数将其写入'temp_roi_image.png'文件。你可以根据需要修改保存的文件名和格式。 在处理完成后,你可以根据需要进行图像处理操作。如果需要使用已保存的感兴趣区域进行处理,可以使用imread函数读取临时文件进行操作。 最后,处理完成后,使用delete函数删除临时文件。这样可以确保在处理过程不会留下不需要的临时文件。 请注意,你可以根据需要修改代码来适应你的具体处理需求,并根据需要进行其他图像处理操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值