八. 平台

鼠标

OpenCV通过回调函数使用鼠标,以下为定义回调函数必须匹配的协议:

void	your_mouse_callback(
	int	event,							//事件类型
	int	x,									//鼠标事件的X位置
	int y,									//y
	int flags,							//鼠标事件的更多细节
	void *param					//Parameters from cv::setMouseCallback()
);

第一个参数表:

事件

数值

cv::EVENT_MOUSEMOVE

0

cv::EVENT_LBUTTONDOWN

1

cv::EVENT_RBUTTONDOWN

2

cv::EVENT_MBUTTONDOWN

3

cv::EVENT_LBUTTONUP

4

cv::EVENT_RBUTTONUP

5

cv::EVENT_MBUTTONUP

6

cv::EVENT_LBUTTONDBLCLK

7

cv::EVENT_RBUTTONDBLCLK

8

cv::EVENT_MBUTTONDBCLK

9

第四个标志为鼠标事件标志, 用于鼠标组合键(如: shift+鼠标左键):

标志

数值

cv::EVENT_FLAG_LBUTTON

1

cv::EVENT_FLAG_RBUTTON

2

cv::EVENT_FLAG_MBUTTON

4

cv::EVENT_FLAG_CTRLKEY

8

cv::EVENT_FLAG_SHIFTKEY

16

cv::EVENT_FLAG_ALTKEY

32

最后一个参数是void类型的指针, OpcnCV可以用来传递额外的信息到任何类型的结构.

需要一个函数来注册这个回调函数, 即cv::setMouseCallback(), 它需要三个参数:

void	cv::setMouseCallback(
	const	string&	windowName,					//应用回调函数的窗口
	cv::MouseCallback	on_mouse,			//要注册的回调函数
	void*	param = NULL								//回调函数的额外参数, 可以给回调函数传递信息
);

滑动条,滚动条和开关

HighGUI中创建一个滑动条的函数如下:

int	cv::creatTrackbar(
	const 	string&		trackbarname,			//滑动条名称
    cosnt	string&		windowName,			//窗口名称
    int*	value,													//滑动的条当前位置
    int		cout,														//滑动条总的数量
    cv::TrackbarCallback	onChange = NULL,	//回调函数(可选)	(当滑动按钮移动时, 回调函数自动调用)
    void*	param												//额外参数
);

这个回调函数并非必须的. 若无回调函数, 移动滑动钮的唯一响应就是value指向的变量值的变化(可以通过这个值来对值的变化做出响应)

回调函数所满足的形式:

void yourTrackbarCallback(
	int		pos,						//滑动条位置
    void*	param = NULL		//cv::setTrackbarCallback()的参数
);

c::creatTrackbar()的最后一个参数是params, 可以是一个任意类型的指针, 一旦回调执行, 这个参数可以传递给回调函数的params参数, 这样一来, 不创建全局变量也可以处理滑动条事件.

有两个函数可以用来获取和设置滑动条的位置值:

int	cv::getTrackbarPos(
	const	string&	trackbarName,			//滑动条名称
    const	string&	windowName				//窗口名称
);
void	cv::setTrackbarPos(
	const	string&	trackbarName,
    const 	string&	windowName,
    int pos															//设置的位置值
);

通过Qt后端工作

文字蒙版

用于在窗口上方显示文字条幅, 其函数API:

int	cv::displayOverlay(
	const	string&	name,					//显示的窗口名称
    const	string&	text,						//显示的文字
    int		delay										//显示的ms时间(0 = 'forever')
);

最后一个参数中, 若delay的值设置为0, 那么蒙版将一直存在或直到你再次调用cv::displayOverlay()覆盖原来的蒙版, 若在delay结束前调用cv::dispalyOverlay(), 则将显示新的蒙版, 且延时重置.

创建按钮

Qt接口提供创建按钮的函数, 包括正常的按钮, 单选按钮和复选框, 所有创建的按钮都位于控制面板上.

所有三种类型的按钮都通过一个方法完成:

int	cv::creatButton(
	const	string&	buttonName,									//按钮名称
    cv::ButtonCallback	onChange = NULL,			//按钮事件的回调函数(可无)
    void*	params,																//额外的按钮事件参数
    int	buttonType = cv::PUSH_BUTTON,				//按钮类型(PUSH_BUTTON or RADIOBOX or CHECKBOX)
    int	initalState = 0															//按钮的初始化状态
);

