摘要:項目作者為了解決這個問題,改進了對動態鏈接庫的讀取方式,把從讀取改成了從項目文件中讀取具體內容見方法。
前言
Webp是Google推出的一種新型圖片格式,相比于 傳統的PNG/JPG圖片有著更小體積的優勢,在Web中有著廣泛的應用。由于Webp格式推出比較晚, Jdk 內置的圖片編解碼庫對此并不支持。
網上給出的Java環境解決方案往往需要手動在java.library.path中安裝對應的動態鏈接庫,windows是dll文件,linux是so文件。這對于開發部署非常不方便。
本文提供一種無需手動安裝動態鏈接庫,同時可以方便處理Webp的解決方案
準備先從github上面下載所需要的jar包
webp-imageio-core-0.1.0.jar
由于這個項目并未發布到maven中央倉庫,所以需要手動導入本地jar包.
如果你用的是gradle,可以把jar包放入src/main/resource/libs目錄,并在build.gradle中加入依賴
dependencies { compile fileTree(dir:"src/main/resources/libs",include:["*.jar"]) }
如果你用的是maven,可以把jar包放入${project.basedir}/libs目錄,并在pom.xml中加入依賴
例子com.github.nintha webp-imageio-core {versoin} system ${project.basedir}/libs/webp-imageio-core-{version}.jar
完整代碼見 https://github.com/nintha/web...,以下為部分摘錄
Webp編碼
public static void main(String args[]) throws IOException { String inputPngPath = "test_pic/test.png"; String inputJpgPath = "test_pic/test.jpg"; String outputWebpPath = "test_pic/test_.webp"; // Obtain an image to encode from somewhere BufferedImage image = ImageIO.read(new File(inputJpgPath)); // Obtain a WebP ImageWriter instance ImageWriter writer = ImageIO.getImageWritersByMIMEType("image/webp").next(); // Configure encoding parameters WebPWriteParam writeParam = new WebPWriteParam(writer.getLocale()); writeParam.setCompressionMode(WebPWriteParam.MODE_DEFAULT); // Configure the output on the ImageWriter writer.setOutput(new FileImageOutputStream(new File(outputWebpPath))); // Encode writer.write(null, new IIOImage(image, null, null), writeParam); }
Webp解碼
public static void main(String args[]) throws IOException { String inputWebpPath = "test_pic/test.webp"; String outputJpgPath = "test_pic/test_.jpg"; String outputJpegPath = "test_pic/test_.jpeg"; String outputPngPath = "test_pic/test_.png"; // Obtain a WebP ImageReader instance ImageReader reader = ImageIO.getImageReadersByMIMEType("image/webp").next(); // Configure decoding parameters WebPReadParam readParam = new WebPReadParam(); readParam.setBypassFiltering(true); // Configure the input on the ImageReader reader.setInput(new FileImageInputStream(new File(inputWebpPath))); // Decode the image BufferedImage image = reader.read(0, readParam); ImageIO.write(image, "png", new File(outputPngPath)); ImageIO.write(image, "jpg", new File(outputJpgPath)); ImageIO.write(image, "jpeg", new File(outputJpegPath)); }關于webp-imageio-core項目
這個項目是基于于 qwong/j-webp項目,而 qwong/j-webp 是基于 webp project of Luciad 0.4.2項目。
webp project of Luciad這個項目提供了java上一個關于處理webp的可用實現,但是它需要開發者手動java.library.path中安裝對應的動態鏈接庫,非常不方便。qwong/j-webp項目作者為了解決這個問題,改進了對動態鏈接庫的讀取方式,把從java.library.path讀取改成了從項目resource文件中讀取(具體內容見com.luciad.imageio.webp.WebP.loadNativeLibrary方法)。
雖然qwong/j-webp項目解決了動態鏈接庫依賴問題,但是它的作者并未對這些代碼提供一個良好封裝,畢竟開發者不希望在自己項目里面直接引入第三方包的源碼,所以有了webp-imageio-core提供一個可用的jar包,只要導入項目即可使用。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/77041.html
摘要:寫在前面開發中的圖像壓縮是一個很重要的部分。而這篇文章會讓我們從另外一個角度來認識平臺下的圖像壓縮和優化。所以,它是你圖像壓縮和優化的首選,盡可能的去使用吧。 寫在前面 Android開發中的圖像壓縮是一個很重要的部分。而這篇文章會讓我們從另外一個角度來認識Android平臺下的圖像壓縮和優化。 這篇文章更適合和設計師一起來看,所以,如果你和你的設計師是好基友的話,不妨叫上他,倒兩杯咖...
摘要:是一個注冊在指定源和路徑下的事件驅動。移動端方面的支持度較好,從版本開始支持。作為提出的一項技術,在端有很好的支持,但目前的兼容性還無法在移動端網頁中廣泛使用。從而達到向后兼容式的優化。 圖片通常是移動端網頁中最占流量的資源。在很多類型的網站中(比如電商、社區),圖片占據了網頁的大部分空間。優化圖片的質量和加載速度成為提高用戶體驗的重要途徑。 傳統方案的弊端 目前有一些被廣泛應用的方案...
閱讀 3434·2021-11-08 13:20
閱讀 3359·2021-09-30 09:48
閱讀 2560·2021-09-29 09:41
閱讀 589·2021-09-22 15:04
閱讀 2458·2021-08-23 09:44
閱讀 3663·2020-12-03 17:26
閱讀 1007·2019-08-30 14:10
閱讀 1561·2019-08-29 18:34