成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

Java處理Webp圖片格式轉(zhuǎn)換

hellowoody / 3094人閱讀

摘要:項(xiàng)目作者為了解決這個(gè)問題,改進(jìn)了對動(dòng)態(tài)鏈接庫的讀取方式,把從讀取改成了從項(xiàng)目文件中讀取具體內(nèi)容見方法。

前言

Webp是Google推出的一種新型圖片格式,相比于 傳統(tǒng)的PNG/JPG圖片有著更小體積的優(yōu)勢,在Web中有著廣泛的應(yīng)用。由于Webp格式推出比較晚, Jdk 內(nèi)置的圖片編解碼庫對此并不支持。

網(wǎng)上給出的Java環(huán)境解決方案往往需要手動(dòng)在java.library.path中安裝對應(yīng)的動(dòng)態(tài)鏈接庫,windows是dll文件,linux是so文件。這對于開發(fā)部署非常不方便。

本文提供一種無需手動(dòng)安裝動(dòng)態(tài)鏈接庫,同時(shí)可以方便處理Webp的解決方案

準(zhǔn)備

先從github上面下載所需要的jar包

webp-imageio-core-0.1.0.jar

由于這個(gè)項(xiàng)目并未發(fā)布到maven中央倉庫,所以需要手動(dòng)導(dǎo)入本地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));

}
關(guān)于webp-imageio-core項(xiàng)目

這個(gè)項(xiàng)目是基于于 qwong/j-webp項(xiàng)目,而 qwong/j-webp 是基于 webp project of Luciad 0.4.2項(xiàng)目。

webp project of Luciad這個(gè)項(xiàng)目提供了java上一個(gè)關(guān)于處理webp的可用實(shí)現(xiàn),但是它需要開發(fā)者手動(dòng)java.library.path中安裝對應(yīng)的動(dòng)態(tài)鏈接庫,非常不方便。qwong/j-webp項(xiàng)目作者為了解決這個(gè)問題,改進(jìn)了對動(dòng)態(tài)鏈接庫的讀取方式,把從java.library.path讀取改成了從項(xiàng)目resource文件中讀?。ň唧w內(nèi)容見com.luciad.imageio.webp.WebP.loadNativeLibrary方法)。

雖然qwong/j-webp項(xiàng)目解決了動(dòng)態(tài)鏈接庫依賴問題,但是它的作者并未對這些代碼提供一個(gè)良好封裝,畢竟開發(fā)者不希望在自己項(xiàng)目里面直接引入第三方包的源碼,所以有了webp-imageio-core提供一個(gè)可用的jar包,只要導(dǎo)入項(xiàng)目即可使用。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/77041.html

相關(guān)文章

  • Google I/O 2016 筆記之圖像壓縮

    摘要:寫在前面開發(fā)中的圖像壓縮是一個(gè)很重要的部分。而這篇文章會(huì)讓我們從另外一個(gè)角度來認(rèn)識平臺下的圖像壓縮和優(yōu)化。所以,它是你圖像壓縮和優(yōu)化的首選,盡可能的去使用吧。 寫在前面 Android開發(fā)中的圖像壓縮是一個(gè)很重要的部分。而這篇文章會(huì)讓我們從另外一個(gè)角度來認(rèn)識Android平臺下的圖像壓縮和優(yōu)化。 這篇文章更適合和設(shè)計(jì)師一起來看,所以,如果你和你的設(shè)計(jì)師是好基友的話,不妨叫上他,倒兩杯咖...

    BWrong 評論0 收藏0
  • PWA 時(shí)代的移動(dòng)端圖片優(yōu)化新思路

    摘要:是一個(gè)注冊在指定源和路徑下的事件驅(qū)動(dòng)。移動(dòng)端方面的支持度較好,從版本開始支持。作為提出的一項(xiàng)技術(shù),在端有很好的支持,但目前的兼容性還無法在移動(dòng)端網(wǎng)頁中廣泛使用。從而達(dá)到向后兼容式的優(yōu)化。 圖片通常是移動(dòng)端網(wǎng)頁中最占流量的資源。在很多類型的網(wǎng)站中(比如電商、社區(qū)),圖片占據(jù)了網(wǎng)頁的大部分空間。優(yōu)化圖片的質(zhì)量和加載速度成為提高用戶體驗(yàn)的重要途徑。 傳統(tǒng)方案的弊端 目前有一些被廣泛應(yīng)用的方案...

    RaoMeng 評論0 收藏0

發(fā)表評論

0條評論

最新活動(dòng)
閱讀需要支付1元查看
<