Luban-android最接近微信朋友圈的圖片壓縮演算法
目前做App開發總繞不開圖片這個元素。但是隨著手機拍照解析度的提升,圖片的壓縮成為一個很重要的問題。單純對圖片進行裁切,壓縮已經有很多文章介紹。但是裁切成多少,壓縮成多少卻很難控制好,裁切過頭圖片太小,質量壓縮過頭則顯示效果太差。
於是自然想到App巨頭“微信”會是怎麼處理,Luban(魯班)就是通過在微信朋友圈傳送近100張不同解析度圖片,對比原圖與微信壓縮後的圖片逆向推算出來的壓縮演算法。
因為有其他語言也想要實現Luban,所以描述了一遍演算法步驟。
因為是逆向推算,效果還沒法跟微信一模一樣,但是已經很接近微信朋友圈壓縮後的效果,具體看以下對比!
效果與對比
內容 | 原圖 | 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 |
滾動截圖 | 1080*6433,1.56M | 1080*6433,351k | 1080*6433,482k |
使用方法
第一步匯入
compile 'top.zibin:Luban:1.1.3'複製程式碼
非同步呼叫
Luban內部採用IO執行緒進行圖片壓縮,外部呼叫只需設定好結果監聽即可:
Luban.with(this) .load(photos) // 傳人要壓縮的圖片列表 .ignoreBy(100) // 忽略不壓縮圖片的大小 .setTargetDir(getPath()) // 設定壓縮後檔案儲存位置 .setCompressListener(new OnCompressListener() { //設定回撥 @Override public void onStart() { // TODO 壓縮開始前呼叫,可以在方法內啟動 loading UI } @Override public void onSuccess(File file) { // TODO 壓縮成功後呼叫,返回壓縮後的圖片檔案 } @Override public void onError(Throwable e) { // TODO 當壓縮過程出現問題時呼叫 } }).launch(); //啟動壓縮複製程式碼
同步呼叫
同步方法請儘量避免在主執行緒呼叫以免阻塞主執行緒,下面以rxJava呼叫為例
Flowable.just(photos) .observeOn(Schedulers.io()) .map(new Function<List<String>, List<File>>() { @Override public List<File> apply(@NonNull List<String> list) throws Exception { // 同步方法直接返回壓縮後的檔案 return Luban.with(MainActivity.this).load(list).get(); } }) .observeOn(AndroidSchedulers.mainThread()) .subscribe();複製程式碼
專案地址
相信自己,沒有做不到的,只有想不到的
如果你覺得此文對您有所幫助,歡迎入群 QQ交流群 :644196190
微信公眾號:終端研發部