您好,登錄后才能下訂單哦!
小編給大家分享一下JavaCV如何實現照片馬賽克效果,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!
我們先引入 JavaCV 的依賴庫
<dependency> <groupId>org.bytedeco</groupId> <artifactId>javacv-platform</artifactId> <version>1.5.6</version> </dependency>
這種方式引入,會把javacv 所有包含的都引入進來。平時測試使用都時候,可以這樣操作。但是到真實項目中,還是需要做一次精簡才行。
另外我們準備了一個圖片。
讀取文件
val path ="path/to/img/" val img = opencv_imgcodecs.imread(path + "meinv.jpeg")
獲取原圖的像素寬高,然后進行像素比縮放。
val size = img.size() val height = size.height() val width = size.width() val pixelSize = 10 val newWidth = width / pixelSize val newHeight = height / pixelSize
根據設定的像素比, 對原圖進行縮小,再放大的兩次 resize 操作。這樣就完成了像素圖的處理。
val imgTmp: Mat? = null opencv_imgproc.resize(img, imgTmp, Size(newWidth, newHeight),0.0, 0.0, opencv_imgproc.INTER_NEAREST) opencv_imgproc.resize(img, imgTmp, Size(width, height),0.0, 0.0, opencv_imgproc.INTER_NEAREST)
那我們來看下處理過之后的圖像效果吧
效果看起來還可以,圖片顏色單一圖片尺寸稍微小一些的效果會好很多。
import org.bytedeco.opencv.global.opencv_highgui import org.bytedeco.opencv.global.opencv_imgcodecs import org.bytedeco.opencv.global.opencv_imgproc import org.bytedeco.opencv.opencv_core.Mat import org.bytedeco.opencv.opencv_core.Size fun main(args: Array<String>) { val path = "path/to/img/" val img = opencv_imgcodecs.imread(path + "meinv.jpeg") val size = img.size() val height = size.height() val width = size.width() val pixelSize = 10 val newWidth = width / pixelSize val newHeight = height / pixelSize val imgTmp: Mat? = null opencv_imgproc.resize(img, imgTmp, Size(newWidth, newHeight), 0.0, 0.0, opencv_imgproc.INTER_NEAREST) opencv_imgproc.resize(img, imgTmp, Size(width, height), 0.0, 0.0, opencv_imgproc.INTER_NEAREST) opencv_highgui.imshow("meinv", img); opencv_highgui.waitKey(0) }
看完了這篇文章,相信你對“JavaCV如何實現照片馬賽克效果”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。