以下用OpenCV实现获取图像中某点的颜色值,并设置某点区域的颜色
#include <opencv2\opencv.hpp> using namespace cv; vector<char*> listFiles(const char * dir); int main() { Mat img = imread("D:\\OpencvTest\\test.jpg"); Scalar color = img.at<Vec3b>(150, 150);//读取原图像(150, 150)的BGR颜色值,如果是灰度图像,将Vec3b改为uchar for (size_t row=0; row<50; row++) for (size_t col=0;col<img.cols;col++) { //设置原图像中某点的BGR颜色值 img.at<Vec3b>(row, col) = Vec3b(color(0), color(1), color(2)); } cv::circle(img, Point(150, 150), 4, cv::Scalar(0, 0, 255));//在图像中画出特征点,2是圆的半径 imshow("img", img); waitKey(0); return 0; }
运行效果:
补充知识:opencv中对图片的二值化操作并提取特定颜色区域
我就废话不多说了,大家还是直接看代码吧!
#include<opencv2/core/core.hpp> #include<opencv2/highgui/highgui.hpp> #include<opencv2/imgproc/imgproc.hpp> #include <vector> #include<iostream> #include<string> using namespace std; using namespace cv; //bgr图像 Mat bgr; //HSV图像 Mat hsv; //色相 int hmin = 0;//h分量取下限 int hmax = 180;//h分量取上限 int h_Max = 180; //h分量可取的最大值 //饱和度 int smin = 0;//s分量取下限 int smax = 255;//s分量取上限 int s_Max = 255;//s分量可取的最大值 //亮度 int vmin = 0;//v分量取下限 int vmax = 255;//v分量取上限 int v_Max = 255;//v分量可取的最大值 string windowName = "src"; string dstName = "dst"; //输出图像 Mat dst; //回调函数 void callBack(int, void*) { //输出图像分配内存 dst = Mat::zeros(bgr.size(), bgr.type()); Mat mask; inRange(hsv, Scalar(hmin, smin, vmin), Scalar(hmax, smax, vmax), mask); for (int r = 0; r < bgr.rows; r++) { for (int c = 0; c < bgr.cols; c++) { if (mask.at<uchar>(r, c) == 255) { dst.at<Vec3b>(r, c)[0] = bgr.at<Vec3b>(r, c)[0]; dst.at<Vec3b>(r, c)[1] = bgr.at<Vec3b>(r, c)[1]; dst.at<Vec3b>(r, c)[2] = bgr.at<Vec3b>(r, c)[2]; } } } imshow("mask", mask); //输出图片 imshow("dst", dst); } int main() { //输入图片 Mat srcImage = imread("C:\\Users\\Administrator\\Desktop\\0001.jpg"); if (!srcImage.data){ cout << "图片读取失败" << endl; system("pause"); return -1; } imshow(windowName, srcImage); bgr = srcImage; //颜色空间转换 cvtColor(bgr, hsv, COLOR_BGR2HSV); //定义输出图像的显示窗口 namedWindow(dstName, 0); //调节色相 H createTrackbar("hmin", dstName, &hmin, h_Max, callBack); createTrackbar("hmax", dstName, &hmax, h_Max, callBack); //调节饱和度 S createTrackbar("smin", dstName, &smin, s_Max, callBack); createTrackbar("smax", dstName, &smax, s_Max, callBack); //调节亮度 V createTrackbar("vmin", dstName, &vmin, v_Max, callBack); createTrackbar("vmax", dstName, &vmax, v_Max, callBack); callBack(0, 0); waitKey(0); return 0; }
以上这篇使用OpenCV获取图像某点的颜色值,并设置某点的颜色就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
函数功能:设置图片对象指定坐标点的颜色值 函数方法 newimg = image.setColor(oldimg,x,y,color) 参数 类型 必填 说明 oldimg userdata 是 需要操作的图片对象 x number 是 需要设置颜色值的图片对象的横坐标 y number 是 需要设置颜色值的图片对象的纵坐标 color number 是 需要设置的十六进制颜色值 返回值 类型 说
函数名称:获取图片对象指定坐标点的颜色 函数功能: 获取图片对象指定坐标点的颜色 函数方法 color = image.getColor(img,x,y) 参数 类型 必填 说明 img userdata 是 需要操作的图片对象 x number 是 将获取颜色值的屏幕横坐标 y number 是 将获取颜色值的屏幕纵坐标 返回值 类型 说明 r,g,b number 该点颜色的 R,G,B 值,
函数名称:获取图片对象指定坐标点的颜色 函数功能: 获取图片对象指定坐标点的颜色 函数方法 color = image.getColor(image,x,y) 参数 类型 必填 说明 img userdata 是 需要操作的图片对象 x number 是 将获取颜色值的屏幕横坐标 y number 是 将获取颜色值的屏幕纵坐标 返回值 类型 说明 color number 十六进制颜色值 函数用例
我想做个散点图 它有一个不是x,y值,而是另一个改变点颜色的值 如果它的价值超过某个价值 只有我找到了 MPAndroidChart,根据y轴值在条形图中设置不同的颜色 这 但在我的例子中,有一个特殊的值对图没有影响 我能做些什么来解决这个问题? 请帮帮我
对于给定的多色PNG(带透明度),最好的/快速的惯用方式是什么: 创建一个重复的 关于SO有几个相关的问题,但是我还没有找到有效的方法。
嘿,我正在尝试做一个程序,它加载一个彩色图像作为灰度画布,然后返回颜色点击像素。当setrgb()方法没有做它应该做的事情时,我就被困在这里了。我已经通过getRGB()从原始图像中复制了颜色,并使用setRGB()将其分配给新图像。我试图输出两个像素颜色值,但他们不一样。请帮我解决这个问题。以下是到目前为止的代码: