Android canvas drawBitmap方法详解及实例

作者:小猪快跑22 时间:2021-06-12 12:17:18 

 Android canvas drawBitmap方法详解及实例

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

Android canvas drawBitmap方法详解及实例

然后将图片用红色的线条分成4个部分,如下:


Android canvas drawBitmap方法详解及实例

我们自定义一个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)为图片的高度。

效果图如下 :


Android canvas drawBitmap方法详解及实例

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


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

表示图片的左边所在的位置为20个像素,图片的顶部在View上的位置为50个像素。图片右边在view上的位置为(20+girlBitWidth )即距离图片的左边的距离是:[(20+girlBitWidth )- 20]。底部一样的道理。

如图:


Android canvas drawBitmap方法详解及实例

如果我们只想画上述图片的第2部分,该怎么做呢?我们只需要做如下修改:


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

效果图:
Android canvas drawBitmap方法详解及实例
是不是就是显示图片的第二部分呢,细心的会发现这个图和之前整体的图片大小是一样的。原因是什么呢:

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

如下图:
Android canvas drawBitmap方法详解及实例

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

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

来源:http://blog.csdn.net/zhujiangtaotaise/article/details/50505169

标签:Android,canvas,drawBitmap
0
投稿

猜你喜欢

  • JDK14性能管理工具之jstack使用介绍

    2022-10-11 18:48:01
  • c#调用c++的DLL的实现方法

    2023-10-27 05:27:40
  • android downsample降低音频采样频率代码

    2021-11-19 15:32:59
  • JavaWeb利用struts实现文件下载时改变文件名称

    2023-10-24 11:26:53
  • java实现人员信息管理系统

    2023-11-02 05:21:31
  • Java 反射机制实例详解

    2023-11-28 03:49:47
  • spring注解之@Valid和@Validated的区分总结

    2023-11-01 07:51:42
  • 解决java启动时报线程占用报错:Exception in thread “Thread-14“ java.net.BindException: Address already in use: bind

    2021-07-05 04:26:23
  • Java异常处理中的各种细节汇总

    2023-09-26 02:50:17
  • C#实现自定义打印文字和图片的示例代码

    2021-05-30 02:35:20
  • Java 抽象类特点总结

    2023-07-28 10:39:46
  • SpringMVC中Model与Session的区别说明

    2023-07-07 20:42:58
  • SpringBoot通过@Value实现给静态变量注入值详解

    2022-04-30 14:30:37
  • C#的Excel导入、导出

    2023-09-10 01:00:24
  • Android APK使用Debug签名重新打包 Eclipse更改默认Debug签名

    2022-03-07 13:27:12
  • java 查找字符串所在的位置代码

    2023-12-22 21:48:17
  • c# 获取CookieContainer的所有cookies函数代码

    2023-06-17 23:11:30
  • 探讨:如何使用委托,匿名方法对集合进行万能排序

    2022-06-15 02:17:23
  • android采用FFmpeg实现音频混合与拼接剪切

    2023-10-04 06:51:24
  • 高可用架构etcd选主故障主备秒级切换实现

    2022-08-08 23:40:48
  • asp之家 软件编程 m.aspxhome.com