使用OpenCV从图像上读取像素坐标位置

本文介绍了一个简单的OpenCV程序,用于实时显示图像上鼠标点击的坐标,并绘制矩形区域辅助跟踪框定位,适用于图像处理和目标跟踪任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

测试跟踪算法的时候,经常需要一个初始的跟踪框,手动标定这个位置就比较麻烦了

可以采用Matlab或者VS来读取对应点的坐标位置

在这说一个OpenCV的小程序,可以显示点击的坐标位置


原理很简单:出发鼠标响应的函数读取了点击的位置,然后直接显示在点击位置的旁边

#include <opencv/cv.h>  
#include <opencv/highgui.h>  
#include <stdio.h>  


IplImage* src = 0;   
IplImage* dst = 0;   
void on_mouse( int event, int x, int y, int flags, void* ustc)  
{  
	static CvPoint pre_pt = {-1,-1};  
	static CvPoint cur_pt = {-1,-1};  
	CvFont font;  
	cvInitFont(&font, CV_FONT_HERSHEY_SIMPLEX, 0.5, 0.5, 0, 1, CV_AA);  
	char temp[16];  
	  
	if( event == CV_EVENT_LBUTTONDOWN )  
	{  
	    cvCopy(dst,src);  
	    sprintf(temp,"(%d,%d)",x,y);  
	    pre_pt = cvPoint(x,y);  
	    cvPutText(src,temp, pre_pt, &font, cvScalar(0,0, 0, 255));  
	    cvCircle( src, pre_pt, 3,cvScalar(255,0,0,0) ,CV_FILLED, CV_AA, 0 );  
	    cvShowImage( "src", src );  
	    cvCopy(src,dst);  
	}  
	else if( event == CV_EVENT_MOUSEMOVE && !(flags & CV_EVENT_FLAG_LBUTTON))  
	{  
	    cvCopy(dst,src);  
	    sprintf(temp,"(%d,%d)",x,y);  
	    cur_pt = cvPoint(x,y);        
	    cvPutText(src,temp, cur_pt, &font, cvScalar(0,0, 0, 255));  
	    cvShowImage( "src", src );  
	}  
	else if( event == CV_EVENT_MOUSEMOVE && (flags & CV_EVENT_FLAG_LBUTTON))  
	{  
	    cvCopy(dst,src);  
	    sprintf(temp,"(%d,%d)",x,y);  
	    cur_pt = cvPoint(x,y);        
	    cvPutText(src,temp, cur_pt, &font, cvScalar(0,0, 0, 255));  
	    cvRectangle(src, pre_pt, cur_pt, cvScalar(0,255,0,0), 1, 8, 0 );  
	    cvShowImage( "src", src );  
	}  
	else if( event == CV_EVENT_LBUTTONUP )  
	{  
	    sprintf(temp,"(%d,%d)",x,y);  
	    cur_pt = cvPoint(x,y);        
	    cvPutText(src,temp, cur_pt, &font, cvScalar(0,0, 0, 255));  
	    cvCircle( src, cur_pt, 3,cvScalar(255,0,0,0) ,CV_FILLED, CV_AA, 0 );  
	    cvRectangle( src, pre_pt, cur_pt, cvScalar(0,255,0,0), 1, 8, 0 );  
	    cvShowImage( "src", src );  
	    cvCopy(src,dst);  
	}  
}  
int main()  
{  
	src=cvLoadImage("lena.jpg",1);  
	dst=cvCloneImage(src);  
	cvNamedWindow("src",1);  
	cvSetMouseCallback( "src", on_mouse, 0 );  
	  
	cvShowImage("src",src);  
	cvWaitKey(0);   
	cvDestroyAllWindows();  
	cvReleaseImage(&src);  
	cvReleaseImage(&dst);  
	return 0;  
}  


效果图如下:



评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值