返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >OpenCV实现相机标定示例详解
  • 854
分享到

OpenCV实现相机标定示例详解

2024-04-02 19:04:59 854人浏览 八月长安
摘要

目录环境准备相机标定棋盘格图片实时显示相机的画面在线标定实时显示相机画面,按键保存能检测到角点的棋盘格图片离线标定畸变矫正环境准备 vs2015+OpenCV4.10安装与配置 相机

环境准备

vs2015+OpenCV4.10安装与配置

相机标定

棋盘格图片

可以自己生成,然后打印到A4纸上。(也可以去TB买一块,平价买亚克力板的,不反光买氧化铝材质,高精度买陶瓷的)



int generateCalibrationPicture()
{
	//Mat frame = imread("3A4.bmp"); // cols*rows = 630*891  
	Mat frame(1600, 2580, CV_8UC3, Scalar(0, 0, 0));
	int nc = frame.channels();
	int nWidthOfROI = 320;
	for (int j = 10; j<frame.rows - 10; j++)
	{
		uchar* data = frame.ptr<uchar>(j);
		for (int i = 10; i<(frame.cols - 10)*nc; i += nc)
		{
			if ((i / nc / nWidthOfROI + j / nWidthOfROI) % 2)
			{
				// bgr  
				data[i / nc*nc + 0] = 255;
				data[i / nc*nc + 1] = 255;
				data[i / nc*nc + 2] = 255;
			}
		}
	}
	imshow("test", frame);
	//imwrite("3.bmp", frame);
	waiTKEy(0);
	return 0;
}

实时显示相机的画面

准备一个相机,我的是usb相机(罗技100多的)。


int displayCameraRealTime()
{
	//1.从摄像头读入视频
	VideoCapture capture(0);
	if (!capture.isOpened()) {
		std::cout << "无法开启摄像头!" << std::endl;
		return -1;
	}
	//2.循环显示每一帧
	while (1)
	{
		Mat cam;
		capture >> cam;//获取当前帧图像
		namedWindow("实时相机画面", WINDOW_AUTOSIZE);
		imshow("实时相机画面", cam);//显示当前帧图像
							  //imwrite(to_string(i) + ".png", cam);
		waitKey(20);//延时20ms
	}
}

效果如下图:

在线标定

把打印的棋盘格固定在板子上



int calibrateCameraRealTime(int numBoards, cv::Size boardSize, float squareSize = 1, int delay = 50, bool flipHorizontal = false);

实时显示相机画面,按键保存能检测到角点的 棋盘格图片


int saveChessboardImages(cv::Size boardSize, string savePath)
{
	//1.从摄像头读入视频
	VideoCapture capture(0);
	if (!capture.isOpened()) {
		std::cout << "无法开启摄像头!" << std::endl;
		return -1;
	}
	if (savePath != "./")
	{
		myMkdir(savePath);
	}
	//2.循环显示每一帧
	while (1) {
		Mat image0, image;
		capture >> image0;
		// 将图像复制到image
		image0.copyTo(image);
		// 查找标定板(不对称圆网格板)
		vector<Point2f> corners;
		//bool found = findCirclesGrid(image, boardSize, corners, CALIB_CB_ASYMMETRIC_GRID);
		bool found = findChessboardCorners(image, boardSize, corners, CALIB_CB_FAST_CHECK);
		// 画上去
		drawChessboardCorners(image, boardSize, corners, found);
		int action = waitKey(30) & 255;
		// 判断动作
		if (action == ACTION_SPACE) { // 用户按下了空格
			if (found) {
				// 保存图片
				string imgFileName = savePath + getCurrentTime() + ".png";
				imwrite(imgFileName, image0);
				cout << imgFileName << " saved" << endl;
			}
			else {
				printf("%s\n", "未检测到角点");
			}
		}
		else if (action == ACTION_ESC) { // 用户按下了ESC
			break;
		}
		cv::imshow("Calibration", image);
	}
	cv::destroyAllwindows();
	return 1;
}

离线标定



int calibrateCameraOffLine(string imagePath, const Size boardSize, float squareSize = 1);

畸变矫正



int undistortRectifyImage(string paraPath, string imagePath = " ");

矫正效果貌似不明显

完整工程地址

到此这篇关于OpenCV实现相机标定示例详解的文章就介绍到这了,更多相关OpenCV 相机标定内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: OpenCV实现相机标定示例详解

