Luban
Luban(魯班)——Android圖片壓縮工具,仿微信朋友圈壓縮策略
工具描述
目前做app開發(fā)總繞不開圖片這個(gè)元素。但是隨著手機(jī)拍照分辨率的提升,圖片的壓縮成為一個(gè)很重要的問題。單純對圖片進(jìn)行裁切,壓縮已經(jīng)有很多文章介紹。但是裁切成多少,壓縮成多少卻很難控制好,裁切過頭圖片太小,質(zhì)量壓縮過頭則顯示效果太差。
于是自然想到app巨頭“微信”會(huì)是怎么處理,Luban(魯班)就是通過在微信朋友圈發(fā)送近100張不同分辨率圖片,對比原圖與微信壓縮后的圖片逆向推算出來的壓縮算法。
因?yàn)槭悄嫦蛲扑?,效果還沒法跟微信一模一樣,但是已經(jīng)很接近微信朋友圈壓縮后的效果,具體看以下對比!
效果與對比
內(nèi)容 | 原圖 | Luban | |
---|---|---|---|
截屏 720P | 720*1280,390k | 720*1280,87k | 720*1280,56k |
截屏 1080P | 1080*1920,2.21M | 1080*1920,104k | 1080*1920,112k |
拍照 13M(4:3) | 3096*4128,3.12M | 1548*2064,141k | 1548*2064,147k |
拍照 9.6M(16:9) | 4128*2322,4.64M | 1032*581,97k | 1032*581,74k |
滾動(dòng)截屏 | 1080*6433,1.56M | 1080*6433,351k | 1080*6433,482k |
導(dǎo)入
compile 'io.reactivex:rxandroid:1.2.1'
compile 'io.reactivex:rxjava:1.1.6'
compile 'top.zibin:Luban:1.0.5'
使用
Listener方式
Luban內(nèi)部采用io線程進(jìn)行圖片壓縮,外部調(diào)用只需設(shè)置好結(jié)果監(jiān)聽即可
Luban.get(this)
.load(File) //傳人要壓縮的圖片
.putGear(Luban.THIRD_GEAR) //設(shè)定壓縮檔次,默認(rèn)三擋
.setCompressListener(new OnCompressListener() { //設(shè)置回調(diào)
@Override
public void onStart() {
//TODO 壓縮開始前調(diào)用,可以在方法內(nèi)啟動(dòng) loading UI
}
@Override
public void onSuccess(File file) {
//TODO 壓縮成功后調(diào)用,返回壓縮后的圖片文件
}
@Override
public void onError(Throwable e) {
//TODO 當(dāng)壓縮過去出現(xiàn)問題時(shí)調(diào)用
}
}).launch(); //啟動(dòng)壓縮
RxJava方式
RxJava 調(diào)用方式請自行隨意控制線程
Luban.get(this)
.load(file)
.putGear(Luban.THIRD_GEAR)
.asObservable()
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.doOnError(new Action1<Throwable>() {
@Override
public void call(Throwable throwable) {
throwable.printStackTrace();
}
})
.onErrorResumeNext(new Func1<Throwable, Observable<? extends File>>() {
@Override
public Observable<? extends File> call(Throwable throwable) {
return Observable.empty();
}
})
.subscribe(new Action1<File>() {
@Override
public void call(File file) {
//TODO 壓縮成功后調(diào)用,返回壓縮后的圖片文件
}
});