亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Android canvas drawBitmap方法詳解及實例

 更新時間:2017年01月24日 14:47:21   作者:小豬快跑22  
這篇文章主要介紹了 Android canvas drawBitmap方法詳解及實例的相關(guān)資料,需要的朋友可以參考下

 Android canvas drawBitmap方法詳解及實例

之前自己在自定義view,用到canvas.drawBitmap(Bitmap, SrcRect, DesRect, Paint)的時候,對其中的第2和3個參數(shù)的含義含糊不清。看源碼函數(shù)也沒理解,然后看了一些其他的博客加上自己的理解,整理如下。首先,我們看一張圖片,今天就要繪制這張圖片。

這里寫圖片描述

然后將圖片用紅色的線條分成4個部分,如下:


這里寫圖片描述

我們自定義一個View,代碼如下:

public class PoterDuffLoadingView extends View {

 private Resources mResources;
 private Paint mBitPaint;
 private Bitmap mBitmap;

 private int mTotalWidth, mTotalHeight;
 private Bitmap girlBitmap;
 private int girlBitWidth , girlBitHeight;
 private Rect girlSrcRect , girlDesRect;

 public PoterDuffLoadingView(Context context) {
  super(context);
  mResources = getResources();
  initBitmap();
 }

 private void initBitmap() {
  //美女圖片的寬和高
  girlBitmap = ((BitmapDrawable)mResources.getDrawable(R.drawable.a1)).getBitmap();
  girlBitWidth = girlBitmap.getWidth();
  girlBitHeight = girlBitmap.getHeight();


 }

 @Override
 protected void onDraw(Canvas canvas) {
  super.onDraw(canvas);
  canvas.drawBitmap(girlBitmap, girlSrcRect, girlDesRect, null);
 }
 @Override
 protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) {
  super.onMeasure(widthMeasureSpec, heightMeasureSpec);
 }

 @Override
 protected void onSizeChanged(int w, int h, int oldw, int oldh) {
  Log.d("xxxxxx", "onSizeChanged , w = "+w+" , h = "+h+" , mBitWidth = "+mBitWidth+" , mBitHeight = "+mBitHeight);
  super.onSizeChanged(w, h, oldw, oldh);
  mTotalWidth = w;
  mTotalHeight = h;

  girlSrcRect = new Rect(0, 0, girlBitWidth, girlBitHeight);
  girlDesRect = new Rect(0, 0, girlBitWidth, girlBitHeight);

 }
}

其中:

girlSrcRect = new Rect(0, 0, girlBitWidth, girlBitHeight); 

表示要畫的圖就是整個圖片的大小。我覺得girlSrcRect 就是指畫圖的大小范圍。

girlDesRect :就是所畫的圖在View上的位置。表是距離左邊和上邊為0,右邊(girlBitWidth - 0)就為圖片的寬度,下邊(girlBitHeight - 0)為圖片的高度。

效果圖如下 :


這里寫圖片描述

當(dāng)我們想移動圖片的位置,代碼如下:

girlDesRect = new Rect(20, 50, 20+girlBitWidth, 50+girlBitHeight);

表示圖片的左邊所在的位置為20個像素,圖片的頂部在View上的位置為50個像素。圖片右邊在view上的位置為(20+girlBitWidth )即距離圖片的左邊的距離是:[(20+girlBitWidth )- 20]。底部一樣的道理。

如圖:


這里寫圖片描述

如果我們只想畫上述圖片的第2部分,該怎么做呢?我們只需要做如下修改:

girlSrcRect = new Rect(girlBitWidth/2, 0, girlBitWidth, girlBitHeight/2);
  girlDesRect = new Rect(20, 50, 20+girlBitWidth, 50+girlBitHeight);

效果圖:
這里寫圖片描述
是不是就是顯示圖片的第二部分呢,細(xì)心的會發(fā)現(xiàn)這個圖和之前整體的圖片大小是一樣的。原因是什么呢:

girlSrcRect :表示我們要畫圖的部分。

girlDesRect :表示我們要繪圖的位置。從上面的girlDesRect 值看出,繪圖的位置的確是整個圖片的位置。

那我們只想要1/4圖的大小呢,怎么辦?

girlSrcRect = new Rect(girlBitWidth/2, 0, girlBitWidth, girlBitHeight/2);
  girlDesRect = new Rect(20, 50, 20+girlBitWidth/2, 50+girlBitHeight/2);

如下圖:
這里寫圖片描述

好了,就到這里了,畢竟自己寫的才回更深刻!

感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!

相關(guān)文章

最新評論