OpenCV访问像素点的灰度值

 

1.Mat矩阵数值的存储方式

            这里以指针的方式访问图像素为例

         (1)单通道

 

              定义一个单通道图像:

                 

   cv::Mat img_1 = (320, 640, CV_8UC1, Scalar(0));

            对于单通道M(i,j)即为第i行j列的其灰度值;程序中表示为:

                   

 img_1.ptr<uchar>(i)[j];

         (2)多通道

 

            这里以RGB图像为例,每一个子列依次为B、G、R,,第一个分量是蓝色,第二个是绿色,第三个是红色。

           定义一个3通道BGR图像:

                 

  cv::Mat img_1 = (320, 640, CV_8UC3, Scalar(0, 0 ,0));

           对于多通道M(i,j*3)即为第i行j列的B通道其灰度值,M(i,j*3+1) 即为第i行j列的G通道其灰度值,M(i,j*3+1) 即为第i行j列的B通     道其灰度值;程序中表示为:

                  第i行j列的B通道其灰度值:

                     

    img_1.ptr<uchar>(i)[j*3];

                  第i行j列的G通道其灰度值:

                         

 img_1.ptr<uchar>(i)[j*3+1];

                 第i行j列的R通道其灰度值:
                       

 img_1.ptr<uchar>(i)[j*3+2];

2.示例程序,以三种方法(指针,at,迭代器)


 

获得图像像素值#include <iostream>#include <vector>#include <algorithm>#include <opencv2/core/core.hpp>#include <opencv2/imgproc/imgproc.hpp>#include <opencv2/opencv.hpp>using namespace std;using namespace cv;void get_setImagePixel3(char *imagePath, int x, int y){Mat image = imread(imagePath, 1);//得宽高int w = image.cols;int h = image.rows;int channels = image.channels();if (channels == 1){//得到初始位置的迭代器 Mat_<uchar>::iterator it = image.begin<uchar>();//得到终止位置的迭代器 Mat_<uchar>::iterator itend = image.end<uchar>();int pixel = *(it + y * w + x);cout << "灰度图像,处的灰度值为" << pixel << endl;}else{//得到初始位置的迭代器 Mat_<Vec3b>::iterator it = image.begin<Vec3b>();//得到终止位置的迭代器 Mat_<Vec3b>::iterator itend = image.end<Vec3b>();//读取it = it + y * w + x;int b = (*it)[0];cout << b << endl;int g = (*it)[1];cout << g << endl;int r = (*it)[2];cout << r << endl;//设置像素值(*it)[0] = 255;(*it)[1] = 255;(*it)[2] = 255;}imshow("cc", image);}int main(){vector<int> v = {1,2,3,4,6};cout << "*********通过指针访问像素的灰度值********************"  << endl;//通过指针访问像素的灰度值//单通道Mat img1(20, 30, CV_32FC1, Scalar(0));img1.ptr<float>(19)[25] = 23456.1789;cout << "img(19,25):" << img1.ptr<float>(19)[25] <<endl;//多通道,创建一个B、G、R通道灰度值为0的图像,图像大小20*30,每个灰度值为16位无符号2进制表示Mat img2(20, 30, CV_16UC3, Scalar(0, 0, 0));cout << "img(1,2):" << int(img1.ptr<uchar>(19)[25]) << endl;Mat img = imread("test1.jpg");int numRow = img.rows;int numCol = img.cols;int numCol_channel = img.cols*img.channels();cout << "numRow:" << numRow << endl;cout << "numCol:" << numCol << endl;cout << "numCol_channel:" << numCol_channel << endl;cout << "45行,483列B通道灰度值" << int(img.ptr<uchar>(45)[483*3]) << endl;cout << "45行,483列G通道灰度值" << int(img.ptr<uchar>(45)[483*3+1]) << endl;cout << "45行,483列R通道灰度值" << int(img.ptr<uchar>(45)[483*3+2]) << endl;Mat img_B(numRow, numCol, CV_8UC3, Scalar(0, 0, 0));Mat img_G(numRow, numCol, CV_8UC3, Scalar(0, 0, 0));Mat img_R(numRow, numCol, CV_8UC3, Scalar(0, 0, 0));for (int i = 0; i < numRow; i++){for (int j = 0; j < numCol; j++){img_B.ptr<uchar>(i)[j*3] = img.ptr<uchar>(i)[j*3];img_G.ptr<uchar>(i)[j*3+1] = img.ptr<uchar>(i)[j*3+1];img_R.ptr<uchar>(i)[j*3+2] = img.ptr<uchar>(i)[j*3+2];}}imshow("img", img);imshow("img_B", img_B);imshow("img_G", img_G);imshow("img_R", img_R);cout << endl;cout << endl;cout << endl;cout << "*********at只适合灰度值为8位的图像********************" << endl;//注意:at只适合灰度值为8位的图像//单通道Mat img3(20, 30, CV_8UC1, Scalar(0));cout << "img(7,8)" << int(img3.at<uchar>(7, 8)) << endl;//多通道Mat img4(20, 30, CV_8UC3, Scalar(0));//BGR通道cout << "B通道灰度值" << int(img4.at<Vec3b>(3, 4)[0]) << endl;cout << "G通道灰度值" << int(img4.at<Vec3b>(3, 4)[1]) << endl;cout << "R通道灰度值" << int(img4.at<Vec3b>(3, 4)[2]) << endl;waitKey(0);system("pause");return 0;}

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/350493.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