本文链接: https://lsjlt.com/news/158341.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • OpenCV实现相机标定示例详解
    目录环境准备相机标定棋盘格图片实时显示相机的画面在线标定实时显示相机画面,按键保存能检测到角点的棋盘格图片离线标定畸变矫正环境准备 vs2015+opencv4.10安装与配置 相机...
    99+
    2024-04-02
  • OpenCV实现相机标定
    本文实例为大家分享了OpenCV实现相机标定的具体代码,供大家参考,具体内容如下 一、相机与针孔相机模型 1.相机模型 现代科技加持下的相机已经成为制造精密设计巧妙的消费品,相机的光...
    99+
    2024-04-02
  • OpenCV实现相机标定板
    本文实例为大家分享了OpenCV实现相机标定板的具体代码,供大家参考,具体内容如下 1.代码实现 #include <opencv.hpp> #include "h...
    99+
    2024-04-02
  • OpenCV怎么实现相机标定板
    这篇文章主要介绍OpenCV怎么实现相机标定板,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体内容如下1.代码实现#include <opencv.hpp>#include &quo...
    99+
    2023-06-14
  • uniapp自定义相机实现示例详解
    目录自定义相机起因利用livePusher实现使用效果图拓展实现多种自定义相机水印相机身份证相机人像相机自定义相机 起因 由于最近用uniapp调用原生相机容易出现闪退问题,找了很...
    99+
    2023-03-09
    uniapp自定义相机 uniapp 相机实现
  • opencv摄像机标定的实现
    原图 矫正后 我新建了个jz的文件夹放相机矫正所需要拍摄的图片,如下:共12张   # coding:utf-8 import cv2 import nu...
    99+
    2024-04-02
  • OpenCV相机标定的全过程记录
    目录一、OpenCV标定的几个常用函数findChessboardCorners()棋盘格角点检测cv::drawChessboardCorners()棋盘格角点的绘制find4Qu...
    99+
    2024-04-02
  • opencv如何实现摄像机标定
    小编给大家分享一下opencv如何实现摄像机标定,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!原图矫正后我新建了个jz的文件夹放相机矫正所需要拍摄的图片,如下:共...
    99+
    2023-06-29
  • Python OpenCV实现图形检测示例详解
    目录1. 轮廓识别与描绘1.1 cv2.findComtours()方法1.2 cv2.drawContours() 方法1.3 代码示例2. 轮廓拟合2.1 矩形包围框拟合 - c...
    99+
    2024-04-02
  • OpenCV实现相机校正
    本文实例为大家分享了OpenCV实现相机校正的具体代码,供大家参考,具体内容如下 1. 相机标定 根据张正友校正算法,利用棋盘格数据校正对车载相机进行校正,计算其内参矩阵,外参矩阵和...
    99+
    2024-04-02
  • Python OpenCV 单目相机标定、坐标转换相关代码(包括鱼眼相机)
    前言   本文不讲原理,只关注代码,有很多博客是讲原理的,但是代码最多到畸变矫正就结束了,实际上就是到 OpenCV 官方示例涉及的部分。   在官方示例中使用黑白棋盘格求解了相机的内外参和畸变系数,...
    99+
    2023-09-23
    python opencv 计算机视觉
  • C#实现自定义动画鼠标的示例详解
    目录实践过程效果代码实践过程 效果 代码 public partial class Form1 : Form { public Form1() { ...
    99+
    2022-12-20
    C#自定义动画鼠标 C# 动画鼠标 C# 鼠标
  • Qt+OpenCV实现目标检测详解
    目录一、创建项目&UI设计二、代码与演示演示效果拓展阅读一、创建项目&UI设计 创建项目,UI设计如下 文件类型判断 简单的判断文件类型 QString file(...
    99+
    2024-04-02
  • JS实现大数相加大数相乘示例详解
    目录JS大数相加、大数相乘一、实现两个大数相加二、实现两个大数相乘JS大数相加、大数相乘 JavaScript 只有一种数字类型,可以使用也可以不使用小数点来书写数字。 在 Java...
    99+
    2022-11-13
    JS大数相加相乘 JS大数
  • 基于pythonopencv单目相机标定的示例代码
    相机固定不动,通过标定版改动不同方位的位姿进行抓拍 import cv2 camera=cv2.VideoCapture(1) i = 0 while 1: (grabbe...
    99+
    2024-04-02
  • Pygame实现监听鼠标示例详解
    目录初始化参数鼠标移动鼠标点击位置输出鼠标位置及其对用的按钮完整代码 pygame如何捕捉鼠标的活动 初始化参数 import pygame, sys from pygame.l...
    99+
    2024-04-02
  • OpenCV实现简易标定板
    本文实例为大家分享了OpenCV实现简易标定板的具体代码,供大家参考,具体内容如下 使用OpenCV生成标定板图片,然后找高精度打印机进行打印,贴在硬板上,就可以得到一个简易的标定板...
    99+
    2024-04-02
  • python OpenCV实现图像特征匹配示例详解
    目录目标Brute-Force匹配器的基础使用ORB描述符进行Brute-Force匹配什么是Matcher对象?带有SIFT描述符和比例测试的Brute-Force匹配基于匹配器的...
    99+
    2023-05-17
    python OpenCV图像特征匹配 python OpenCV
  • C++ OpenCV实现物体尺寸测量示例详解
    目录前言一、图像透视矫正二、物体定位三、尺寸测量四、效果显示五、源码总结前言 本文将使用OpenCV C++ 进行物体尺寸测量。具体来说就是先定位到待测物体的位置,然后测量物体的宽高...
    99+
    2024-04-02
  • opencv锁定鼠标定位的实现
    目录控制鼠标鼠标事件:创建方法完整学习代码控制鼠标 opencv允许我们对窗口的鼠标动作做出响应: setMouseCallback(winname,callback,userdat...
    99+
    2023-02-16
    opencv锁定鼠标定位 opencv 鼠标定位
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作