Android圖片壓縮實現過程及程式碼
Android圖片壓縮無非兩種,一種質量壓縮,一種畫素壓縮,前者多用於圖片上傳時,後者多用於本地圖片展示縮圖時。
對於質量壓縮,主要用到的一個方法就是:
public boolean compress(CompressFormat format, int quality, OutputStream stream) {}
這是Bitmap類裡的一個方法,第一個參數列示圖片壓縮的格式,android中提供了以下格式:
public enum CompressFormat { JPEG (0), PNG (1), WEBP (2); CompressFormat(int nativeInt) { this.nativeInt = nativeInt; } final int nativeInt; }
第二個參數列示壓縮的質量,注意這個是壓縮的關鍵,它的取值是0到100,越小表示壓縮的越厲害,第三個參數列示把壓縮的資料寫入了outputstream流中。
OK,來看一個例子:
public byte [] compressBitmap(Bitmap bitmap,int max){ int quality = 100; ByteArrayOutputStream byteArrayOutputStream = new ByteArrayOutputStream(); bitmap.compress(Bitmap.CompressFormat.JPEG,quality,byteArrayOutputStream); while (byteArrayOutputStream.toByteArray().length / 1024 > max){ byteArrayOutputStream.reset(); quality = quality -10; bitmap.compress(Bitmap.CompressFormat.JPEG,quality,byteArrayOutputStream); } return byteArrayOutputStream.toByteArray(); }
這個方法的第一個引數不必解釋,第二個參數列示你要求的壓縮後圖片最大可以是多少。最後可以拿到一個byte陣列。我們有了這個byte陣列就可以轉化為file或者bitmap。
注意這種質量壓縮後,畫素本身沒有改變。
對於畫素壓縮,顧名思義就是壓縮畫素。這裡用到的一個主要的方法就是:
public static Bitmap decodeFile(String pathName, Options opts) { Bitmap bm = null; InputStream stream = null; try { stream = new FileInputStream(pathName); bm = decodeStream(stream, null, opts); } catch (Exception e) { /* do nothing. If the exception happened on open, bm will be null. */ Log.e("BitmapFactory", "Unable to decode stream: " + e); } finally { if (stream != null) { try { stream.close(); } catch (IOException e) { // do nothing here } } } return bm; }
這是BitmapFactory中的一個靜態方法,第一個參數列示file的全路徑,第二個引數是關鍵,Options是BitmapFactory類中的一個靜態內部類,它有兩個非常重要的屬性:
/** * If set to true, the decoder will return null (no bitmap), but * the out... fields will still be set, allowing the caller to query * the bitmap without having to allocate the memory for its pixels. */ public boolean inJustDecodeBounds; /** * If set to a value > 1, requests the decoder to subsample the original * image, returning a smaller image to save memory. The sample size is * the number of pixels in either dimension that correspond to a single * pixel in the decoded bitmap. For example, inSampleSize == 4 returns * an image that is 1/4 the width/height of the original, and 1/16 the * number of pixels. Any value <= 1 is treated the same as 1. Note: the * decoder uses a final value based on powers of 2, any other value will * be rounded down to the nearest power of 2. */ public int inSampleSize;
第一個屬性inJustDecodeBounds,如果設定為ture,則返回null。
第二個屬性inSampleSize表示縮放比例,大於1表示縮小了原來的多少,比如inSampleSize == 4,就表示縮小了原來的四分之一,如果小於1則和1相同。
好了來看看這個網上遍地都是的一個畫素壓縮的方法:
private Bitmap getimage(String srcPath) { BitmapFactory.Options newOpts = new BitmapFactory.Options(); //開始讀入圖片,此時把options.inJustDecodeBounds 設回true了 newOpts.inJustDecodeBounds = true; Bitmap bitmap = BitmapFactory.decodeFile(srcPath,newOpts);//此時返回bm為空 newOpts.inJustDecodeBounds = false; int w = newOpts.outWidth; int h = newOpts.outHeight; //現在主流手機比較多是800*480解析度,所以高和寬我們設定為 float hh = 800f;//這裡設定高度為800f float ww = 480f;//這裡設定寬度為480f //縮放比。由於是固定比例縮放,只用高或者寬其中一個資料進行計算即可 int be = 1;//be=1表示不縮放 if (w > h && w > ww) {//如果寬度大的話根據寬度固定大小縮放 be = (int) (newOpts.outWidth / ww); } else if (w < h && h > hh) {//如果高度高的話根據寬度固定大小縮放 be = (int) (newOpts.outHeight / hh); } if (be <= 0) be = 1; newOpts.inSampleSize = be;//設定縮放比例 //重新讀入圖片,注意此時已經把options.inJustDecodeBounds 設回false了 bitmap = BitmapFactory.decodeFile(srcPath, newOpts); return bitmap; }
是不是就很好理解了。
相關文章
- JNI實現圖片壓縮
- 利用 canvas 實現圖片壓縮Canvas
- 前端的圖片壓縮image-compressor(可在圖片上傳前實現圖片壓縮)前端
- 純前端實現 JPG 圖片壓縮 | canvas前端Canvas
- 圖片純前端JS壓縮的實現前端JS
- layui中實現上傳圖片壓縮UI
- 前端圖片壓縮及上傳前端
- Android黑白棋遊戲實現過程及程式碼解析Android遊戲
- 探討iOS 中圖片的解壓縮到渲染過程iOS
- PHP實現高畫質晰度無損圖片壓縮功能的程式碼PHP
- Java 實現壓縮圖片,影片,音訊案例Java音訊
- Android-圖片壓縮(二)-純乾貨Android
- 前端圖片壓縮 - H5&Uni-App圖片壓縮前端H5APP
- Nginx網路壓縮 CSS壓縮 圖片壓縮 JSON壓縮NginxCSSJSON
- 圖片壓縮怎樣操作?分享幾種實用的批次圖片壓縮技巧
- canvas 壓縮圖片Canvas
- 圖片壓縮20201109
- ??圖片壓縮CanvasCanvas
- 純前端實現 PNG 圖片壓縮 | UPNG.js前端JS
- Flutter實現Luban圖片壓縮庫演算法Flutter演算法
- 淺談Flutter web 圖片選擇器及圖片壓縮FlutterWeb
- Glide 原始碼分析(一):圖片壓縮IDE原始碼
- 直播app開發搭建,Android studio 圖片壓縮APPAndroid
- 淺談移動端圖片壓縮(iOS & Android)iOSAndroid
- 用ASP實現線上壓縮與解壓縮功能程式碼
- Android-壓縮大圖到容量超小的圖片Android
- 前端圖片壓縮方案前端
- Photoshop壓縮png圖片
- iOS 圖片壓縮方法iOS
- JS中通過指定大小來壓縮圖片JS
- JPEG圖片的解碼和壓縮流程
- Android通過程式碼修改圖片顏色Android
- 觸屏 H5 如何實現壓縮並上傳多張圖片,同時還可以進行圖片壓縮H5
- Vue使用cube-ui的upload元件實現圖片壓縮VueUI元件
- JavaScript實現手機拍攝圖片的旋轉、壓縮JavaScript
- 【Node】簡單快捷的圖片壓縮指令碼指令碼
- SmallImage for Mac(圖片壓縮工具)Mac
- js圖片壓縮推薦JS
- js上傳圖片壓縮JS