asp.net中大文件下载

因为IIS支持的最大文件为int32的最大值位数的文件下载&#xff0c;所以&#xff0c;超过2G的文件无法通过IIS进行下载。 通过网上查找的资料&#xff0c;如下可实现文件的下载&#xff0c;使用filestream进行下载。 public void download(){System.IO.Stream iStream null;byt…

Java的终结器仍然存在

当我第一次学习Java并从C 过渡到Java时&#xff0c;我记得我经常被告知&#xff0c;经常读到它不应该像C 析构函数那样对待Java终结器&#xff0c;也不应该依靠它。 该建议的频率和坚持性对我产生了影响&#xff0c;以至于我无法回忆起我上一次编写finalize&#xff08;&#x…

时隙aloha协议仿真程序_工控ModbusTCP/IP协议仿真环境搭建

01ModbusTCP/IP协议简介Modbus TCP/IP是简单的、中立厂商的用于管理和控制自动化设备的MODBUS系列通讯协议的派生产品。它覆盖了使用TCP/IP协议的“intranet”和“internet”环境中MODBUS报文的用途。协议的最通用用途是为诸如PLC’S&#xff0c;I/O模块&#xff0c;以及连接其…

vector的初始化及常用操作

1.vector的初始化&#xff1a;可以有五种方式,举例说明如下&#xff1a; &#xff08;1&#xff09; vector<int> a(10); //定义了10个整型元素的向量&#xff08;尖括号中为元素类型名&#xff0c;它可以是任何合法的数据类型&#xff09;&#xff0c;但没有给出初值&a…

查看Linux版本

suse版本 lsb_release -a suse版本之间差距还是有的&#xff0c;在suse12.2跑的脚本没有问题&#xff0c;到suse12.4上就出现问题了。 centos版本 cat /etc/redhat-release 转载于:https://www.cnblogs.com/jkhere/p/10900659.html

ps法线贴图插件_法线与置换贴图原理讲解以及烘焙制作!

​首先在讲解之前先给大家讲解下什么是法线贴图&#xff0c;法线贴图其实就是一张带有颜色的凹凸贴图&#xff0c;分别是有红绿蓝&#xff0c;三种颜色构造而成的&#xff0c;如下图所示&#xff1a;每一个颜色通道分别控制了每个像素的方向&#xff0c;当你把法线贴图用到低解…

从向量中读取元素:

从向量中读取元素&#xff1a; 1通过下标&#xff1a; int a[6] { 1,2,3,4,5,6 }; vector<int> b(a, a 4); for (int i 0; i < b.size() - 1; i) cout << b[i] << " "; 2通过迭代器 int a[6] { 1,2,3,4,5,6 }; vector<int> b(a, …

Nim博弈

忽然发现博弈论是个很好玩的东西哎 之前假期学长讲课的时候就发现这种必胜的战略可以用来坑人做题 这两天终于做了第一道博弈论的题&#xff0c;写篇博客纪念一下 灵感来源&#xff1a;洛谷P1247 Pre-scene 众所周知&#xff0c;李明和Jenny都喜欢Danny&#xff0c;为了争夺Dan…

java调用怎么调用方法区_Java中的方法调用有多昂贵

