【问题标题】:Plotting image rgb value against function of time根据时间函数绘制图像 rgb 值
【发布时间】:2017-08-14 16:36:57
【问题描述】:

有没有办法只计算一个数字来表示图像中像素的 rgb 值?我试图将我的 ROI 颜色随 time.x 的变化可视化为我的时间函数和 y 作为我的 rgb 值。最初,我平均得到的像素 rgb 值。例如 [84 90 135] = 103 并将其绘制为我的第一点,但我意识到这可能是错误的表示?[135 90 84] 也给出了相同的平均值,但它们实际上代表不同的颜色?这意味着我会得到错误的图表。

编辑:很抱歉最近更新试图修复我的图表。 我不知道为什么,但我无法为我的数据绘制折线图,​​仅适用于点标记或圆形标记

当图像接近像这样的白色时,试图跟踪图像的颜色数据

我预计当它接近白色时该值会继续增加,因为白色的十进制代码是 255 255 255,所以趋势应该向上倾斜?但是我得到了结果,这是我在绘制图像的 b、g、r 值时得到的结果,它并没有真正向我显示太多信息。

。代码如下:

import cv2
import numpy as np
import matplotlib.pyplot as plt


path = 'R:\\xx\\'
path1 = 'R:\\xx\\'

def BlueComponent(im_file):
    im = cv2.imread(im_file) #return blue value
    im1 = im[788, 526]
    b = im1[0]
    return b

def GreenComponent(im_file):
    im = cv2.imread(im_file) #return green value 
    im1 = im[788, 526]
    g = im1[1]
    return g

def RedComponent(im_file): #return red value 
    im = cv2.imread(im_file)
    im1 = im[788, 526]
    r = im1[2]
    return r


myBlueList = []
myGreenList = []
myRedList = []
myList = []
num_images = 99 # number of images

dotPos = 0
for i in range(1770, 1869): # loop to auto-generate image names and run prior function 
    image_name = path + 'Cropped_Aligned_IMG_' + str(i) + '.png' # for loop runs from image number 1770 to 1868
    myBlueList.append(BlueComponent(image_name))
    myGreenList.append(GreenComponent(image_name))
    myRedList.append(RedComponent(image_name))
    myList.append(dotPos)
    dotPos = dotPos + 0.5

print(myList)
print(myBlueList)
print(myGreenList)
print(myRedList)


for k in range(1770,1869):
    a = 'Cropped_Aligned_IMG_' + str(k)
    image_name = path + a + '.png'
    img_file = cv2.imread(image_name)

y = [myGreenList]
x = [myList]
y1 = [myBlueList]
y2 = [myRedList]


plt.xticks(np.arange(0.0 ,50.0, 0.5), rotation='vertical' )
plt.plot(x, y, 'g.-')
plt.plot(x, y1, 'b.-')
plt.plot(x, y2, 'r.-')
plt.title('Color Decimal Code Against Time')
plt.xlabel('Time(Hours)', labelpad=10)
plt.ylabel('Colour Code')
plt.show()

【问题讨论】:

  • r*(256^2) + g*256 + b?
  • 另外,为什么不为每个组件绘制一条线?
  • @ason​​gtoruin 任何我可以参考这个公式的来源?
  • 它只是一个基本的 256 编码。
  • @ason​​gtoruin 我有一个图表应该是什么样子的趋势,因为颜色从淡黄色(最初的图像)变为最后图像的白色......我不确定是否在绘制每个组件将代表任何东西。

标签: python opencv image-processing matplotlib colors


【解决方案1】:

如果您只对颜色感兴趣,您可以将 RGB touples 转换为 Hue 值。如果饱和度和强度也很重要,这当然是不够的。

这对于中性值当然会失败。

详情请上网搜索。

MIN = min(r,g,b)

MAX = max(r,g,b)

色调 =

  • 0 如果 MIN == MAX
  • 60° ⋅ (g - b)/(MAX - MIN) 如果 MAX == r
  • 60° ⋅ (2 + (b - r)/(MAX - MIN)) 如果 MAX == g
  • 60° ⋅ (4 + (r - g)/(MAX - MIN)) 如果 MAX == b

如果您只对变化感兴趣,而不是对哪种颜色感兴趣,例如可以使用 RGB touples 之间的距离。

cmets 中已经建议的另一个选项是组成一个 3 字节的值。

您无法以直观的方式完全可视化 1d 中的 3d 变化。

【讨论】:

  • 这就是我的第一个想法,不幸的是他说“颜色变化是从淡黄色(最初的图像)到最后图像的白色”,在 HSV 中它只是转换为饱和度(可能还有一点价值)。
  • @piglet 将同时尝试您的建议...将根据我得到的结果进行更新。
  • @Piglet 的 Hue 值是否与 HSV 颜色格式相同?我实际上可以立即将我的色彩空间更改为 HSV 并获取色调数据,而不是使用您的公式手动转换?
  • @SacreD Hue 有不同的定义。根据您使用的色彩空间(HSI、HSV、HSL),值会略有不同。但这对您的应用程序无关紧要。只需使用 HSV touple 的 H(色调)组件。
猜你喜欢
  • 2016-07-22
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2023-03-02
  • 2021-06-03
  • 2012-08-03
  • 1970-01-01
  • 2014-05-26
相关资源
最近更新 更多