opencv截图工具

一、前言

在进行图像处理时,经常碰到要从一张完整的图像中截取某一部分图像保存成另一个图像,同时知道该图像是从原图像的哪里截取的。因此,这里提供该工具代码。

二、实现

以下代码实现用鼠标从输入图像截取图像,并以截取图像在输入图像中的矩形左上角和右下角的坐标命名。代码如下:

////////////////////////////////////
/*
 *  author: holamirai(@163.com)
*/
///////////////////////////////

#include"iostream"
#include"opencv2/opencv.hpp"
using namespace std;

void on_mouse(int Event,int x,int y,int flags,void* param );

IplImage *src = cvLoadImage("sg.jpg",1);
CvPoint point1,point2;
CvFont font = cvFont(2, 1);
int main(int argc, char* argv[])
{
    if (argc != 2)
    {
        printf("please input the source image`s name.\n");
        return 0;
    }
    cvNamedWindow("src",CV_WINDOW_AUTOSIZE);
    src = cvLoadImage(argv[1], CV_LOAD_IMAGE_UNCHANGED);
    if (!src)
    {
        printf("ERROR:\n can`t load image.\n");
        return 0;
    }
    cvShowImage("src",src);
    cvSetMouseCallback("src",on_mouse,NULL); 
    while (cvWaitKey(10) != 'q') { }

    return 0;
} 


void on_mouse(int Event,int x,int y,int flags,void* param )
{
    IplImage *copy = cvCloneImage(src);
    bool roi = false;
    if (Event == CV_EVENT_MOUSEMOVE)
    {
        char pt[15];
        sprintf_s(pt, "(%d,%d)", x, y);
        cvPutText(copy,pt, cvPoint(x, y), &font, CV_RGB(255, 0, 0));
        cvShowImage("src", copy);
    }
    if (Event == CV_EVENT_LBUTTONDOWN)
    {
        point1 = cvPoint(x, y);
        char pt[15];
        sprintf_s(pt, "(%d,%d)", x, y);
        cvPutText(copy, pt, cvPoint(x, y), &font, CV_RGB(255, 0, 0));
        cvShowImage("src", copy);
    }

    if (Event == CV_EVENT_MOUSEMOVE && flags == CV_EVENT_FLAG_LBUTTON)
    {
        char pt[15],point1_str[15];
        sprintf_s(pt, "(%d,%d)", x, y);
        sprintf_s(point1_str, "(%d,%d)", point1.x, point1.y);
        cvPutText(copy, point1_str, point1, &font, CV_RGB(255, 0, 0));
        cvPutText(copy, pt, cvPoint(x, y), &font, CV_RGB(255, 0, 0));
        cvRectangle(copy, point1, cvPoint(x, y),CV_RGB(0,255,0));
        cvShowImage("src", copy);
    }        
    if(Event == CV_EVENT_LBUTTONUP)
    {
        point2 = cvPoint(x,y);
        cvRectangle(copy, point1, point2, CV_RGB(0, 255, 0));
        roi = true;
    }

    if(roi)
    {
        // 以 ROI 区域坐标命名
        // 不允许从左到右,从上到下截图
        if (point2.x <= point1.x || point2.y <= point1.y)
        {
            printf("the second point is not big than the first point.\n");
            return;
        }
        char filename[40];
        sprintf(filename,"%d,%d--%d,%d.jpg",point1.x, point1.y, point2.x, point2.y);
        IplImage *dst = cvCreateImage(cvSize(point2.y - point1.y , point2.x - point1.x),src->depth,src->nChannels);
        cvSetImageROI(src,cvRect(point1.x,point1.y,(point2.y - point1.y) , (point2.x - point1.x) ) );
        cvCopy(src,dst);
        cvResetImageROI(src);
        cvNamedWindow("dst",CV_WINDOW_AUTOSIZE);
        cvShowImage("dst",dst);
        cvSaveImage(filename,dst);
    }
}

运行

运行结果如下图所示,在当前目录下将生产一个92,89–288,270.jpg文件:

这里写图片描述


转载请注明作者和出处:http://blog.csdn.net/holamirai,未经允许请勿用于商业用途。

OpenCV中的卡尺工具是用于测量图像中物体的长度、角度和轮廓等属性的工具。通过将一根已知长度的标尺放置在图像上,可以利用卡尺工具来测量其他物体的长度。在OpenCV中,可以使用cv2.findContours()函数识别物体的轮廓,然后使用cv2.arcLength()函数计算轮廓的长度。 使用OpenCV进行卡尺测量的步骤如下: 1. 读取图像,并转换为灰度图像。 2. 对图像进行二值化处理,以便更好地识别边缘。 3. 使用cv2.findContours()函数找到图像中的物体轮廓。 4. 对于每个轮廓,使用cv2.arcLength()函数计算轮廓的长度。 5. 进行单位转换,将像素长度转换为实际物体的单位长度。 6. 根据需要可以使用cv2.drawContours()函数绘制出物体的轮廓。 除了长度,卡尺工具也可以用于测量物体的角度。通过分析物体轮廓的形状,可以使用OpenCV的函数来计算物体的角度。可以使用cv2.minAreaRect()函数计算轮廓的最小外接矩形,然后使用cv2.boxPoints()函数获取矩形的四个顶点坐标,最后可以使用cv2.line()函数绘制出两条垂直于矩形的线段。通过计算这两条线段的夹角,即可得到物体的角度。 总而言之,OpenCV的卡尺工具提供了一种方便快捷的方法来测量图像中物体的长度、角度和轮廓等属性。其主要基于图像处理和计算机视觉的技术,可以应用于各种领域,如机器视觉、图像分析和测量等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值