VS+opencv实现鼠标移动图片

基于控制台应用程序+opencv,实现点击鼠标左键,可以拖动图片以显示感兴趣区域

#include <opencv2/highgui/highgui.hpp>

//#include <iostream>
//using namespace std;
using namespace cv;

int win_width=1400,win_height=700;
Mat image,win_image;       //申明全局变量
Rect rect_win,rect_img;

void moveImage()//实现移动图像
{
 Mat image_ROI=image(rect_img);  // 定义源图像感兴趣区域ROI(需要显示的区域)
 image_ROI.convertTo(win_image,image_ROI.type());  // image_ROI 复制到 win_image
 ////也可以直接用 Mat win_image=image(rect_img); //但是很卡 Why?
 imshow("拼接结果",win_image);
}

void on_mouse( int event, int x, int y, int flags, void* ustc) //int x,int y,代表鼠标位于窗口的(x,y)坐标位置,窗口左上角默认为原点,向右为x轴,向下为y轴
{
  // static声明静态局部变量,值在函数调用结束后不消失而保留原值,
  //即其占用的存储单元不释放,在下次该函数调用时,该变量保留上一次函数调用结束时的值
  static Point p0;
  static int xrect_img;  //左键按下时,窗口显示图像左上角在源图像中x、y
  static int yrect_img;
 if(event==CV_EVENT_LBUTTONDOWN)
 {
  p0=Point(x,y); //获取鼠标左键按下时的起始点
   xrect_img=rect_img.x;
   yrect_img=rect_img.y;
 }
 if(event==CV_EVENT_MOUSEMOVE&& (flags & CV_EVENT_LBUTTONDOWN)) //左键按下,鼠标移动时
 {
   int dx=x-p0.x;
   int dy=y-p0.y;
   if(x>=0 && x<=win_width-1 && y>=0 && y<=win_height-1) //判断鼠标是否在窗口图像区域内
   {
    rect_img=Rect(xrect_img-dx,yrect_img-dy,rect_img.width,rect_img.height);  //窗口显示图像移动dx、dy(相对于鼠标左键按下时)
    if(rect_img.x<0)
    {
     rect_img.x=0;
    }
    if(rect_img.y<0)
    {
     rect_img.y=0;
    }
    if(rect_img.x > image.cols-rect_img.width-1)
    {
     rect_img.x=image.cols-rect_img.width-1;
    }
    if(rect_img.y > image.rows - rect_img.height-1)
    {
     rect_img.y=image.rows - rect_img.height-1;
    } 

    moveImage();
   }
 }
}

