摘要:项目作者为了解决这个问题,改进了对动态链接库的读取方式,把从读取改成了从项目文件中读取具体内容见方法。
前言
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包,只要导入项目即可使用。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/77041.html
摘要:写在前面开发中的图像压缩是一个很重要的部分。而这篇文章会让我们从另外一个角度来认识平台下的图像压缩和优化。所以,它是你图像压缩和优化的首选,尽可能的去使用吧。 写在前面 Android开发中的图像压缩是一个很重要的部分。而这篇文章会让我们从另外一个角度来认识Android平台下的图像压缩和优化。 这篇文章更适合和设计师一起来看,所以,如果你和你的设计师是好基友的话,不妨叫上他,倒两杯咖...
摘要:是一个注册在指定源和路径下的事件驱动。移动端方面的支持度较好,从版本开始支持。作为提出的一项技术,在端有很好的支持,但目前的兼容性还无法在移动端网页中广泛使用。从而达到向后兼容式的优化。 图片通常是移动端网页中最占流量的资源。在很多类型的网站中(比如电商、社区),图片占据了网页的大部分空间。优化图片的质量和加载速度成为提高用户体验的重要途径。 传统方案的弊端 目前有一些被广泛应用的方案...
阅读 3433·2021-11-08 13:20
阅读 3358·2021-09-30 09:48
阅读 2558·2021-09-29 09:41
阅读 588·2021-09-22 15:04
阅读 2457·2021-08-23 09:44
阅读 3663·2020-12-03 17:26
阅读 1006·2019-08-30 14:10
阅读 1560·2019-08-29 18:34