如何在OpenCV中绘制图像的3D直方图

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在OpenCV中绘制图像的3D直方图相关的知识,希望对你有一定的参考价值。

[更新]我找到更多的例子,我现在可以做到Can I plot several histograms in 3d?

我知道这个问题已经问过了,我试试这个How to calculate 3D histogram in python using open CV但它不起作用

我想要像这样的3D histogram

这就是我现在拥有的My Graph

hsv_image = cv2.cvtColor(image, cv2.COLOR_BGR2HSV)
h,s,v = cv2.split(hsv_image)

fig = plt.figure(figsize=(8,7))
ax = plt.axes(projection='3d'), plt.title("Histogram 3D")
plt.hist(h.ravel(), 256, [0, 256])
plt.hist(s.ravel(), 256, [0, 256])
plt.hist(v.ravel(), 256, [0, 256])

我可以使用plt.hist()绘制3d条形图或者我还需要更多东西吗?

我一直在寻找图像教程的3d直方图,但我找不到任何

答案

这是我的结果:enter image description here


码:

#!/usr/bin/python3
# 2017.12.20 14:00:12 CST
# 2017.12.20 14:26:08 CST

from mpl_toolkits.mplot3d import Axes3D
import matplotlib.pyplot as plt
import numpy as np
import cv2

img = cv2.imread("panda.png")
hsv = cv2.cvtColor(img, cv2.COLOR_BGR2HSV)
h,s,v = cv2.split(hsv)
fig = plt.figure()

ax = fig.add_subplot(111, projection='3d')
for x, c, z in zip([h,s,v], ['r', 'g', 'b'], [30, 20, 10]):
    xs = np.arange(256)
    ys = cv2.calcHist([x], [0], None, [256], [0,256])
    cs = [c] * len(xs)
    cs[0] = 'c'
    ax.bar(xs, ys.ravel(), zs=z, zdir='y', color=cs, alpha=0.8)

ax.set_xlabel('X')
ax.set_ylabel('Y')
ax.set_zlabel('Z')
plt.show()

以上是关于如何在OpenCV中绘制图像的3D直方图的主要内容,如果未能解决你的问题,请参考以下文章

利用OpenCV的函数calcHist()计算出图像的直方图数据后绘制图像的直方图

利用OpenCV的函数calcHist()计算出图像的直方图数据后绘制图像的直方图

OpenCV学习笔记13-图像直方图的介绍及代码实现

OpenCV RGB直方图计算与绘制----calcHist()函数normalize()函数

opencv——图像直方图与反向投影

opencv:绘制图像直方图