OpenCV-waitKey()


学习仿射变换时用到waitKey()实现图片旋转显示


waitKey(30)

for(;;){
if (waitKey(30) >= 0)//返回30ms内按下的键值,否则返回-1.
break;
}

其中()内的值表示等待时间(ms),如代码中表示等待30ms,waitKey(30)返回值为30ms内键盘按下的返回值(键盘中每个按键对应一个ASCII码,见https://www.cnblogs.com/yiven/p/7118056.html)
如果没有按键按下,则返回-1,所以不会跳出循环

waitKey(0)

表示一直等待用户按键事件发生

 int main()
{
	Mat src = imread("lyj.png");
	imshow("this is 林宥嘉",src);
	Point2f srcTri[] = {
		Point2f(0,0),
		Point2f(src.cols - 1,0),
		Point2f(0,src.rows - 1),
	};
	Point2f dstTri[] = {
		Point2f(0,src.rows*0.33f),
		Point2f(src.cols*0.85f,src.rows*0.25f),
		Point2f(src.cols*0.15f,src.rows*0.9f),	
	};
	//compute affine matrix
	Mat warp_mat = getAffineTransform(srcTri, dstTri);
	Mat dst, dst2;
	warpAffine(src, dst, warp_mat, src.size(), INTER_LINEAR, BORDER_CONSTANT, Scalar());
	for (int i = 0; i < 3; i++)
		circle(dst, dstTri[i], 5, Scalar(255, 0, 255), -1, 16);
	imshow("Affine Transform Test", dst);
     waitKey(0);
	//Rotation
	for (int frame = 0;; ++frame) {
	Point2f	 center=Point2f(src.cols*0.5f, src.rows*0.5f);
		double angle = frame * 3 % 360, scale = (cos((angle - 60)*PI / 180) + 1.05)*0.8;
		Mat rot_mat = getRotationMatrix2D(center, angle, scale);
		warpAffine(src, dst2, rot_mat, src.size(), INTER_LINEAR, BORDER_CONSTANT, Scalar());
		imshow("Affine Transform Test2", dst2);
		if (waitKey(30) >= 0)//返回30ms内按下的键值,否则返回-1.
			break;

	}
	return 0;
}


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM