JavaCV實現照片馬賽克效果

前言

青空最近在逛一些社區的時候發現瞭有很多圖片是像素圖,感覺挺好玩的。正巧最近自己在學習JavaCV,所以在這裡給大傢演示一下如何使用JavaCV來處理像素圖。

像素圖其實有點類似於類似於打馬賽克的功能。通過像素的變化,演示一個像素畫的功能。像素畫在 NFT 中特別的流行。

準備工作

我們先引入 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實現照片馬賽克效果的文章就介紹到這瞭,更多相關JavaCV內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!

推薦閱讀: