亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

詳解OpenCV For Java環境搭建與功能演示

2024-07-13 10:17:37
字體:
來源:轉載
供稿:網友

OpenCV概述

OpenCV做為功能強大的計算機視覺開源框架,包含了500多個算法實現,而且還在不斷增加,其最新版本已經更新到3.2。其SDK支持Android與Java平臺開發,對于常見的圖像處理需求幾乎都可以滿足,理應成為廣大Java與Android程序員的首先的圖像處理框架。Java中使用OpenCV的配置及其簡單,可以毫不客氣的說幾乎是零配置都可以。

一:配置

配置引入OpenCV相關jar包,首先要下載OpenCV的自解壓版本,下載地址: http://opencv.org/opencv-3-2.html

然后拉到網頁的最下方,下載Windows自解壓開發包

OpenCV,Java環境搭建

下載好了雙擊解壓縮之后找到build路徑,顯示如下:

OpenCV,Java環境搭建

雙擊打開Java文件夾,

OpenCV,Java環境搭建

里面有一個jar直接導入到Eclipse中的新建項目中去, 然后把x64里面的dll文件copy到Eclipse中使用的Java JDK bin和jre/bin目錄下面即可。環境就配置好啦,簡單吧!配置好的最終項目結構:

OpenCV,Java環境搭建

二:加載圖像與像素操作

讀入一張圖像 -, 一句話搞定

Mat src = Imgcodecs.imread(imageFilePath);if(src.empty()) return;

將Mat對象轉換為BufferedImage對象

public BufferedImage conver2Image(Mat mat) { int width = mat.cols(); int height = mat.rows(); int dims = mat.channels(); int[] pixels = new int[width*height]; byte[] rgbdata = new byte[width*height*dims]; mat.get(0, 0, rgbdata); BufferedImage image = new BufferedImage(width, height,        BufferedImage.TYPE_INT_ARGB); int index = 0; int r=0, g=0, b=0; for(int row=0; row<height; row++) {  for(int col=0; col<width; col++) {   if(dims == 3) {    index = row*width*dims + col*dims;    b = rgbdata[index]&0xff;    g = rgbdata[index+1]&0xff;    r = rgbdata[index+2]&0xff;    pixels[row*width+col] = ((255&0xff)<<24) |     ((r&0xff)<<16) | ((g&0xff)<<8) | b&0xff;    }   if(dims == 1) {    index = row*width + col;    b = rgbdata[index]&0xff;    pixels[row*width+col] = ((255&0xff)<<24) |     ((b&0xff)<<16) | ((b&0xff)<<8) | b&0xff;    }  } } setRGB( image, 0, 0, width, height, pixels); return image;}

將BufferedImage對象轉換為Mat對象

public Mat convert2Mat(BufferedImage image) { int width = image.getWidth(); int height = image.getHeight(); Mat src = new Mat(new Size(width, height), CvType.CV_8UC3); int[] pixels = new int[width*height]; byte[] rgbdata = new byte[width*height*3]; getRGB( image, 0, 0, width, height, pixels ); int index = 0, c=0; int r=0, g=0, b=0; for(int row=0; row<height; row++) {  for(int col=0; col<width; col++) {   index = row*width + col;   c = pixels[index];   r = (c&0xff0000)>>16;   g = (c&0xff00)>>8;   b = c&0xff;   index = row*width*3 + col*3;   rgbdata[index] = (byte)b;   rgbdata[index+1] = (byte)g;   rgbdata[index+2] = (byte)r;  } } src.put(0, 0, rgbdata); return src;}

特別要說明一下,BufferedImage與Mat的RGB通道順序是不一樣,正好相反,在Mat對象中三通道的順序為BGR而在BufferedImage中為RGB。

從Mat中讀取全部像素(其中image為Mat類型數據)

int width = image.cols();int height = image.rows();int dims = image.channels();byte[] data = new byte[width*height*dims];image.get(0, 0, data);

遍歷像素操作與保存改變

int index = 0;int r=0, g=0, b=0;for(int row=0; row<height; row++) { for(int col=0; col<width*dims; col+=dims) {  index = row*width*dims + col;  b = data[index]&0xff;  g = data[index+1]&0xff;  r = data[index+2]&0xff;  r = 255 - r;  g = 255 - g;  b = 255 - b;  data[index] = (byte)b;  data[index+1] = (byte)g;  data[index+2] = (byte)r; }}image.put(0, 0, data);

保存Mat對象為圖像文件 - 一句話可以搞定

Imgcodecs.imwrite(filePath, src); 

OpenCV代碼運行與測試

調節明暗程度 - 亮度降低

OpenCV,Java環境搭建

