Android canvas drawBitmap方法详解及实例

 更新时间:2017年01月24日 14:47:21   作者:小猪快跑22  
这篇文章主要介绍了 Android canvas drawBitmap方法详解及实例的相关资料,需要的朋友可以参考下

 Android canvas drawBitmap方法详解及实例

之前自己在自定义view,用到canvas.drawBitmap(Bitmap, SrcRect, DesRect, Paint)的时候,对其中的第2和3个参数的含义含糊不清。看源码函数也没理解,然后看了一些其他的博客加上自己的理解,整理如下。首先,我们看一张图片,今天就要绘制这张图片。

这里写图片描述

然后将图片用红色的线条分成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)为图片的高度。

效果图如下 :


这里写图片描述

当我们想移动图片的位置,代码如下:

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);

效果图:
这里写图片描述
是不是就是显示图片的第二部分呢,细心的会发现这个图和之前整体的图片大小是一样的。原因是什么呢:

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);

如下图:
这里写图片描述

好了,就到这里了,毕竟自己写的才回更深刻!

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

相关文章

  • 利用Kotlin的协程实现简单的异步加载详解

    利用Kotlin的协程实现简单的异步加载详解

    这篇文章主要给大家介绍了关于利用Kotlin的协程实现简单的异步加载的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2018-03-03
  • Android实现网络加载图片点击大图后浏览可缩放

    Android实现网络加载图片点击大图后浏览可缩放

    这篇文章主要为大家详细介绍了Android实现网络加载图片点击大图后浏览可缩放,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-12-12
  • Android中SparseArray性能优化的使用方法

    Android中SparseArray性能优化的使用方法

    这篇文章主要为大家详细介绍了Android中SparseArray性能优化的使用方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-04-04
  • Android实现多个连续带数字圆圈效果

    Android实现多个连续带数字圆圈效果

    这篇文章主要为大家详细介绍了Android实现多个连续带数字圆圈效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • Android中Fab(FloatingActionButton)实现上下滑动的渐变效果

    Android中Fab(FloatingActionButton)实现上下滑动的渐变效果

    这篇文章主要给大家介绍了Android中FloatingActionButton(简称FAB)是如何实现上下滑动的渐变效果,文中给出了详细的示例代码,相信对大家具有一定的参考价值,有需要的朋友们可以一起看看吧。
    2017-02-02
  • Android中 service组件详解

    Android中 service组件详解

    Service是Android的四大组件之一,以下是我结合Android Doc和网上资料的学习总结,有不准确的地方请高手指出,互相学习嘛。。。
    2016-08-08
  • Android通过交互实现贝塞尔曲线的绘制

    Android通过交互实现贝塞尔曲线的绘制

    本篇我们将介绍简单的交互式绘图,通过获取触控位置来设定贝塞尔曲线的控制点,从而实现交互式绘制曲线,感兴趣的小伙伴可以了解一下
    2022-05-05
  • 详解Android StrictMode严格模式的使用方法

    详解Android StrictMode严格模式的使用方法

    这篇文章主要介绍了Android StrictMode严格模式的使用方法,需要的朋友可以参考下
    2018-01-01
  • Android基于OpenCV实现霍夫直线检测

    Android基于OpenCV实现霍夫直线检测

    霍夫变换利用点与线之间的对偶性,将图像空间中直线上离散的像素点通过参数方程映射为霍夫空间中的曲线,并将霍夫空间中多条曲线的交点作为直线方程的参数映射为图像空间中的直线。给定直线的参数方程,可以利用霍夫变换来检测图像中的直线。本文简单讲解Android的实现
    2021-06-06
  • Android定制自己的EditText轻松改变底线颜色

    Android定制自己的EditText轻松改变底线颜色

    这篇文章主要介绍了Android如何定制自己的EditText,如何轻松改变底线颜色,感兴趣的小伙伴们可以参考一下
    2015-12-12

最新评论