Convert WebP to PNG using java

WebP是谷歌的图片格式,java 类库imageio 是不支持此种格式的。目前除了在线转换以及工具以外,第三方类库转换webp格式大致有:

1.linux:Google libwebp 既是类库也可以在命令行调用

2.Python:Python Image Library(PIL)及其分支 https://pypi.python.org/pypi/PIL  不太了解

3.Java:luciad/webp-imageio https://bitbucket.org/luciad/webp-imageio/src   证实可用(linux环境下)

本文讲述第三种方法:

在linux环境下,将google libwebp-0.4.0 放至 luciad-webp-imageio-2962dd563583 根目录内,安装CMake,在上述根目录内执行 cmake . 命令,cmake完成后在上述根目录下执行make命令。make完成会在java目录和c目录下分别生成.jar 和.so 文件。将.jar 导入自己的java项目路径,将.so文件放至系统java路径。此时在java项目中使用imageio即可读写webp格式文件。

说明:

操作环境:ubuntu

语言:java

实例:webp 转png

步骤:

一:下载以下三个文件包

1.CMake 安装包:cmake-3.1.0-rc2-Linux-i386.tar

2.Google webp 依赖库:libwebp-0.4.0.tar.gz   原地址:https://developers.google.com/speed/webp/download?hl=zh-cN

3.luciad/webp-imageio工程:luciad-webp-imageio-2962dd563583.zip    原地址:https://bitbucket.org/luciad/webp-imageio/src

考虑到以上资源需要翻墙下载,比较慢。我已将三个文件传至csdn,0分下载  。

地址:http://download.csdn.net/detail/geeklei/8161731

二:编译得到 webp-imageio.jar 和 libwebp-imageio.so

1.解压 luciad-webp-imageio-2962dd563583.zip。

2.将libwebp-0.4.0.tar.gz  解压至 luciad-webp-imageio-2962dd563583 根目录下。

3.将cmake-3.1.0-rc2-Linux-i386.tar 解压。 cmake解压即用,当然也可以自己用命令从镜像源中下载安装。

4.在确保cmake可用的前提下,在luciad-webp-imageio-2962dd563583 根目录下 执行cmake . 命令。注意 cmake 和 . 之间有一个空格

5.cmake结束,看到了makefile文件, 在luciad-webp-imageio-2962dd563583 根目录下 执行make 命令。

6.make结束,在luciad-webp-imageio-2962dd563583 根目录下的java和c 文件夹内可以看到.jar 和.so

三:

1.将webp-imageio.jar导入 eclipse 中自己的java项目中。

2.将libwebp-imageio.so 放至系统java路径中。可以再项目中利用 System.out.println(System.getProperty("java.library.path"));语句打印出java 路径,避免遗漏。打印出的java路径有多个,有部分重复。

3.在项目中使用 ImageIO即可读写webp格式文件了。

代码:

File file1= new File("/home/geeklei/Desktop/640_tp.webp");
File file2= new File("/home/geeklei/Desktop/640a.png"); 

System.out.println(System.getProperty("java.library.path")); 

try { 

 BufferedImage im = ImageIO.read(file1);
 ImageIO.write(im, "png", file2); 

} catch (IOException e) {
 e.printStackTrace();
}

感谢luciad/webp-imageio项目作者 Luciad 的努力,以及对我的提问的无私帮助。

今天早上发现有人把编译好的包传到项目里面了。。我也没测试,不过把包也共享出来吧。原地址:https://bitbucket.org/luciad/webp-imageio/downloads

csdn地址:http://download.csdn.net/detail/geeklei/8163329

里面有 .jar .so .dll

涵盖linux 32/64 windows  32/64 等版本

(0)