調節明暗程度 - 亮度提升

OpenCV,Java環境搭建

高斯模糊

OpenCV,Java環境搭建

銳化

OpenCV,Java環境搭建

梯度

OpenCV,Java環境搭建

灰度化

OpenCV,Java環境搭建

上述效果完整Java代碼如下:

package com.gloomyfish.opencvdemo;import org.opencv.core.Core;import org.opencv.core.CvType;import org.opencv.core.Mat;import org.opencv.core.Size;import org.opencv.imgproc.Imgproc;public class ImageFilters { /** - 反色處理 - */ public Mat inverse(Mat image) {  int width = image.cols();  int height = image.rows();  int dims = image.channels();  byte[] data = new byte[width*height*dims];  image.get(0, 0, data);  int index = 0;  int r=0, g=0, b=0;  for(int row=0; row<height; row++) {   for(int col=0; col<width*dims; col+=dims) {    index = row*width*dims + col;    b = data[index]&0xff;    g = data[index+1]&0xff;    r = data[index+2]&0xff;    r = 255 - r;    g = 255 - g;    b = 255 - b;    data[index] = (byte)b;    data[index+1] = (byte)g;    data[index+2] = (byte)r;   }  }  image.put(0, 0, data);  return image; } public Mat brightness(Mat image) {  // 亮度提升  Mat dst = new Mat();  Mat black = Mat.zeros(image.size(), image.type());  Core.addWeighted(image, 1.2, black, 0.5, 0, dst);  return dst; } public Mat darkness(Mat image) {  // 亮度降低  Mat dst = new Mat();  Mat black = Mat.zeros(image.size(), image.type());  Core.addWeighted(image, 0.5, black, 0.5, 0, dst);  return dst; } public Mat gray(Mat image) {  // 灰度  Mat gray = new Mat();  Imgproc.cvtColor(image, gray, Imgproc.COLOR_BGR2GRAY);  return gray; } public Mat sharpen(Mat image) {  // 銳化  Mat dst = new Mat();  float[] sharper = new float[]{0, -1, 0, -1, 5, -1, 0, -1, 0};  Mat operator = new Mat(3, 3, CvType.CV_32FC1);  operator.put(0, 0, sharper);  Imgproc.filter2D(image, dst, -1, operator);  return dst; } public Mat blur(Mat image) {  // 高斯模糊  Mat dst = new Mat();  Imgproc.GaussianBlur(image, dst, new Size(15, 15), 0);  return dst; } public Mat gradient(Mat image) {  // 梯度  Mat grad_x = new Mat();  Mat grad_y = new Mat();  Mat abs_grad_x = new Mat();  Mat abs_grad_y = new Mat();  Imgproc.Sobel(image, grad_x, CvType.CV_32F, 1, 0);  Imgproc.Sobel(image, grad_y, CvType.CV_32F, 0, 1);  Core.convertScaleAbs(grad_x, abs_grad_x);  Core.convertScaleAbs(grad_y, abs_grad_y);  grad_x.release();  grad_y.release();  Mat gradxy = new Mat();  Core.addWeighted(abs_grad_x, 0.5, abs_grad_y, 0.5, 10, gradxy);  return gradxy; }}

可以說簡單到哭,此外OpenCV For Java支持各種的圖像處理包括形態學操作,二值圖像分析、圖像特征檢測與識別、模板匹配、直方圖相關功能等等。常見的機器學習算法與圖像分析方法??梢哉f是功能最強大的圖像處理SDK與開發平臺之一,本人繼續發掘分享!

特別注意

在調用之前,一定要加上這句話

System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

目的是加載OpenCV API相關的DLL支持,沒有它是不會正確運行的。以上代碼與功能實現是基于JDK8 64位與OpenCV 3.2版本。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
黄色精品在线看| 66m—66摸成人免费视频| 日韩av第一页| 国产成人精品一区二区三区| 青草热久免费精品视频| 久久91亚洲精品中文字幕奶水| 日韩中文字幕av| 国产精品99久久99久久久二8| 亚洲国产又黄又爽女人高潮的| 国产精品自拍视频| 亚洲天堂免费在线| 欧美成人精品影院| 久久九九热免费视频| 亚洲肉体裸体xxxx137| 97免费中文视频在线观看| 日韩经典中文字幕在线观看| 日韩av免费看网站| 亚洲高清在线观看| 久久九九免费视频| 亚洲成人激情在线| 91夜夜未满十八勿入爽爽影院| 欧美放荡办公室videos4k| 91精品国产一区| 视频一区视频二区国产精品| 久久九九全国免费精品观看| 久久精品国产亚洲一区二区| 日本三级韩国三级久久| 中文字幕亚洲二区| 亚洲影视九九影院在线观看| 欧美高清视频在线| 久久天天躁狠狠躁老女人| 成人在线观看视频网站| 欧美巨大黑人极品精男| 亚洲欧美国产精品久久久久久久| 91在线视频一区| 国产精品成人观看视频国产奇米| 欧美日韩国产中文精品字幕自在自线| 日本精品久久久| 98精品国产高清在线xxxx天堂| 日韩视频在线免费观看| 亚洲韩国欧洲国产日产av| 久久久欧美精品| 国产盗摄xxxx视频xxx69| 亚洲精品小视频在线观看| 亚洲综合日韩在线| 欧美精品18videos性欧| 不用播放器成人网| 97久久精品在线| 成人午夜一级二级三级| 怡红院精品视频| 欧美专区在线观看| 欧美亚洲国产日本| 91在线观看免费| 美女久久久久久久久久久| 亚洲成人国产精品| 欧美成人亚洲成人日韩成人| 欧美在线影院在线视频| 日韩在线观看免费高清完整版| 欧美激情xxxx性bbbb| 丝袜美腿精品国产二区| 国产欧美精品一区二区三区介绍| 欧美高清在线视频观看不卡| 欧美在线免费观看| 亚洲第一在线视频| 精品久久久久久国产| 一区国产精品视频| 国产盗摄xxxx视频xxx69| 这里精品视频免费| 国产成人精品免高潮费视频| 国产精品一区二区女厕厕| 色偷偷噜噜噜亚洲男人的天堂| 性色av一区二区三区免费| 国产精品99久久久久久www| 午夜精品一区二区三区av| 中文字幕日韩免费视频| 国产精品一区二区久久国产| 不卡在线观看电视剧完整版| 国产精品永久免费视频| 精品久久国产精品| 日韩电影视频免费| 日韩一区二区精品视频| 亚洲国产精品美女| 日韩欧美国产一区二区| 中文字幕久热精品在线视频| 欧美在线性视频| 亚洲精品一区二区网址| 欧美激情精品久久久久久变态| 久久天堂电影网| 伊是香蕉大人久久| 粉嫩av一区二区三区免费野| 欧美日韩一区二区免费视频| 国产精品国产三级国产aⅴ9色| 国产不卡av在线免费观看| 久99久在线视频| 福利视频导航一区| 精品久久久久久久久久ntr影视| 深夜福利91大全| 亚洲女性裸体视频| 成人av资源在线播放| 久久久久久久国产| 91精品国产自产在线老师啪| 日韩国产欧美精品在线| 日本亚洲欧美成人| 26uuu亚洲国产精品| 国产99久久精品一区二区永久免费| 亚洲全黄一级网站| 伊人久久精品视频| 国产精品狼人色视频一区| 51视频国产精品一区二区| 日本精品久久久久久久| 免费91麻豆精品国产自产在线观看| 91精品国产高清久久久久久久久| 国产97免费视| 91久久精品美女| 欧美国产日韩一区二区在线观看| 欧美亚洲成人免费| 91av视频导航| 2019中文字幕全在线观看| 亚洲人a成www在线影院| 色狠狠av一区二区三区香蕉蜜桃| 亚洲第一页自拍| 亚洲欧美中文在线视频| 在线电影欧美日韩一区二区私密| 国产精品1区2区在线观看| 97视频人免费观看| 国产精欧美一区二区三区| 久久精品国产亚洲一区二区| 亚洲色图50p| 国产精品三级久久久久久电影| 欧美中文字幕视频| 久久av在线看| 国产99久久久欧美黑人| 亚洲第一福利在线观看| 亚洲成人精品久久| 狠狠操狠狠色综合网| xxxx欧美18另类的高清| 国产精品久久国产精品99gif| 亚洲电影免费观看高清完整版在线观看| 久久国产精品久久国产精品| 欧美日韩亚洲激情| 日本韩国欧美精品大片卡二| 亚洲国产精品va在线| 久久成人国产精品| 国产精品爽爽爽爽爽爽在线观看| 色先锋久久影院av| 亚洲人成电影网站色xx| 国产精品专区h在线观看| 亚洲欧美国产日韩中文字幕| 欧美大片第1页| 欧美一级视频一区二区| 91精品视频免费观看| 丝袜亚洲欧美日韩综合| 在线观看国产精品日韩av| 精品中文字幕在线观看| 91av视频在线观看| 久久精品久久精品亚洲人| 精品国产乱码久久久久久天美| 91久久久久久久久久| 亚洲人成电影网| 欧美电影在线观看| 欧美性精品220| 国产91色在线|| 国产精品一区二区三区久久久| 欧美高清视频一区二区|