Android 圖片變換處理Matrix

        講解一下如何處理對一個Bitmap對象進行處理,包括:縮放、旋轉、位移、傾斜等。在最後將以一個簡單的Demo來演示圖片特效的變換。

Matrix


  對於一個圖片變換的處理,需要Matrix類的支持,它位於"android.graphics.Matrix"包下,是Android提供的一個矩陣工具類,它本身不能對圖像或View進行變換,但它可與其他API結合來控制圖形、View的變換,如Canvas。

  Matrix提供了一些方法來控制圖片變換:
setTranslate(float dx,float dy):控制Matrix進行位移。
setSkew(float kx,float ky):控制Matrix進行傾斜,kx、ky爲X、Y方向上的比例。
setSkew(float kx,float ky,float px,float py):控制Matrix以px、py爲軸心進行傾斜,kx、ky爲X、Y方向上的傾斜比例。
setRotate(float degrees):控制Matrix進行depress角度的旋轉,軸心爲(0,0)。
setRotate(float degrees,float px,float py):控制Matrix進行depress角度的旋轉,軸心爲(px,py)。
setScale(float sx,float sy):設置Matrix進行縮放,sx、sy爲X、Y方向上的縮放比例。
setScale(float sx,float sy,float px,float py):設置Matrix以(px,py)爲軸心進行縮放,sx、sy爲X、Y方向上的縮放比例。
  之前有提過,圖片在內存中存放的就是一個一個的像素點,而對於圖片的變換主要是處理圖片的每個像素點,對每個像素點進行相應的變換,即可完成對圖像的變換。上面已經列舉了Matrix進行變換的常用方法,下面以幾個Demo來講解一下如何通過Matrix進行變換。 


 

Matrix縮放
  代碼:

/**
     * 縮放圖片
     */
    protected void bitmapScale(float x, float y) {
        // 因爲要將圖片放大,所以要根據放大的尺寸重新創建Bitmap
        Bitmap afterBitmap = Bitmap.createBitmap(
                (int) (baseBitmap.getWidth() * x),
                (int) (baseBitmap.getHeight() * y), baseBitmap.getConfig());
        Canvas canvas = new Canvas(afterBitmap);
        // 初始化Matrix對象
        Matrix matrix = new Matrix();
        // 根據傳入的參數設置縮放比例
        matrix.setScale(x, y);
        // 根據縮放比例,把圖片draw到Canvas上
        canvas.drawBitmap(baseBitmap, matrix,paint);
        iv_after.setImageBitmap(afterBitmap);
    }


效果展示:


Matrix旋轉:

/**
     * 圖片旋轉
     */
    protected void bitmapRotate(float degrees) {
        // 創建一個和原圖一樣大小的圖片
        Bitmap afterBitmap = Bitmap.createBitmap(baseBitmap.getWidth(),
                baseBitmap.getHeight(), baseBitmap.getConfig());
        Canvas canvas = new Canvas(afterBitmap);
        Matrix matrix = new Matrix();
        // 根據原圖的中心位置旋轉
        matrix.setRotate(degrees, baseBitmap.getWidth() / 2,
                baseBitmap.getHeight() / 2);
        canvas.drawBitmap(baseBitmap, matrix, paint);
        iv_after.setImageBitmap(afterBitmap);
    }

效果展示:


 

Matrix位移:

/**
     * 圖片移動
     */
    protected void bitmapTranslate(float dx, float dy) {
        // 需要根據移動的距離來創建圖片的拷貝圖大小
        Bitmap afterBitmap = Bitmap.createBitmap(
                (int) (baseBitmap.getWidth() + dx),
                (int) (baseBitmap.getHeight() + dy), baseBitmap.getConfig());
        Canvas canvas = new Canvas(afterBitmap);
        Matrix matrix = new Matrix();
        // 設置移動的距離
        matrix.setTranslate(dx, dy);
        canvas.drawBitmap(baseBitmap, matrix, paint);
        iv_after.setImageBitmap(afterBitmap);
    }

效果展示:



Matrix傾斜:

/**
     * 傾斜圖片
     */
    protected void bitmapSkew(float dx, float dy) {
        // 根據圖片的傾斜比例,計算變換後圖片的大小,
        Bitmap afterBitmap = Bitmap.createBitmap(baseBitmap.getWidth()
                + (int) (baseBitmap.getWidth() * dx), baseBitmap.getHeight()
                + (int) (baseBitmap.getHeight() * dy), baseBitmap.getConfig());
        Canvas canvas = new Canvas(afterBitmap);
        Matrix matrix = new Matrix();
        // 設置圖片傾斜的比例
        matrix.setSkew(dx, dy);
        canvas.drawBitmap(baseBitmap, matrix, paint);
        iv_after.setImageBitmap(afterBitmap);
    }

效果展示:


Matrix變換注意事項

  上面幾個小方法演示瞭如何使用Matrix進行變換,但是還有幾點需要額外注意一下:

1.對於一個從BitmapFactory.decodeXxx()方法加載的Bitmap對象而言,它是一個只讀的,無法對其進行處理,必須使用Bitmap.createBitmap()方法重新創建一個Bitmap對象的拷貝,纔可以對拷貝的Bitmap進行處理。
2.因爲圖像的變換是針對每一個像素點的,所以有些變換可能發生像素點的丟失,這裏需要使用Paint.setAnitiAlias(boolean)設置來消除鋸齒,這樣圖片變換後的效果會好很多。
3.在重新創建一個Bitmap對象的拷貝的時候,需要注意它的寬高,如果設置不妥,很可能變換後的像素點已經移動到"圖片之外"去了。
 

發佈了53 篇原創文章 · 獲贊 17 · 訪問量 12萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章