修改SR4000自带软件,支持opencv
/*-----------------------------------------------------------------------------
*
* 版权声明:
* 可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息及本声明
* http://www.cnblogs.com/yuliyang/
* 联系方式:
* Mail:yuliyang@qq.com
*
*-----------------------------------------------------------------------------*/
/*
* =====================================================================================
*
* Filename: SwissRangerSampleGui.cpp
* Environment:
* Description: 使用opencv获取深度和幅度数据
*
*
* Version: 1.0
* Created: 2013/11/6 21:55:43
* Author: yuliyang
I*
* Mail: wzyuliyang911@gmail.com
* Blog: http://www.cnblogs.com/yuliyang
*
* =====================================================================================
*/ /*------------------------------------------------------------------------*/
/* */
/* Copyright (c) 2008 by MESA Imaging SA, */
/* http://www.mesa-imaging.ch */
/*------------------------------------------------------------------------*/
// $Author$
// $URL$
// $Rev$
// $Date$
/*------------------------------------------------------------------------*/
//!\file
//!Example Win32 application
// SwissRangerSampleGui.cpp : Defines the entry point for the application.
// #include "stdafx.h"
//#include <vld.h>
#include "SwissRangerSampleGui.h"
#include "commdlg.h"
#include "commctrl.h"
#pragma comment( lib, "comctl32" ) //Used for slider control
#include "richedit.h"
#include <math.h>
#include "opencv2/core/core.hpp"
#include "opencv2/highgui/highgui.hpp"
#include "opencv2/imgproc/imgproc.hpp"
/*------------------------------------------------------------------------------------------------------------
* rgb2gray用到
*------------------------------------------------------------------------------------------------------------*/
#include "opencv2/imgproc/imgproc_c.h"
#include "opencv2/core/core_c.h"
#include "opencv2/highgui/highgui_c.h"
using namespace cv; #ifndef DOXYGEN //exclude these defines from doxygen
// Global Variables:
static HINSTANCE hInst; // current instance HINSTANCE AfxGetInstanceHandle(){return hInst;} CPreciseTimer precTimer; #define LIMIT(val,min,max) (((val)<(min))?(min):(((val)>(max))? (max):(val))) #ifndef D3DCOLOR_ARGB
typedef DWORD D3DCOLOR; //!<32 bit color value
#define D3DCOLOR_ARGB(a,r,g,b) \
((D3DCOLOR)((((a)&0xff)<<)|(((r)&0xff)<<)|(((g)&0xff)<<)|((b)&0xff)))
#endif //Colors for error overflow etc.
#define OVFL_COL D3DCOLOR_ARGB(0,0xff,0xe0,0xc0)
#define UDFL_COL D3DCOLOR_ARGB(0,0xc0,0xe0,0xff)
#define ERR_COL D3DCOLOR_ARGB(0,0x00,0xe0,0x00)
#endif //DOXYGEN //!The RGBColMap struct is used to generate colormaps.
//!This is a local class in the file OCTViewSlice.cpp
typedef struct
{
BYTE pos;//!<position in the color shading
BYTE r; //!<red value
BYTE g; //!<green value
BYTE b; //!<blue value
} RGBColMap; //!<colormap entry for SetColormap() static const RGBColMap jet[]={
{0x00, 0x00, 0x00, 0x80},
{0x20, 0x00, 0x00, 0xff},
{0x60, 0x00, 0xff, 0xff},
{0xa0, 0xff, 0xff, 0x00},
{0xe0, 0xff, 0x00, 0x00},
{0xff, 0x80, 0x00, 0x00}
}; //!fills a folormap with a desired color shading
void SetColormap(const RGBColMap* cm, RGBQUAD* col)
{
int i,x;
float f;
col[].rgbBlue =(BYTE)cm[].b;
col[].rgbGreen=(BYTE)cm[].g;
col[].rgbRed =(BYTE)cm[].r;
col[].rgbReserved=0x00;
x=;
for (i=;i<;i++)
{
while (cm[x].pos<i)x++;
f=((float)i-cm[x-].pos)/(cm[x].pos-cm[x-].pos);
col[i].rgbBlue =(BYTE)(f*cm[x].b+(.-f)*cm[x-].b);
col[i].rgbGreen=(BYTE)(f*cm[x].g+(.-f)*cm[x-].g);
col[i].rgbRed =(BYTE)(f*cm[x].r+(.-f)*cm[x-].r);
col[i].rgbReserved=0x00;
}
} //!Loops and calls CWndSwissranger::Acquire() until CCameraThread::Stop() is called
DWORD CCameraThread::CameraLoop()
{
while(!_stop)
{
_srWnd->Acquire();
}
return ;
} const TCHAR* CWndSwissranger::_wndClass="WndSwissrangerClass";
const TCHAR* CWndSwissranger::_wndTitle="Swissranger"; //!\ingroup swissRangerSampleGui
//!This is he main entry function that allocates a CWndSwissranger object, creates the window and starts the message loop.
int APIENTRY _tWinMain(HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPTSTR lpCmdLine,
int nCmdShow)
{
MSG msg;
WINDOWINFO winf;
HACCEL hAccelTable;
HWND dlg;
hInst = hInstance;
InitCommonControls(); SR_CheckForNewDllVersion(); CWndSwissranger wndSR; wndSR.Create(hInstance,);
hAccelTable = LoadAccelerators(hInstance, (LPCTSTR)IDC_SWISSRANGERSAMPLEGUI); // Main message loop:
while (GetMessage(&msg, NULL, , ))
{
if (TranslateAccelerator(msg.hwnd, hAccelTable, &msg))continue; dlg=msg.hwnd;
while(IsWindow(dlg) && GetWindowInfo(dlg,&winf))
{
if ((winf.dwStyle&WS_POPUP) && IsDialogMessage(dlg, &msg))
{
goto cont2;
}
dlg=GetParent(dlg);
}
TranslateMessage(&msg);
DispatchMessage(&msg);
cont2:;
}
return (int) msg.wParam;
} //!redirects the call from this static function to the method WindowProc
BOOL CALLBACK CDlgAbout::SWindowProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
CDlgAbout* pWnd;
if (message == WM_INITDIALOG)
{
pWnd=(CDlgAbout*)lParam;
pWnd->_hWnd=hDlg;
// get the pointer to the window from lpCreateParams which was set in CreateWindow
SetWindowLong(hDlg, GWL_USERDATA, (long)(lParam));
pWnd->OnInitialUpdate();
return TRUE;
}
// get the pointer to the window
pWnd = GetObjectFromWindow(hDlg);
// if we have the pointer, go to the message handler of the window
// else, use DefWindowProc
if (pWnd)
return pWnd->WindowProc(hDlg, message, wParam, lParam);
else
return FALSE;
} //!window message handling function
BOOL CALLBACK CDlgAbout::WindowProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
switch (message)
{
case WM_INITDIALOG:
return TRUE; case WM_COMMAND:
if (LOWORD(wParam) == IDOK || LOWORD(wParam) == IDCANCEL)
{
EndDialog(hDlg, LOWORD(wParam));
return TRUE;
}
break;
}
return FALSE;
} CWndSwissranger* CWndSwissranger::_cbInstance=;
//!registers a new window class
ATOM CWndSwissranger::RegisterClass(HINSTANCE hInstance)
{
static bool registered=false;
if(registered)return ;
registered=true;
WNDCLASSEX wcex; wcex.cbSize = sizeof(WNDCLASSEX); wcex.style = CS_HREDRAW | CS_VREDRAW;
//wcex.lpfnWndProc = SWindowProc;
wcex.cbClsExtra = ;
wcex.cbWndExtra = ;
wcex.hInstance = hInstance;
wcex.hIcon = LoadIcon(hInstance, (LPCTSTR)IDI_SWISSRANGERSAMPLEGUI);
wcex.hCursor = LoadCursor(NULL, IDC_ARROW);
wcex.hbrBackground = (HBRUSH)(COLOR_WINDOW+);
wcex.lpszMenuName = (LPCTSTR)IDC_SWISSRANGERSAMPLEGUI;
wcex.lpszClassName = _wndClass;
wcex.hIconSm = LoadIcon(wcex.hInstance, (LPCTSTR)IDI_SMALL);
return RegisterClassEx(&wcex);
} //!redirects the call from this static function to the method WindowProc
BOOL CALLBACK CWndSwissranger::SWindowProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam)
{
CWndSwissranger* pWnd;
if (message == WM_INITDIALOG)
{
pWnd=(CWndSwissranger*)lParam;
pWnd->_hWnd=hDlg;
// get the pointer to the window from lpCreateParams which was set in CreateWindow
SetWindowLong(hDlg, GWL_USERDATA, (long)(lParam));
pWnd->OnInitialUpdate();
return TRUE;
}
// get the pointer to the window
pWnd = GetObjectFromWindow(hDlg);
// if we have the pointer, go to the message handler of the window
// else, use DefWindowProc
if (pWnd)
return pWnd->WindowProc(hDlg, message, wParam, lParam);
else
return FALSE;
} //!window message handling function
BOOL CALLBACK CWndSwissranger::WindowProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{
int wmId, wmEvent; switch (message)
{
case WM_COMMAND:
wmId = LOWORD(wParam);
wmEvent = HIWORD(wParam);
// Parse the menu selections:
switch (wmId)
{
case IDOK:
case IDCANCEL:
{
_camThread.Stop();
if(IsWindowEnabled(::GetDlgItem(hWnd,IDC_CLOSE)))
{
OnCloseDev();
}
DestroyWindow(hWnd);
break;
}
case IDM_ABOUT:
{
CDlgAbout about;
about.DoModal(AfxGetInstanceHandle(),hWnd);
break;
}
case IDM_EXIT:
DestroyWindow(hWnd);
break;
case ID_SETTINGS_DLL:
{
if(_srCam)
SR_OpenSettingsDlg(_srCam,hWnd);
else
{
MessageBox(hWnd,"No Swissranger camera opened","Warning",MB_ICONEXCLAMATION);
}
break;
}
case IDC_CHECK_NEW_DLL:
{
int res=SR_CheckForNewDllVersion();
if(res)
MessageBox(hWnd,"No new libMesaSR-dll version found","libMesaSR: Info",MB_ICONASTERISK);
break;
} case ID_OPEN_FORCE_DLG:
{
OnOpenDlg();
break;
}
case IDC_OPEN:
case ID_OPEN_DLG:
{
short s=GetKeyState(VK_LSHIFT);
if(s<)//shift pressed?
OnOpenDlg();
else
OnOpenDlg();
break;
}
case IDC_ACQUIRE:
{
//_camThread.Run(this);
HWND hcntrl=GetDlgItem(hWnd,IDC_CONTINUOUS);
LRESULT lResult = SendMessage(hcntrl, BM_GETCHECK, , );
if(lResult)
{
if(_camThread.IsRunning())
{
_camThread.Stop();
EnableWindow(::GetDlgItem(hWnd,IDC_CLOSE),TRUE);
::SendMessage(::GetDlgItem(hWnd,IDC_ACQUIRE),WM_SETTEXT,,(LPARAM)"Acquire");
}
else
{
EnableWindow(::GetDlgItem(hWnd,IDC_CLOSE),FALSE);
::SendMessage(::GetDlgItem(hWnd,IDC_ACQUIRE),WM_SETTEXT,,(LPARAM)"Stop");
precTimer.StartTimer();
_camThread.Run(this);
}
}
else
{
precTimer.StartTimer();
Acquire();
}
break;
}
case IDC_CLOSE:
{
OnCloseDev();
break;
}
case IDC_MINCOL:
{
HWND hcntrl=(HWND)lParam;
switch(wmEvent)
{
case EN_CHANGE:
{
char buf[];
HWND hcntrl=(HWND)lParam;
GetWindowText(hcntrl,buf,_countof(buf));
hcntrl=GetDlgItem(hWnd,IDC_CB_COL);
LRESULT lResult = SendMessage(hcntrl,CB_GETCURSEL,,);
float v=(float)atof(buf);
_minVal[lResult]=v;
break;
}
}
break;
}
case IDC_MAXCOL:
{
HWND hcntrl=(HWND)lParam;
switch(wmEvent)
{
case EN_CHANGE:
{
char buf[];
HWND hcntrl=(HWND)lParam;
GetWindowText(hcntrl,buf,_countof(buf));
hcntrl=GetDlgItem(hWnd,IDC_CB_COL);
LRESULT lResult = SendMessage(hcntrl,CB_GETCURSEL,,);
float v=(float)atof(buf);
_maxVal[lResult]=v;
break;
}
}
break;
}
case IDC_CB_COL:
{
switch(wmEvent)
{
case CBN_SELCHANGE:
{
HWND hcntrl=(HWND)lParam;
LRESULT lResult = SendMessage(hcntrl,CB_GETCURSEL,,);
SetColorLim((int)lResult);
break;
}
}
break;
}
case IDC_AUTO_EXPOSURE:
{
bool optInt=SendMessage(GetDlgItem(_hWnd,IDC_AUTO_EXPOSURE), BM_GETCHECK, , )?true:false;
if(optInt)
SR_SetAutoExposure(_srCam, ,,,);
else
SR_SetAutoExposure(_srCam, ,,,);
break;
}
case IDC_MEDIAN:
{
if(SendMessage((HWND)lParam,(UINT)BM_GETCHECK,,)==BST_CHECKED)
SetMode(_acquMode|AM_MEDIAN);
else
SetMode(_acquMode&~AM_MEDIAN);
break;
}
case IDC_CONV_GRAY:
{
if(SendMessage((HWND)lParam,(UINT)BM_GETCHECK,,)==BST_CHECKED)
SetMode(_acquMode|AM_CONV_GRAY);
else
SetMode(_acquMode&~AM_CONV_GRAY);
break;
}
case IDC_COORD_TRANSF:
{
HWND hcntrl=GetDlgItem(_hWnd,IDC_COORD_TRANSF);
LRESULT lResult = SendMessage(hcntrl, BM_GETCHECK, , );
_coordTrf=lResult?true:false;
break;
}
default:
return FALSE; // Didn't process the message: Got a WM_COMMAND message with unknown id.
}
break;
case WM_PAINT:
{
OnPaint();
break;
}
case WM_SIZE:
{
RECT rct0;
RECT cltRct;
HWND imgWnd0=GetDlgItem(hWnd,IDC_IMAGE0);
int w = LOWORD(lParam);
int h = HIWORD(lParam);
TRACE("WM_SIZE %d,%d",w,h);
GetClientRect(hWnd,&cltRct);
GetWindowRect(imgWnd0,&rct0);ScreenToClient(hWnd,(LPPOINT)&rct0);ScreenToClient(hWnd,((LPPOINT)&rct0)+);
int d=;
int ww=(cltRct.right-rct0.left-d);
MoveWindow(imgWnd0,
rct0.left,//
rct0.top,//
ww,
cltRct.bottom-rct0.top-d,
true);
break;
}
case WM_DESTROY:
PostQuitMessage();
break;
default:
return FALSE; // Didn't process the message: Got a WM_COMMAND message with unknown id.
}
return TRUE; // processed the message
} //!fills the dib with image data from the camera void CWndSwissranger::SetDib()
{ /*------------------------------------------------------------------------------------------------------------ *
* 0000-0xffff 扩展到0x000000-0xffffff每种颜色
* 每种颜色占一个字节 00-ff
* 扩张后再分配到各个通道,然后再组装成彩色一幅图
*
*
*
*------------------------------------------------------------------------------------------------------------*/
IplImage *tempbule=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,); /* 蓝色单通道 */
IplImage *tempgreen=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,); /* 绿色单通道 */
IplImage *tempred=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,); /* 红色单通道 */
IplImage *tempbule_A=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,); /* 幅度室外蓝色单通道 */
IplImage *tempgreen_A=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,);
IplImage *tempred_A=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,);
IplImage *temprgb=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,);
IplImage *temprgb_A=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,);
IplImage *tempgray=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,);
IplImage *tempgray_A=cvCreateImage(cvSize(_imgSz.cx,_imgSz.cy),IPL_DEPTH_8U,);
IplImage *temp0=cvCreateImage(cvSize(,),IPL_DEPTH_16U,);
cvNamedWindow("distance",CV_WINDOW_AUTOSIZE);
cvNamedWindow("amp",CV_WINDOW_AUTOSIZE);
cvNamedWindow("gray",CV_WINDOW_AUTOSIZE);
cvNamedWindow("amp_gray",CV_WINDOW_AUTOSIZE);
cvNamedWindow("",CV_WINDOW_AUTOSIZE);
if(_dibCam)
{
int i,idx,img;
int row=;
int col=; float v,minVal,step;
img=;idx=;
if(_coordTrf)
{
int res;
float lambda[MF_LAST]={3.75f, .f, 7.142857f, 7.5f, 7.894737f, 2.5f, .f, .f, 5.172414f, 4.838710f, 10.344828f, 9.677419f};//MF_40MHz,MF_30MHz,MF_21MHz,MF_20MHz,MF_19MHz,...
ModulationFrq frq=SR_GetModulationFrequency(_srCam);
res=SR_CoordTrfFlt(_srCam, ,,_z, sizeof(float),sizeof(float),sizeof(float));
minVal=_minVal[img];
step=(float)0xff/(_maxVal[img]-_minVal[img]);
for(i=;i<_imgSz.cx*_imgSz.cy;i++,idx++)
{
row=i/_imgSz.cx;
col=i%_imgSz.cx;
v=(_z[i]*((float)(<<)/lambda[frq])-minVal)*step;
_dibCam[idx]=_bmiScale->bmiColors[(BYTE)LIMIT(v,,)]; BYTE Blue1 =_dibCam[idx].rgbBlue;
BYTE Green1=_dibCam[idx].rgbGreen;
BYTE Red1=_dibCam[idx].rgbRed;
CV_IMAGE_ELEM( tempbule, uchar, row,col )=Blue1;
CV_IMAGE_ELEM( tempgreen, uchar, row,col )=Green1;
CV_IMAGE_ELEM( tempred, uchar, row,col )=Red1; } cvMerge(tempbule,tempgreen,tempred,NULL,temprgb);
cvShowImage("distance",temprgb);
cvCvtColor(temprgb,tempgray,CV_RGB2GRAY);
cvShowImage("gray",tempgray);
cvWaitKey();
img++;
} for(;img<_numImg;img++)
{
WORD* p=(WORD*)_imgEntryArray[img].data;
unsigned short int * pdata0;
pdata0=(unsigned short int *)SR_GetImage(_srCam, ); /* 原数据 */
minVal=_minVal[img];
step=(float)0xff/(_maxVal[img]-_minVal[img]);
for(i=;i<_imgSz.cx*_imgSz.cy;i++,idx++)
{
int row=i/_imgSz.cx; /* 行 */
int col=i%_imgSz.cx; /* 列 */
v=((float)p[i]-minVal)*step;
_dibCam[idx]=_bmiScale->bmiColors[(BYTE)LIMIT(v,,)];
BYTE Blue1 =_dibCam[idx].rgbBlue;
BYTE Green1=_dibCam[idx].rgbGreen;
BYTE Red1=_dibCam[idx].rgbRed;
CV_IMAGE_ELEM( tempbule_A, uchar, row,col )=Blue1;
CV_IMAGE_ELEM( tempgreen_A, uchar, row,col )=Green1;
CV_IMAGE_ELEM( tempred_A, uchar, row,col )=Red1;
}
cvMerge(tempbule_A,tempgreen_A,tempred_A,NULL,temprgb_A);
cvShowImage("amp",temprgb_A); /* 融合 */
cvCvtColor(temprgb_A,tempgray_A,CV_RGB2GRAY);
cvShowImage("amp_gray",tempgray_A);
cvWaitKey();
for (int i=;i<;i++)
{
for (int j=;j<;j++)
{
CV_IMAGE_ELEM( temp0, unsigned short int, i, j)=*pdata0; /* 给图像赋值 */
pdata0++; }
}
cvShowImage("",temp0);
cvWaitKey(); } }
InvalidateRect(_hWnd,,false);
cvReleaseImage(&tempbule);
cvReleaseImage(&tempgreen);
cvReleaseImage(&tempred);
cvReleaseImage(&temprgb);
// cvDestroyWindow("distance");
} //!redirects the call from this static function to the method SRFuncCB
int CWndSwissranger::SSRFuncCB(SRCAM srCam, unsigned int msg, unsigned int param, void* data)
{
if(!_cbInstance)
return ;
return _cbInstance->SRFuncCB(srCam, msg, param, data);
}
//!callback function of the libMesaSR. It enters/leaves the critical section during changes
int CWndSwissranger::SRFuncCB(SRCAM srCam, unsigned int msg, unsigned int param, void* data)
{
switch(msg)
{
default:
return SR_GetDefaultCallback()(srCam,msg,param,data);
break;
case CM_CHANGING:
EnterCritSec();
break;
case CM_CHANGED:
if(param)
AllocObj();
LeaveCritSec();
break;
}
return ;
} //!allocates memory for _dibCam buffer and initializes the _bmiCam structure
void CWndSwissranger::AllocObj()
{
_imgSz.cx=SR_GetCols(_srCam);
_imgSz.cy=SR_GetRows(_srCam);
_numImg=SR_GetImageList(_srCam,&_imgEntryArray); SAFE_FREE(_dibCam);
_dibCam=(RGBQUAD*)malloc(_imgSz.cx*_imgSz.cy*_numImg*sizeof(RGBQUAD));//RGBQUAD, RGBTRIPLE, BYTE, WORD
_bmiCam->bmiHeader.biWidth =_imgSz.cx;
_bmiCam->bmiHeader.biHeight=-_numImg*_imgSz.cy; SAFE_FREE(_z);
_z=(float*)malloc(_imgSz.cx*_imgSz.cy*sizeof(float));
} //!frees all allocated objects
void CWndSwissranger::Free()
{
SAFE_FREE(_dibCam);
SAFE_FREE(_bmiCam);
SAFE_FREE(_dibScale);
SAFE_FREE(_bmiScale);
SAFE_FREE(_z);
} //!initializes _maxVal,_bmiCam, _bmiScale and allocates _dibScale
void CWndSwissranger::Initialize()
{
int i;
for(i=;i<_countof(_minVal);i++)
{
_minVal[i]=;
_maxVal[i]=0xffff;
}
_maxVal[]=.f;
_maxVal[]=.f;
_maxVal[]=.f;
_maxVal[]=.f; _bmiCam=(BITMAPINFO*)malloc(sizeof(BITMAPINFOHEADER)+*sizeof(RGBQUAD));
memset(_bmiCam,,sizeof(BITMAPINFOHEADER));
_bmiCam->bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
_bmiCam->bmiHeader.biPlanes = ;
_bmiCam->bmiHeader.biBitCount = ;
_bmiCam->bmiHeader.biCompression = BI_RGB; _bmiScale=(BITMAPINFO*)malloc(sizeof(BITMAPINFOHEADER)+*sizeof(RGBQUAD));
memset(_bmiScale,,sizeof(BITMAPINFOHEADER));
_bmiScale->bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
_bmiScale->bmiHeader.biPlanes = ;
_bmiScale->bmiHeader.biBitCount = ;
_bmiScale->bmiHeader.biCompression = BI_RGB;
_bmiScale->bmiHeader.biWidth=;
_bmiScale->bmiHeader.biHeight=; //alloc and fill scale DIB
int x;
_dibScale=(BYTE*)malloc(*sizeof(BYTE));
for (x=;x<;x++)_dibScale[x]=x;
SetColormap(jet,_bmiScale->bmiColors);
}
//!When the window is created this function will be called
void CWndSwissranger::OnInitialUpdate()
{
LRESULT lResult;
HWND hcntrl;
int i;
char buf[]; HICON hIcon=LoadIcon(hInst, (LPCTSTR)IDI_SMALL);
lResult = SendMessage(_hWnd, WM_SETICON, ICON_BIG, (LPARAM)hIcon);
lResult = SendMessage(_hWnd, WM_SETICON, ICON_SMALL, (LPARAM)hIcon); hcntrl=GetDlgItem(_hWnd,IDC_CB_COL);
for(i=;i<_countof(_minVal);i++)
{
_snprintf(buf,_countof(buf),"Image %d",i);
lResult = SendMessage(hcntrl,CB_INSERTSTRING,-,(LPARAM)buf);
}
lResult = SendMessage(hcntrl,CB_SETCURSEL,,);
SetColorLim();
hcntrl=GetDlgItem(_hWnd,IDC_CONTINUOUS);
lResult = SendMessage(hcntrl, BM_SETCHECK, BST_CHECKED, );
hcntrl=GetDlgItem(_hWnd,IDC_COORD_TRANSF);
lResult = SendMessage(hcntrl, BM_SETCHECK, BST_CHECKED, );
_coordTrf=true;
} //!Sets the acuire mode of the camera
void CWndSwissranger::SetMode(int mode)
{
EnterCritSec();
_acquMode=mode;
SR_SetMode(_srCam, mode);
LeaveCritSec();
}
//!Sets color limits _minVal[idx] and _maxVal[idx] according to the gui settings
void CWndSwissranger::SetColorLim(int idx)
{
HWND hcntrl;
char buf[];
hcntrl=GetDlgItem(_hWnd,IDC_MINCOL);
_snprintf(buf,_countof(buf),"%.2f",_minVal[idx]);
SetWindowText(hcntrl,buf);
hcntrl=GetDlgItem(_hWnd,IDC_MAXCOL);
_snprintf(buf,_countof(buf),"%.2f",_maxVal[idx]);
SetWindowText(hcntrl,buf);
}
//!called when close button is pressed
void CWndSwissranger::OnCloseDev()
{
int res;
TRACE("swissrangerTester: SR_Close");
res=SR_Close(_srCam);
EnableWindow(::GetDlgItem(_hWnd,IDC_OPEN),TRUE);
if (res < )
{
TRACE("Failed to close device: error %d",res);
//but change the button states anyway, no return;
}
EnableWindow(::GetDlgItem(_hWnd,IDC_CLOSE),FALSE);
EnableWindow(::GetDlgItem(_hWnd,IDC_ACQUIRE),FALSE);
_srCam=;//there are no valid device opened
} //!called on a \b WM_PAINT message
void CWndSwissranger::OnPaint()
{
char buf[];
_snprintf(buf,_countof(buf)," %.2f fps\n",.f/_timePerFrame);
HWND hcntrl=GetDlgItem(_hWnd,IDC_TX_FPS);
::SetWindowText(hcntrl,buf); PAINTSTRUCT ps;
HDC hdc;
HWND imgWnd;
hdc = BeginPaint(_hWnd, &ps);
EndPaint(_hWnd, &ps);
imgWnd=GetDlgItem(_hWnd,IDC_IMAGE0);
hdc = BeginPaint(imgWnd, &ps);
RECT rect;
GetClientRect(imgWnd,&rect);
float fct;
if(_dibScale)
{
const SIZE sz={_bmiScale->bmiHeader.biWidth,_bmiScale->bmiHeader.biHeight};
fct=(float)(rect.right-)/sz.cx;
StretchDIBits(hdc, , , (int)(fct*sz.cx), , , , // x,y,w,h destination // x,y source
_bmiScale->bmiHeader.biWidth, _bmiScale->bmiHeader.biHeight, // width & height in source
_dibScale, _bmiScale, // pointer to 'bits' //BITMAPINFOHEADER
DIB_RGB_COLORS, SRCCOPY);
} if(_dibCam)
{
const SIZE sz={_bmiCam->bmiHeader.biWidth,-_bmiCam->bmiHeader.biHeight};
fct=min((float)(rect.right-)/sz.cx,(float)(rect.bottom-)/sz.cy);
StretchDIBits(hdc, , , (int)(fct*sz.cx), (int)(fct*sz.cy), , , // x,y,w,h destination // x,y source
_bmiCam->bmiHeader.biWidth, -_bmiCam->bmiHeader.biHeight, // width & height in source
_dibCam, _bmiCam, // pointer to 'bits' //BITMAPINFOHEADER
DIB_RGB_COLORS, SRCCOPY);
} EndPaint(imgWnd, &ps);
return;
} //!called when open button is pressed
void CWndSwissranger::OnOpenDlg(int mode)
{
TRACE("swissrangerTester: SR_Open device");
if (_srCam)
{
TRACE("Swiss Ranger device already opened.");
return;
}
int res;
res=SR_OpenDlg(&_srCam,mode,_hWnd);
SendMessage(GetDlgItem(_hWnd,IDC_AUTO_EXPOSURE), BST_UNCHECKED, , );
_acquMode=SR_GetMode(_srCam); SendMessage((HWND)GetDlgItem(_hWnd,IDC_MEDIAN),(UINT)BM_SETCHECK, (_acquMode&AM_MEDIAN)?BST_CHECKED:BST_UNCHECKED,);
SendMessage((HWND)GetDlgItem(_hWnd,IDC_CONV_GRAY),(UINT)BM_SETCHECK, (_acquMode&AM_CONV_GRAY)?BST_CHECKED:BST_UNCHECKED,); if (res<=)
{
TRACE("Couldn't connect to Swiss Ranger device error %d",res);
return;
}
TRACE("swissrangerTester: Device opened successfully device handle=%d",_srCam);
AllocObj();
EnableWindow(::GetDlgItem(_hWnd,IDC_OPEN),FALSE);
EnableWindow(::GetDlgItem(_hWnd,IDC_CLOSE),TRUE);
EnableWindow(::GetDlgItem(_hWnd,IDC_ACQUIRE),TRUE);
} //!Acquires an image and displays it
void CWndSwissranger::Acquire()
{
EnterCritSec();
int res=SR_Acquire(_srCam);
if (res < )
{
TRACE("Failed to acquire the measurement");
}
else
{
//logPrintf("swissrangerTester: %d bytes read", res);
SetDib();
}
LeaveCritSec();
__int64 tic=precTimer.GetTime();precTimer.StartTimer();
static __int64 smtic=;
_timePerFrame=0.90f*_timePerFrame+0.10f*(float)tic/1e6f;
smtic+=tic;
smtic=;
}
修改SR4000自带软件,支持opencv的更多相关文章
- SR4000自带软件修改(二)
/*----------------------------------------------------------------------------- * * 版权声明: * 可以 ...
- 修改minifest使桌面软件支持高dpi
在VisualStudio中可以很方便的设置manifest以支持高dpi的用户界面.当然也可以手工修改manifest文件来添加对高dpi的支持. QQ在高dpi方面做的尤其差,对高dpi的支持迟迟 ...
- sr4000自带API和opencv结合获取图像
/* * ===================================================================================== * * Filen ...
- OpenCV开发笔记(七十三):红胖子8分钟带你使用opencv+dnn+yolov3识别物体
前言 级联分类器的效果并不是很好,准确度相对深度学习较低,上一章节使用了dnn中的tensorflow,本章使用yolov3模型,识别出具体的分类. Demo 320x320,置信度0 ...
- 删除Android自带软件方法及adb remount 失败解决方案
删除Android自带软件方法 1.在电脑上打开cmd,然后输入命令 adb remount adb shell su 2.接着就是Linux命令行模式了,输入 cd system/app 3然后输入 ...
- 让c#的exe只要被修改就无法运行,支持混淆和数字证书
原文:让c#的exe只要被修改就无法运行,支持混淆和数字证书 首先用sdk的sn工具或者makecert工具生成公钥和密钥,推荐makecert,做自己的证书,我做了一个受信任的根证书放在受信任的根证 ...
- 带EFI支持的GRUB2安装全记录
版权归作者所有,任何形式转载请联系作者. 作者:keenshoes(来自豆瓣) 来源:https://www.douban.com/note/210077866/ 关键词:EFIGRUB2efibo ...
- iOS开发——运行时OC篇&使用运行时获取系统的属性:使用自己的手势修改系统自带的手势
使用运行时获取系统的属性:使用自己的手势修改系统自带的手势 有的时候我需要实现一个功能,但是没有想到很好的方法或者想到了方法只是那个方法实现起来太麻烦,一或者确实为了装逼,我们就会想到iOS开发中最牛 ...
- 关于自定义tabBar时修改系统自带tabBarItem属性造成的按钮顺序错乱的问题相关探究
关于自定义tabBar时修改系统自带tabBarItem属性造成的按钮顺序错乱的问题相关探究 测试代码:http://git.oschina.net/Xiyue/TabBarItem_TEST 简 ...
随机推荐
- C#通过ODAC访问Oracle12c
昨天晚上刚装好Oracle12c并配制好了PLSQL Developer开发环境.今天继续完善一下,讲讲在C#中如何访问Oracle12c. 其实我们运用老早的ADO.NET也可以连接,但是在.NET ...
- margin系列之百分比
本系列摘自 px; height: 600px; } #demo p{ margin: 10% 5%; } HTML: <div id="demo"> <p&g ...
- CSS 之 @media
@media 版本:CSS2 兼容性:IE5+ 语法: @media sMedia {sRules} 取值: sMedia : 指定设备名称.请参阅设备类型 all, aural, braille ...
- Makefile 多目录自动编译
适用于多目录结构 C 工程自动编译. makefile 分成三类: 1. 工程根目录 makefile : 这个makefile执行分成两个阶段 a)递归进入每个子目录, 逐个执行子目录里面的 ma ...
- TOKEN+签名验证
TOKEN+签名验证 首先问大家一个问题,你在写开放的API接口时是如何保证数据的安全性的?先来看看有哪些安全性问题在开放的api接口中,我们通过http Post或者Get方式请求服务器的时候,会面 ...
- iOS序列化与反序列化
1到底这个序列化有啥作用? 面向对象的程序在运行的时候会创建一个复杂的对象图,经常要以二进制的方法序列化这个对象图,这个过程叫做Archiving. 二进制流可以通过网络或写入文件中(来源于某教材的一 ...
- CSS3学习之 animation 属性
发现animation这个新属性很有趣,在此学习,并整理下! 浏览器支持: Internet Explorer 10.Firefox 以及 Opera 支持 animation 属性: Safari ...
- Codeforces Round #361 div2
ProblemA(Codeforces Round 689A): 题意: 给一个手势, 问这个手势是否是唯一. 思路: 暴力, 模拟将这个手势上下左右移动一次看是否还在键盘上即可. 代码: #incl ...
- 九张图让你的PPT立刻高大上
- Matlab心得及学习方法(不断更新)
Matlab心得及学习方法(不断更新) Matlab心得及学习方法(不断更新)P.S. 那些网上转载我的文章不写明出处的傻眼了吧?!老子更新了! 发现现在很多人(找工作的或者读博的)都想要学习或者正在 ...