欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android canvas drawBitmap方法详解及实例

程序员文章站 2024-02-15 19:56:28
 android canvas drawbitmap方法详解及实例 之前自己在自定义view,用到canvas.drawbitmap(bitmap, srcre...

 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方法详解及实例

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

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