java调用怎么调用方法区我们都去过那儿。 在查看设计不良的代码的同时&#xff0c;听听作者对人们永远不应该牺牲性能而不是设计的解释。 而且&#xff0c;您不能说服作者摆脱其500行方法&#xff0c;因为链接方法调用会破坏性能。 好吧&#xff0c;这可能在1996年左右是正确的…

python中的np array函数_numpy中的np.ascontiguousarray()函数

"Return a contiguous array (ndim > 1) in memory (C order)."用途ascontiguousarray函数将一个内存不连续存储的数组转换为内存连续存储的数组&#xff0c;使得运行速度更快。C order vs Fortran orderC order 指的是行优先的顺序(Row-major Order)&#xff0c;…

OpenCV版本

#include <opencv2/opencv.hpp>using namespace cv;void main(){/*printf("\t当前使用的opencv版本为 OpenCV"CV_VERSION);getchar();*/std::cout << "\t当前使用的opencv版本为 OpenCV" << CV_VERSION << std::endl;system(&quo…

使用jstat的JVM统计信息

过去&#xff0c;我已经写过关于Oracle和/或OpenJDK Java开发工具包&#xff08;JDK&#xff09;随附的几个命令行工具的信息&#xff0c;但是我从来没有专门写过jstat工具 。 Oracle JDK 9文档Early Access指出jstat用于“监视Java虚拟机&#xff08;JVM&#xff09;统计信息”…

每天一点点之 taro 框架开发 - taro路由及传参

1.路由 taro的路由是自带的&#xff0c;不需要我们额外配置&#xff0c;只需要我们在app.js下config中配置pages即可 class App extends Component {config {pages: [pages/test/test,pages/index/index],} } 2.taro通过api实现跳转&#xff0c;替换 官网地址&#xff1a;taro…

调用支付jsapi缺少参数:total_fee_小程序支付问题怎么解决?

微信小程序开发的过程一定会遇到各种问题&#xff0c;最让人棘手的就是支付问题&#xff0c;因为没有支付做商城类似的小程序就没有办法完成最关键的一步。那么支付失败到底什么原因呢&#xff1f;一下子收集了几个错误类似&#xff0c;希望对你有帮助&#xff1a;No.1{err_cod…

Visual Stutio中win32控制台应用程序、win32项目、MFC项目的区别:

我的理解&#xff0c;我首先把这几个货分为两大类&#xff1b;第一类包括win32控制台应用程序&#xff0c;第二类就是剩下那俩货。而剩下那俩货又有一个包含关系&#xff0c;即win32项目包含mfc。&#xff08;我个人是这个区分的。&#xff09; 一、 区别: &#xff08;1&…

二分图匹配【模板】

传送门&#xff1a; #include <cstdio> #include <cstring> #include <cmath> using namespace std; #define ll long long #define re register const int N1005; inline void read(int &a) {a0;int d1;char ch;while(chgetchar(),ch>9||ch<0)if(…

c++两个数组对比去掉重复的元素_30 数组案例

数组案例案例一&#xff1a;筛选指定数组元素要求&#xff1a;将数组[2,0,6,1,77,0,52,0,25,7]中的0去掉后&#xff0c;形成一个不包含0的新数组。var arr [2,0,6,1,77,0,52,0,25,7];var newArr [];for(var i0; i<arr.length; i){if(arr[i]!0){newArr[newArr.length]arr[i…

排序并记录排序前的索引(类似matlab sort函数)

这里用到vector比较方便。 #include<iostream> #include<vector> #include<algorithm> using namespace std; struct num_label { int num; int label; }; //自定义“大于” bool comp(const num_label &a, const num_label &b) { return a.n…

selenium实现登录百度(自动识别简单验证码)

需要做的工作 0、工程结构 1、代码&#xff1a; ①baidu_login.py 1 import re2 import os3 import sys4 import time5 import random6 from selenium import webdriver7 from PIL import Image, ImageEnhance8 import pytesseract9 from func import base642str, str2base6410…

为什么猫王不应该访问Java

最近&#xff0c;我参与了一个关于Java的Optional类型系统的漫长的Twitter讨论 &#xff0c;该系统区分可空类型和非可空类型以及Elvis运算符 &#xff0c;该运算符允许选择空值安全的成员。 后者被认为是简洁的null处理的杀手级功能&#xff0c;对此我强烈不同意。 我对此的看…