void main()
{
 image=imread("im.jpg");
 //int win_width=1400,win_height=700;     //固定窗口的大小1400 x 700
 //rect_win=Rect(0,0,win_width,win_height);   //窗口显示矩形区
 rect_img=Rect(0,0,win_width,win_height);   //窗口图像对应的矩形区
 //win_image.create(win_height,win_width,image.type());
 //Mat tmp=image(rect_win);  // 窗口图像对应于源图像中的区域
 //tmp.convertTo(win_image,tmp.type());  //复制一个图像的ROI到另外一个图像的指定区域
 Mat win_image=image(rect_img);
 namedWindow("拼接结果", 1);
 imshow("拼接结果",win_image);

 setMouseCallback("拼接结果", on_mouse);
 waitKey();
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • OpenCV鼠标绘制矩形和截取矩形区域图像

    本文实例为大家分享了OpenCV鼠标绘制截取矩形区域图像的具体代码,供大家参考,具体内容如下 在opencv中利用鼠标绘制矩形,代码如下: #include <cv.h> #include <highgui.h> #include <stdio.h> #pragma comment( lib, "cv.lib" ) #pragma comment( lib, "cxcore.lib" ) #pragma comment( lib,

  • OpenCV获取鼠标左键点击位置图像的像素值

    本文实现功能:利用opencv获取鼠标左键点击位置图像的像素值(RGB像) vs2015+opencv3.1 #include<opencv2\opencv.hpp> #include<iostream> using namespace std; using namespace cv; void on_mouse(int EVENT, int x, int y, int flags, void* userdata); void main() { namedWindow("

  • OpenCV使用鼠标响应裁剪图像

    给定一幅图像,将其中的某一部分兴趣区域裁剪出来,这在PS中很好实现,但是使用openCV如何实现呢?因此本文主要介绍openCV使用鼠标响应来裁剪图像: 一.代码部分: #include "stdafx.h" #include "cv.h" #include <highgui.h> #include <stdio.h> IplImage* org = 0; IplImage* img = 0; IplImage* tmp = 0; IplIm

  • VS+opencv实现鼠标移动图片

    基于控制台应用程序+opencv,实现点击鼠标左键,可以拖动图片以显示感兴趣区域 #include <opencv2/highgui/highgui.hpp> //#include <iostream> //using namespace std; using namespace cv; int win_width=1400,win_height=700; Mat image,win_image; //申明全局变量 Rect rect_win,rect_img; void move

  • Opencv使用鼠标任意形状的抠图

    本文实例为大家分享了Opencv使用鼠标任意形状抠图的具体代码,供大家参考,具体内容如下 主要的方法思路是:首先利用鼠标在图上画任意形状,利用掩码将任意形状抠出来 主要难点是怎么填充,因为鼠标在画线的时候,滑动越快,点是不连续的,利用floodFill和drawContours都是没有办法进行填充的,从另一个方面想,一个面是由很多个点组成的,虽然鼠标滑动保存下来的就是一系列点,可以利用这一系列点构成一个面,利用面的性质进行填充就比较简单了. 一.首先使用鼠标点击事件,鼠标点击事件的函数为: vo

  • Python OpenCV实现鼠标画框效果

    使用Python+OpenCV实现鼠标画框的代码,供大家参考,具体内容如下 # -*-coding: utf-8 -*- """ @Project: IntelligentManufacture @File : user_interaction.py @Author : panjq @E-mail : pan_jinquan@163.com @Date : 2019-02-21 15:03:18 """ # -*- coding: utf-8 -

  • jQuery实现的感应鼠标悬停图片色彩渐显效果

    本文实例讲述了jQuery实现的感应鼠标悬停图片色彩渐显效果.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/

  • js实现鼠标感应图片展示的方法

    本文实例讲述了js实现鼠标感应图片展示的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml&qu

  • js实现鼠标悬停图片上时滚动文字说明的方法

    本文实例讲述了js实现鼠标悬停图片上时滚动文字说明的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <html> <title>js实现鼠标悬停图片上时的滚动文字说明</title> <body> <SCRIPT LANGUAGE="JavaScript"> <!-- Begin function showtip2(current,e,text){   if (document.all&&a

  • js实现鼠标触发图片抖动效果的方法

    本文实例讲述了js实现鼠标触发图片抖动效果的方法.分享给大家供大家参考.具体实现方法如下: 复制代码 代码如下: <html> <head> <title>鼠标触发图片抖动效果</title> <style> .shakeimage{ position:relative } </style> <script language="JavaScript1.2"> //configure shake degr

  • 感应鼠标的图片遮罩动画效果

    感应鼠标的图片遮罩动画效果 html, body, div,ul, li { margin: 0; padding: 0; } div.examples_body { width: 750px; margin: 0px auto; clear: both; overflow: hidden; } .bannerHolder { width: 726px; margin: 20px 0 15px 0; padding: 20px 10px 20px 10px; background-color:

  • JQuery实现鼠标移动图片显示描述层的方法

    本文实例讲述了JQuery实现鼠标移动图片显示描述层的方法.分享给大家供大家参考.具体如下: 这里可结合 JQuery easing 的动画来配合使用. 主要代码如下: $(".item").hover( function() { //$(this).children("img").stop().animate({opacity: 0.8}, 700, "easeInSine"); $(this).children("div.title

  • jQuery实现鼠标经过图片变亮其他变暗效果

    以下是完整源代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv=&quo

随机推荐