java直方图算法,用 Java 使用 OpenCV 编写直方图处理程序

用Java使用OpenCV编写直方图处理程序:

(一)计算一个图像的直方图

importjava.util.ArrayList;

importorg.opencv.core.Core;

importorg.opencv.core.CvType;

importorg.opencv.core.Mat;

importorg.opencv.core.MatOfFloat;

importorg.opencv.core.MatOfInt;

importorg.opencv.core.Scalar;

importorg.opencv.imgcodecs.Imgcodecs;

importorg.opencv.imgproc.Imgproc;

public class MyHistograms {

// 加载OpenCV本地库

static {

System.loadLibrary(Core.NATIVE_LIBRARY_NAME );

}

public static void main(String[]args) {

Mat image = Imgcodecs.imread("mylena.png");

Mat gray = new Mat(image.height(), image.width(), CvType.CV_8U, new Scalar(0)); Imgproc.cvtColor(image, gray, Imgproc.COLOR_BGR2GRAY);

Mat hist = new Mat(256, 1, CvType.CV_8U, new Scalar(0));

ArrayListhistsSource = new ArrayList();

histsSource.add(gray);

Imgproc.calcHist(histsSource, new MatOfInt(0), new Mat(), hist, new MatOfInt(256), new MatOfFloat(0f, 256f));

System.out.println(hist);

System.out.println(hist.dump());

intpixAll = gray.rows() * gray.cols();

Mat histNorm = new Mat(hist.rows(), hist.cols(), hist.type());

Core.divide(hist, new Scalar(pixAll), histNorm);

System.out.println(histNorm);

System.out.println(histNorm.dump());

}

}

直方图从统计学的角度表征图像,它可以反映图片的整体亮度和对比度:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
反向投影是一种用于图像分割的技术,它可以将图像中某个特定区域中的像素值与整个图像中的像素值进行比较,从而实现对该区域的分离。OpenCV中提供了多通道直方图算法来实现反向投影,以下是一些示例代码: ```c++ #include <opencv2/opencv.hpp> using namespace cv; int main() { Mat image, hsv; image = imread("image.jpg"); // 转换为HSV格式 cvtColor(image, hsv, COLOR_BGR2HSV); // 设置H、S通道的范围 float h_ranges[] = { 0, 180 }; float s_ranges[] = { 0, 256 }; const float* ranges[] = { h_ranges, s_ranges }; // 设置H、S通道的数量 int h_bins = 16, s_bins = 16; int hist_sizes[] = { h_bins, s_bins }; // 计算图像的直方图 MatND hist; int channels[] = { 0, 1 }; calcHist(&hsv, 1, channels, Mat(), hist, 2, hist_sizes, ranges, true, false); // 归一化直方图 normalize(hist, hist, 0, 255, NORM_MINMAX, -1, Mat()); // 反向投影 Mat dst; calcBackProject(&hsv, 1, channels, hist, dst, ranges, 1, true); // 显示结果 imshow("image", image); imshow("back projection", dst); waitKey(0); return 0; } ``` 在这个示例中,我们首先将图像转换为HSV格式,然后计算出H、S通道的直方图,并将其归一化。接下来,我们使用`calcBackProject`函数来计算反向投影图像,并将结果显示出来。 注意,我们在调用`calcHist`和`calcBackProject`函数时,都需要指定通道数量和通道范围。在本例中,我们使用了两个通道(H、S),并将H通道的范围设置为0到180,S通道的范围设置为0到256。我们还指定了16个bin用于计算直方图,这个值可以根据实际需要进行调整。 希望这些代码可以对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值