gpt4 book ai didi

OpenCV实现简易标定板

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 28 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章OpenCV实现简易标定板由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

本文实例为大家分享了OpenCV实现简易标定板的具体代码,供大家参考,具体内容如下 。

使用OpenCV生成标定板图片,然后找高精度打印机进行打印,贴在硬板上,就可以得到一个简易的标定板.

废话不多说,代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
//编程环境:VS2013, X64,OpenCV3.0.0
#include <iostream>
#include <opencv2\core\core.hpp>
#include <opencv2\opencv.hpp>
 
using namespace std;
using namespace cv;
 
int main(){
         //单位转换
  int dot_per_inch = 96;  //我的电脑是96DPI(dot per inch)
  double cm_to_inch = 0.3937; //1cm=0.3937inch
  double inch_to_cm = 2.54;   //1inch = 2.54cm
  double inch_per_dot = 1.0 / 96.0;
 
         //自定义标定板
  double blockSize_cm = 1.3; //方格尺寸:边长1.3cm的正方形
         int blockNum = 8; //8*8个方格
 
 
  int blockSize = ( int )(blockSize_cm /inch_to_cm *dot_per_inch);
  cout << blockSize << endl;
 
  int imageSize = blockSize * blockNum;
  cout << imageSize << endl;
  Mat chessBoard(imageSize, imageSize, CV_8UC3, Scalar::all(0));
  unsigned char color = 0;
 
  for ( int i = 0; i < imageSize; i = i + blockSize){
   color = ~color;
   for ( int j = 0; j < imageSize; j = j + blockSize){
    Mat ROI = chessBoard(Rect(i, j, blockSize, blockSize));
    ROI.setTo(Scalar::all(color));
    color = ~color;
   }
  }
  imshow( "Chess board" , chessBoard);
         imwrite( "C:\\Users\\ComputerName\\Pictures\\chessBoard.jpg" ,chessBoard);
  cvWaitKey(3000);
         return 0;
}

OpenCV实现简易标定板

声明:代码红色部分是标定板生成的主要代码,参考的 是别人的,具体出处找不到了。单位换算是我后来添加的,方便大家根据镜头视场生成合理的标定板.

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我.

原文链接:https://blog.csdn.net/whhit111/article/details/70231887 。

最后此篇关于OpenCV实现简易标定板的文章就讲到这里了,如果你想了解更多关于OpenCV实现简易标定板的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com