1. #include "cv.h"
  2. #include "highgui.h"
  3. bool check_line_state=false;
  4. IplImage* workImg;
  5. IplImage* imgshow;
  6. CvRect ROI_rect;
  7. void on_mouse4(int event, int x,int y,int flags,void* param)
  8. {
  9. int thickness=2;
  10. CvPoint p1,p2;
  11. if(event==CV_EVENT_LBUTTONDOWN)
  12. {
  13. //当前鼠标位置(x,y)
  14. ROI_rect.x=x;
  15. ROI_rect.y=y;
  16. check_line_state=true;
  17. }
  18. else if(check_line_state&&event==CV_EVENT_MOUSEMOVE)//鼠标状态
  19. {
  20. cvCopy(workImg,imgshow);//这一步很重要,不断更新显示图像,不然画出的图像如图2所示
  21. p1=cvPoint(ROI_rect.x,ROI_rect.y);
  22. p2=cvPoint(x,y);
  23. cvRectangle(imgshow,p1,p2,CV_RGB(0,255,150),thickness,CV_AA,0);
  24. cvShowImage("image",imgshow);
  25. }
  26. else if(check_line_state&&event==CV_EVENT_LBUTTONUP)
  27. {
  28. check_line_state=false;
  29. cvWaitKey(20);
  30. }
  31. }
  32. int main()
  33. {
  34. workImg=cvLoadImage("D:/Demo.jpg",1);
  35. imgshow=cvCreateImage(cvSize(workImg->width,workImg->height),workImg->depth,workImg->nChannels);
  36. cvCopy(workImg,imgshow);
  37. //cvFlip(imgshow);
  38. ROI_rect.x=ROI_rect.y=0;
  39. cvNamedWindow("image",CV_WINDOW_AUTOSIZE);
  40. cvShowImage("image",imgshow);
  41. cvSetMouseCallback("image",on_mouse4);
  42. cvWaitKey();
  43. cvDestroyWindow("image");
  44. }

图1:                                                                                               图2:

   

from: http://blog.csdn.net/yangtrees/article/details/7573919

学习OpenCV——鼠标事件(画框)的更多相关文章

  1. opencv鼠标事件

    #include <opencv2\opencv.hpp> using namespace cv; struct mouse_para { cv::Mat org; cv::Mat img ...

  2. 深入学习jQuery鼠标事件

    × 目录 [1]类型 [2]写法 [3]合成事件[4]鼠标按键[5]修改键[6]坐标位置 前面的话 鼠标事件是DOM事件中最常用的事件,jQuery对鼠标事件进行了封装和扩展.本文将详细介绍jQuer ...

  3. python学习之鼠标事件&键盘事件

    driver.maximize_window()   浏览器最大化 ActionChains类与输入事件 1:from selenium.webdriver.common.action_chains ...

  4. opencv-python教程学习系列5-处理鼠标事件

    前言 opencv-python教程学习系列记录学习python-opencv过程的点滴,本文主要介绍opencv-python处理鼠标事件,坚持学习,共同进步. 系列教程参照OpenCV-Pytho ...

  5. Opencv step by step - 鼠标事件

    鼠标事件有下面几种(没有滚轮事件,比较遗憾): #define CV_EVENT_MOUSEMOVE 0 滑动 #define CV_EVENT_LBUTTONDOWN 1 左键点击 #define ...

  6. Python3+Selenium3+webdriver学习笔记14(等待判断 鼠标事件 )

    !/usr/bin/env python -*- coding:utf-8 -*-'''Selenium3+webdriver学习笔记14(等待判断 鼠标事件 )'''from selenium im ...

  7. Opencv函数setMouseCallback鼠标事件响应

    用户通过鼠标对图像视窗最常见的操作有: 1. 左键单击按下 2. 左键单击抬起 3. 左键按下拖动 4. 鼠标指针位置移动 单次单击操作响应事件及顺序 Opencv中setMouseCallback( ...

  8. opencv入门系列教学(四)处理鼠标事件

    一.鼠标事件的简单演示 opencv中的鼠标事件,值得是任何与鼠标相关的任何事物,例如左键按下,左键按下,左键双击等.我们先来看看鼠标事件有哪些,在python中执行下面代码: import cv2 ...

  9. JavaScript学习笔记3之 数组 & arguments(参数对象)& 数字和字符串转换 & innerText/innerHTML & 鼠标事件

    一.Array数组 1.数组初始化(Array属于对象类型) /*关于数组的初始化*/ //1.创建 Array 对象--方法1: var arr1=[]; arr1[0]='aa';//给数组元素赋 ...

随机推荐

  1. mysql通过data目录恢复数据库

    mysql通过data目录恢复数据库 阅读:次   时间:2010-03-24 06:53:30   字体:[大 中 小]     重装系统后,MySQL服务没有了,但是数据库的文件还在,这个时候我想 ...

  2. Introduction to Structured Data

    https://developers.google.com/search/docs/guides/intro-structured-data Structured data refers to kin ...

  3. url如何传递参数

    $(document).ready(function() { var name=getQueryString('minename'); if (name != null && name ...

  4. 【ECshop错误集锦】解决ECShop发送邮件提示:Error: need RCPT command

    ECShop发送邮件报错Error: need RCPT command,经检测,邮件服务器返回的真实错误是501 mail from address must be same as authoriz ...

  5. The Producer-Consumer Relationship Version 2

    Listing -. The Producer-Consumer Relationship Version public class PC { public static void main(Stri ...

  6. .NET同页面内用户控件与父页面以及控件之间方法调用

    用户控件调用父页面的方法: //获得父页面 Page p =this.Parent.Page; Type pageType = p.GetType(); //父页面的方法名 MethodInfo mi ...

  7. hiveserver2以及beeline客户端的使用

    一:开启服务 1.启动前端的hiveserver2 按住ctrl+c就可以结束这个服务. 2.怎么知道已经开启的服务 如果进程在后台,可以查出来,kill这些进程. 3.后端开启服务 二:beelin ...

  8. input[type=checkbox]

    一个问题,今天用jquery-1.11.3.min.js时遇到的关于input复选框的问题. 类似于以下代码: <ul class="demo">  <li> ...

  9. HTML5音频,视频播放

    1.此方法可支持多种浏览器 <audio controls="controls"> <source src="1.mp3" ></ ...

  10. JS实现一个简单的计算器

    使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除.效果如上: 第一步: 创建构建运算函数count(). 第二步: 获取两个输入框中的值和获取选择 ...