相关推荐

  • Android WebP 图片压缩与传输

    1. 简介 直到4g时代,流量依然是宝贵的东西.而移动网络传输中,最占流量的一种载体:图片,成为了我们移动开发者不得不关注的一个问题. 我们关注的问题,无非是图片体积和质量如何达到一个比较和谐的平衡,希望得到质量不错的图片同时体积还不能太大. 走在时代前列的谷歌给出了一个不错的答案--WebP. WebP是一种图片文件格式,在相同的压缩指标下,webp的有损压缩能比jpg小 25-34%.而在我自己的测试里,有时候能小50%. 2. 大企业背书 WebP在2010年发布第一个版本,到现在已经6年

  • webpageparser.dll丢失问题的解决方法

    一.问题的提出 1.案例一:来自网络求助 昨天中了个deskipn.all桌面媒体,今天折腾了一天,试了N种方法,单独用杀毒软件根本弄不了,安全模式下禁止进程启动,删除注册表都没用,在网上查,原来这东西是正常安装的,所以杀毒软件都直接查不了,还会修改,最后按别人说的方法把毒是杀了,可遗留下这个问题,每次开机后会弹出"没有找到webpageparser.dll(MS是桌面媒体的一部分源文件),因此这个应用程序未能启动.重新安装应用程序可能会修复此问题"的窗口.而且每启动一个程序都会弹出响

  • Webpack 实现 AngularJS 的延迟加载

    随着你的单页应用扩大,其下载时间也越来越长.这对提高用户体验不会有好处(提示:但用户体验正是我们开发单页应用的原因).更多的代码意味着更大的文件,直到代码压缩已经不能满足你的需求,你唯一能为你的用户做的就是不要再让他一次性下载整个应用.这时,延迟加载就派上用场了.不同于一次性下载所有文件,而是让用户只下载他现在需要的文件. 所以.如何让你的应用程序实现延迟加载?它基本上是分成两件事情.把你的模块拆分成小块,并实施一些机制,允许按需加载这些块.听起来似乎有很多工作量,不是吗?如果你使用 Webpa

  • ASPWebPack(整站文件备份系统) v1.0.2 黑客也用

    功能列表:1.备份数据 2.恢复数据 3.上传备份 4.备份管理  程序说明:拥有了 ASPWebPack,上传更新网站,您只需一步即可完成.适用于空间没有代备份功能的用户,如果您的虚拟主机自带了备份功能,那可以用来辅助整站下载嘛.更适用于做为黑客工具,方便各种职业黑客下载整站源代码商业拍卖(声明:作者的意图并非如此,希望大家勿用于非法.).反正就是方便到家啦,希望大家喜欢.  补充说明:本地打包文件请使用NetBox,或者自己开本地IIS.  作者声明:本程序只作为辅助站长备份站点使用,请勿用

  • python网络编程学习笔记(10):webpy框架

    django和webpy都是python的web开发框架.Django的主要目的是简便.快速的开发数据库驱动的网站.它强调代码复用,多个组件可以很方便的以"插件"形式服务于整个框架,Django有许多功能强大的第三方插件,你甚至可以很方便的开发出自己的工具包.这使得Django具有很强的可扩展性.它还强调快速开发和DRY(Do Not Repeat Yourself)原则.webpy小巧,简单,实用,可以快速的完成简单的web页面.这里根据webpy Cookbook简要的介绍一下we

  • Python将图片批量从png格式转换至WebP格式

    实现效果 将位于/img目录下的1000张.png图片,转换成.webp格式,并存放于img_webp文件夹内. 源图片目录 目标图片目录 关于批量生成1000张图片,可以参考这篇文章:利用Python批量生成任意尺寸的图片 实现示例 import glob import os import threading from PIL import Image def create_image(infile, index): os.path.splitext(infile) im = Image.op

  • ubuntu lighttpd+webpy (fastcgi)配置方法

    lighttpd 的配置脚本在 /etc/lighttpd/lighttpd.conf,采用默认值 缺省的server.document-root路径是 /var/www 具体实施步骤: 1) 首先实现一个 python 脚本 touch /var/www/hello.py chmod 755 /var/www/hello.py vim /var/www/hello.py 复制代码 代码如下: #!/usr/bin/env python import web urls = ( '/hello',

  • webpack中引用jquery的简单实现

    1.首先需要添加项目中jquery的依赖 npm install jquery --save-dev 2.参考配置代码: var webpack = require("webpack"); var path = require("path"); module.exports = { entry:{ home:"./src/js/home.js", -- }, output:{ path:__dirname+"/dist/js"

  • ASPWebPack 代码 提供下载

    复制代码 代码如下: dim pwd pwd=inputbox("请输入新密码:","更改密码","yulv.net") if pwd<>"" then     pwd=PwdConv(pwd)     inputbox "您的新密码编码是:" & vbcrlf & "请将新的编码替换到程序中的密码项!","密码编码",pwd else  

  • Webpack 实现 Node.js 代码热替换

    这两天为了这个问题, Gitter 上问, Twitter 上问, GitHub 上问, 两天没反应 原来写博客的 jlongster 不理我, 我也不知道 Webpack 作者的联系方式 最后在 Gitter 上发的消息他似乎看到了, 就粗略地解释了一遍, 醍醐灌顶啊... https://github.com/webpack/docs/issues/45#issuecomment-149793458 Here is the process in short: Compile the serv

随机推荐