Android canvas画布,Android Canvas(画布)详解

Android 中使用的图像处理引擎,2D部分是androidSDK内部自己提供,3D部分是用Open GL ES 1.0。

而我们最常用的就是在一个View上画一些图片,形状或者自定义的文本内容,这里我们都是使用Canvas来实现的!你可以获取View中的Canvas 对象,在onDraw(Canvas canvas) 提供了canvas 对象.

在进行改变的时候调用,View.invalidata()方法让View重新刷新,然后绘制一个新的形状,这样实现2D动画效果。

下面我们就主要来了解一下Canvas的使用方法

Canvas对象的获取方式有两种。

一种是我们通过重写View.OnDraw方法。

另一种就是当你想创建一个Canvas对象时使用的方法。

Bitmap b=Bitmap.createBitmap(100,100,Bitmap.Confif.ARGB_8888);

这里补充一个知识点,也是怕我自己忘记

createBitmap中有三个参数

第一个是宽

第二个是高

第三个是位图的色彩模式

public static final Bitmap.Config ALPHA_8 就是8位alpha位图

public static final Bitmap.Config ARGB_4444 代表16位ARGB位图

public static final Bitmap.Config ARGB_8888 代表32位ARGB位图

public static final Bitmap.Config RGB_565 代表8位RGB位图

ARGB代表色彩模式 A alapth R red G green B blue 即透明度 三原色

位图数越高代表其可以存储的颜色信息越多,当然图像也就越逼真,占内存更大!

Canvas 可以绘制的对象有

arcs 弧线

argb color填充颜色

circle 圆 oval 椭圆

point 点

line Rect矩形

Picture 图片

RoundRect圆角矩形

text文本

Vertices 顶点

path 路径

当然之前说过可以完成一些简单的2D动画

那么简单的2D动画主要有

rotate旋转 scale translate skew扭曲等

canvas,drawaCircle(100,100,90,paint);

在X=100,Y=100的位置画一个半径90的圆

RectF rect =new RectF(50,50,200,200)

canvas.drawRect(rect,paint);

画一个矩形

Path path=new Path();//定义一条路径

path.moveTo(10,10);

path.moveTo(50,60);

path.moveTo(200,80);

path.moveTo(10,10);

canvas.drawpath(path,paint);

画出一个三角区域

Path path = new Path(); //定义一条路径

path.moveTo(10, 10); //移动到 坐标10,10

path.lineTo(50, 60);

path.lineTo(200,80);

path.lineTo(10, 10);

canvas.drawTextOnPath(“Android777开发者博客”, path, 10, 10, paint);

在一条线上画出文字

一个比较帅气的画图,画一个刻度盘

paint.setAntiAlias(true);抗锯齿

paint.setStyle(Style.STROKE);

canvas.translate(canvas.getWidth()/2,200);

canvas.drawCircle(0,0,100,paint);//画圆圈

canvas.save();

canvas.translate(-75, -75);

Path path = new Path();

path.addArc(new RectF(0,0,150,150), -180, 180);

Paint citePaint = new Paint(paint);

citePaint.setTextSize(14);

citePaint.setStrokeWidth(1);

canvas.drawTextOnPath("http://www.android777.com", path, 28, 0, citePaint);

canvas.restore();

Paint tmpPaint = new Paint(paint); //小刻度画笔对象

tmpPaint.setStrokeWidth(1);

float y=100;

int count = 60; //总刻度数

for(int i=0 ; i

if(i%5 == 0){

canvas.drawLine(0f, y, 0, y+12f, paint);

canvas.drawText(String.valueOf(i/5+1), -4f, y+25f, tmpPaint);

}else{

canvas.drawLine(0f, y, 0f, y +5f, tmpPaint);

}

canvas.rotate(360/count,0f,0f); //旋转画纸

}

//绘制指针

tmpPaint.setColor(Color.GRAY);

tmpPaint.setStrokeWidth(4);

canvas.drawCircle(0, 0, 7, tmpPaint);

tmpPaint.setStyle(Style.FILL);

tmpPaint.setColor(Color.YELLOW);

canvas.drawCircle(0, 0, 5, tmpPaint);

canvas.drawLine(0, 10, 0, -65, paint);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值