《视觉slam十四讲》初学小白笔记(4)

opencv的简单使用

#include<iostream>
#include<chrono>

using namespace std;

#include<opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>

int main(int argc,char** argv){
    //默认构造函数,创建矩形存储图像
    cv::Mat image;

    //读取指定路径下的图片
    image=cv::imread(argv[1]);
    
    //判断图像文件是否正确读取
    if(image.data==nullptr){
      cout<<"文件"<<argv[1]<<"不存在"<<endl;
      return 0;
    }
    
    //文件顺利读取,首先输出一些基本信息
    cout<<"图像宽度为:"<<image.cols<<",高度为:"<<image.rows<<",通道数为:"<<image.channels()<<endl;
    cv::imshow("image",image);
    cv::waitKey(0);//不加这一句,图片无法显示出来  表示程序会无限制的等待用户的按键事件
    
    //判断image的类型
    if(image.type()!=CV_8UC1&&image.type()!=CV_8UC3){ //CV_8UC1彩色图片,CV_8UC3灰色图片
      //如果图像不符合要求
      cout<<"请输入一张彩色或灰色图片"<<endl;
      return 0;
    }
    
    //遍历图像,可用于随机访问像素
    //使用std::chrono给算法计时
    chrono::steady_clock::time_point t1=chrono::steady_clock::now();
    for(size_t y=0;y<image.rows;y++){
      for(size_t x=0;x<image.cols;x++){
	//访问位于(x,y)处的像素
	//用cv::Mat::ptr获得图像的行指针
	unsigned char* row_ptr=image.ptr<unsigned char>(y);//row_ptr为第y行的头指针
	unsigned char* data_ptr=&row_ptr[x*image.channels()];//data_ptr指向待访问的像素数据
	
	//输出该像素的每一个通道,如果是灰度图只有一个通道
	for(int c=0;c!=image.channels();c++){
	  unsigned char data=data_ptr[c];//data为I(x,y)第c个通道的值
	}
      }
    }
    chrono::steady_clock::time_point t2=chrono::steady_clock::now();
    chrono::duration<double> time_used=chrono::duration_cast<chrono::duration<double>>(t2-t1);
    cout<<"图像遍历用时:"<<time_used.count()<<" s"<<endl;
    cv::waitKey(0);
    
    //cv::Mat的拷贝
    //直接赋值
    cv::Mat image_brother=image;
    image_brother(cv::Rect(0,0,100,100)).setTo(0);//将左上角100*100处像素置0(左上角黑一块)
    cv::imshow("image",image);	//直接赋值会导致原图像也跟着改变
    cv::waitKey(0);
    
    //clone函数来拷贝
    cv::Mat image_clone=image.clone();
    image_clone(cv::Rect(0,0,200,200)).setTo(255);
    cv::imshow("image",image);	//clone函数不会改变原图像
    cv::imshow("image clone",image_clone);
    cv::waitKey(0);
    
    cv::destroyAllWindows();
    return 0;
}

运行结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在《视觉SLAM十四》中,章节安排如下: 1. 数学基础部分:介绍这本书的基本信息,包括自测题。概述SLAM系统的组成和各模块的工作。介绍三维空间运动、李群和李代数、针孔相机模型以及非线性优化。完成一个曲线拟合的实验。 2. SLAM技术部分:解特征点法的视觉里程计,包括特征点的提取与匹配、对极几何约束的计算、PnP和ICP等方法。学习直接法的视觉里程计,包括光流和直接法的原理,并使用g2o实现一个简单的RGB-D直接法。构建一个视觉里程计框架,解决优化和关键帧选择的问题。深入讨论后端优化,包括Bundle Adjustment和位姿图的优化。介绍回环检测和地图构建的方法。最后,介绍当前的开源SLAM项目和未来的发展方向。 另外,对于四元数的学习,可以先了解复平面的概念。复平面是一个用来描述复数的平面,其中实部和虚部分别对应平面的横坐标和纵坐标。了解复平面后,可以开始学习四元数的概念和应用。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [视觉SLAM十四笔记](https://blog.csdn.net/dada19980122/article/details/111404967)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [【视觉SLAM十四笔记【逐行代码带你解析】【适合纯小白 ps:因为我就是】(持续更新中)](https://blog.csdn.net/R_ichun/article/details/131964588)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT0_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值