学习OpenCV——鼠标事件&亮暗化精度最高(与距离反比)&批处理

原创 2012年03月26日 20:06:44
#include "stdafx.h"
#include <cv.h>
#include <highgui.h>
#include <stdio.h>
#include <math.h>
#include "windows.h"
#include <vector>
#include <string>
#include "iostream"

using namespace std;
typedef vector<string> file_lists;
template<typename T>T sqr(T x){return x*x;};

CvPoint Point;
bool Drawing=false;

static int str_compare(const void *arg1, const void *arg2)
{
       return strcmp((*(std::string*)arg1).c_str(), (*(std::string*)arg2).c_str());//比较字符串arg1 and arg2
}

file_lists ScanDirectory(const std::string &path, const std::string &extension)
{
    WIN32_FIND_DATA wfd;//WIN32_FIND_DATA:Contains information about the file that is found by the 
        //FindFirstFile, FindFirstFileEx, or FindNextFile function
     HANDLE hHandle;
     string searchPath, searchFile;
     file_lists vFilenames;
     int nbFiles = 0;
    
     searchPath = path + "/*" + extension;
     hHandle = FindFirstFile(searchPath.c_str(), &wfd);//Searches a directory for a file or subdirectory
              //with a name that matches a specific name
     if (INVALID_HANDLE_VALUE == hHandle)
    {
         fprintf(stderr, "ERROR(%s, %d): Cannot find (*.%s)files in directory %s/n",
              __FILE__, __LINE__, extension.c_str(), path.c_str());
         exit(0);
    }
    do
    {
         //. or ..
          if (wfd.cFileName[0] == '.')
         {
              continue;
          }
          // if exists sub-directory
          if (wfd.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY)//dwFileAttributes:The file attributes of a file
        {             

          //FILE_ATTRIBUTE_DIRECTORY:The handle identifies a directory
             continue;
         }
        else//if file
        {
            searchFile = path + "/" + wfd.cFileName;
            vFilenames.push_back(searchFile);
            nbFiles++;
         }
    }while (FindNextFile(hHandle, &wfd));//Call this member function to continue a file search begun 
          //with a call to CGopherFileFind::FindFile

    FindClose(hHandle);//Closes a file search handle opened by the FindFirstFile, FindFirstFileEx,
       //or FindFirstStreamW function

 // sort the filenames
    qsort((void *)&(vFilenames[0]), (size_t)nbFiles, sizeof(string), str_compare);//Performs a quick sort

    return vFilenames;
}

void onMouse(int event,int x,int y,int flags,void* param );

void Draw(IplImage* img0,CvPoint point)
{
	for(int r=0;r<img0->height;r++)
	{
		for(int c=0;c<img0->width;c++)
		{
			double s=cvGetReal2D(img0,r,c);
			double d=(((double)sqr(r-point.y)+sqr(c-point.x)));
			s=s*(exp((250*250-2*d)/(250*250)));

			//d=exp(-d/(250*250));
			
			cvSetReal2D(img0,r,c,s);
		}
	}
	cvNormalize(img0,img0,0,1,CV_MINMAX);
}

int _tmain(int argc, _TCHAR* argv[])
{
	Point=cvPoint(0,0);
	time_t start,end,time; /*注意计时所用的变量名称*/
    /*程序开始执行,开始计时*/
    start=clock(); 
     file_lists files = ScanDirectory("D:/HC", ".png");
     if (files.empty())
     {
          cout<<"no image file find in current directory.."<<endl;
          system("pause");
          exit(-1);
      }

      int size = files.size();
      cout<<"there are "<<size<<" image files totally...."<<endl;
      for (int i=0; i<size; i++)
     {  
	
		IplImage* img = cvLoadImage(files[i].c_str(),-1);
		IplImage *img0=cvCreateImage(cvGetSize(img),IPL_DEPTH_32F,1);
		cvConvertScale(img,img0,1.0/255);
		cvNamedWindow("Webcam",1);
		cvSetMouseCallback("Webcam",onMouse,(void*)img0);
		//cvZero(img0);
		IplImage* temp=cvCloneImage(img0);

 
		 while(true)
		 {
			 cvCopyImage(img0,temp);
			// if(Drawing)
			// Draw(temp,Point);
			 cvShowImage("Webcam",temp);
			
			if(cvWaitKey(15)==27)  
          		  break;  
		  }  



		//cvShowImage("Webcam",img0);
		//cvWaitKey(0);
		cvConvertScale(img0,img,255);

		string a="D:/test/out/";
		string b;
		b.assign(files[i],6,8);
		a.append(b);
		a.append("_RC.png");
		cvSaveImage(a.c_str(),img);
		cout<<files[i].c_str()<<i<<endl;
		}
		//cvNamedWindow("outwindow", CV_WINDOW_AUTOSIZE);
		//cvShowImage("outwindow", result);
		//cvSaveImage("D:/image/test_meanshift/put/1.jpg",result);
		end=clock(); 
		time=end-start;//这里的时间是计算机内部时间
		cout << endl << "time:" << time << endl;
		cvWaitKey(0);

		

	return 0;
}
void onMouse(int event,int x,int y,int flags,void* param )
{
	IplImage*img=(IplImage*)param;
	 switch(event)
     {
		 case CV_EVENT_LBUTTONUP:
         {
             Point=cvPoint(x,y);
         }
		 Draw(img,Point);
         break;
	 }

printf("( %d, %d) ",x,y);
printf("The Event is : %d ",event);
printf("The flags is : %d ",flags);
printf("The param is : %d\n",param);
}


 

相关文章推荐

学习OpenCV——鼠标事件(画框)

#include "cv.h" #include "highgui.h" bool check_line_state=false; IplImage* workImg; IplImage*...

Android学习笔记(一)——简单的控件和基本响应:鼠标事件的响应

鼠标事件响应方式1: java文件 package com.shine.night; import android.app.Activity; import android.os.Bun...

基于《Selenium 2自动化测试实战》的学习笔记(8)—— 鼠标事件

ActionChains 类鼠标操作的常用方法: context_click() 右击  double_click() 双击 drag_and_drop()拖动  move_to_ele...

第五十四节 java学习——鼠标事件(MouseEvent)

鼠标事件(MouseEvent) 表明画布或界面组件中发生的鼠标事件,包含按下鼠标,释放鼠标,单击鼠标,进入部件的地理位置的鼠标事件和退出部件的地理位置的鼠标事件,以及鼠标移动事件(鼠标移动和鼠标拖...

GTK进阶学习:鼠标事件 源代码

  • 2015年01月27日 14:21
  • 5KB
  • 下载

Opencv函数setMouseCallback鼠标事件响应

Opencv中setMouseCallback()创建了一个鼠标回调函数,每次在图像上单击鼠标左键再抬起的过程,都会分3次调用鼠标响应函数,并且响应顺序是: 1.左键单击按下; 2.左键单击抬起; 3...
  • dcrmg
  • dcrmg
  • 2016年07月30日 01:23
  • 5348

OPENCV图像处理基础(五)鼠标事件画个框

在GUI编程中会涉及到鼠标事件,通过鼠标事件可以使得人和机器的交互更为便捷。opencv中提供了一种以回调函数实现的鼠标事件机制。 下面是一个例子,通过鼠标在一张图片上画出任意大小的矩形框。 效果...

利用OpenCV鼠标事件设置函数setMouseCallback显示图像像素坐标值!

利用OpenCV鼠标事件设置函数setMouseCallback显示图像像素坐标值!
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:学习OpenCV——鼠标事件&亮暗化精度最高(与距离反比)&批处理
举报原因:
原因补充:

(最多只允许输入30个字)