按钮回调函数定义:

void	yourButtonCallback(
	int		state,								//按钮状态
    void*	params						//cv::creatButton传递的参数
);

你传递给cv::creatButton()的params指针也会被传给回调函数的params参数.

buttonType可以取值为: cv::PUSH_BUTTON, cv::RADIOBOX或者cv::CHECKBOX:

第一个为标准按钮, 当你点击按钮便会调用回调函数

第二个为复选框, 按钮参数根据有没有选择复选框设置为1或者0

第三个为单选按钮, 区别在于点击按钮同时调用当前点击按钮的回调函数和当前没有被点击的按钮(互斥状态).

文本和文字

使用Qt接口写文本必须首先创建一个CvFont对象, 任何时候想在屏幕中添加文本都可以使用这个对象, 字体通过函数cv::fontQt()创建:

CvFont	fontQt(
	const	string&	fontName,								//字体名称
    int	pointSize,														//字体大小
    cv::Scalar	color = cv::Scalar::all(0),				//BGR颜色
    int	weight = cv::FONT_NORMAL,					//字体宽度(粗细), 1-100(Table	9-3)
    int	spacing = 0															//字体间距
);

Qt字体粗细的预定以名称及与其关联的值:

Camere capture constant

数值

cv::FONT_LIGHT

25

cv::FONT_NORMAL

50

cv::FONT_DEMIBOLD

63

cv::FONT_BOLD

75

cv::FONT_BLACK

87

最后一个参数spacing控制字符间距, 值正负都可以

放置文本函数:

void	cv::addText(
	cv::Mat&	image,				//要写入的图片
    const	string&	text,			//要写入的文本
    cv::Point	location,			//左下角定位的文本位置
    CvFont*	font						//OpenCV字体的结构体
);

文本的位置为首字符左下角的位置(文本基线的起点)

设置和获取窗口属性

大部分基于Qt后端创建的窗口状态属性都是可以获取的, 并且大部分都能够在创建窗口后更改:

void	cv::setWindowProperty(
	const	string&	name,						//窗口名称
    int	prop_id,										 //窗口属性ID
    double	prop_value							//设置的属性值
);
double	cv::getWindowProperty(
	const	string&	name,					//窗口名称
    int	prop_id											//窗口的属性ID
);

获取属性通过提供窗口名和属性ID(prop_id)就可以, 这是属性需要额外提供属性表:

属性名称

描述

cv::WIND_PROP_FULL_SIZE

设置为cv::WINDOW_FULLSCREEN可以将窗口显示为全屏

设置为cv::WINDOW_NORMAL窗口显示为正常尺寸

cv::WIND_PROP_AUTOSIZE

设置为cv::WINDOW_AUTOSIZE窗口大小自动调整为图像大小

设置为cv::WINDOW_NORMAL显示图像大小调整为窗口大小

cv::WIND_PROP_ASPECTRATIO

设置为cv::WINDOW_FREERATIO可以使窗口有任意长宽比(用户可调整)

设置为cv::WINDOW_KEEPRATIO只能按照固定长宽比调整窗口大小

保存和恢复窗口的状态

Qt接口可以保存和恢复窗口的状态:

void	cv::savaWindowParameters(
	const	string&	name											//窗口名
);
void	cv::loadWindowParameters(
	const	string&	name
);

保存窗口时使用cv::saveWindowParameters即可, 恢复窗口通过cv::loadWIndowParameters()即可.

即使你退出或者重启程序, 属性加载命令依然能够正常工作.

和OpenGL交互

回调函数需要满足的定义:

void	yourOpenGLCallback(
	void*	params											//从cv::createOpenGLCallback()传过来的参数
);

可以通过cv::createOpenGLCallback()配置回调函数:

void	cv::createOpenGLCallback(
	const	string&	windowName,					//窗口名称
    cv::OpenGLCallback	callback,				//OpenGL的回调函数
    void*	params = NULL								//传给回调函数的参数
);

参数可以在调用回调函数时给函数以额外的参数.