我这里记录一下使用Luban(鲁班)进行对图片压缩处理,可惜EC目前没法使用,这里是使用AS的,特此记录一下。
摘自官方介绍说明:
目前做App
开发总绕不开图片这个元素。但是随着手机拍照分辨率的提升,图片的压缩成为一个很重要的问题。单纯对图片进行裁切,压缩已经有很多文章介绍。但是裁切成多少,压缩成多少却很难控制好,裁切过头图片太小,质量压缩过头则显示效果太差。
于是自然想到App
巨头“微信”会是怎么处理,Luban
(鲁班)就是通过在微信朋友圈发送近100张不同分辨率图片,对比原图与微信压缩后的图片逆向推算出来的压缩算法。
因为有其他语言也想要实现Luban
,所以描述了一遍算法步骤。
因为是逆向推算,效果还没法跟微信一模一样,但是已经很接近微信朋友圈压缩后的效果,具体看以下对比!
这个教程说明:http://www.open-open.com/lib/view/open1470381700640.html
使用方式
implementation 'top.zibin:Luban:1.1.8'
Luban.with(this)
.load(new File(imgPath))
.ignoreBy(100)
.setTargetDir(imgPath)
.filter(new CompressionPredicate() {
@Override
public boolean apply(String path) {
return !(TextUtils.isEmpty(path) || path.toLowerCase().endsWith(".gif"));
}
})
.setCompressListener(new OnCompressListener() {
@Override
public void onStart() {
// TODO 压缩开始前调用,可以在方法内启动 loading UI
}
@Override
public void onSuccess(File file) {
// TODO 压缩成功后调用,返回压缩后的图片文件
userFile=file;
updateImg();
}
@Override
public void onError(Throwable e) {
// TODO 当压缩过程出现问题时调用
ToastManager.showShortToast(UserInfoActivity.this,""+e.getMessage());
}
}).launch();
}
官方开源项目地址是:https://github.com/Curzibn/Luban