canvas通俗的说就是一个帆布,我们可以用刷子paint,就此随机抽签显卡。

原理:

能够canvas视Surface替代或接口。图形绘制Surface向上。Canvas封装了全部的绘制调用。

通过Canvas。

绘制到Surface上的内容首先存储到一个内存区域(也就是相应的Bitmapz中),该Bitmap终于会呈现到窗体上。

使用:

1、Canvas能够直接new Canvas();

2、在View中重写OnDraw()方法,里面有一个Canvas,今天讨论的内容。

方法:

//绘制区域。參数一为RectF一个区域

drawRect(RectF rect, Paint paint)

//绘制一个路径。參数一为Path路径对象

drawPath(Path path, Paint paint)

//贴图,參数一就是我们常规的Bitmap对象。參数二是源区域(这里是bitmap),參数三是目标区域

(应该在canvas的位置和大小),參数四是Paint画刷对象,由于用到了缩放和拉伸的可能,当原始

Rect不等于目标Rect时性能将会有大幅损失。

drawBitmap(Bitmap bitmap, Rect src, Rect dst, Paint paint)

//画线,參数一起始点的x轴位置,參数二起始点的y轴位置,參数三终点的x轴水平位置,

參数四y轴垂直位置,最后一个參数为Paint 画刷对象。

drawLine(float startX, float startY, float stopX, float stopY, Paintpaint)

//画点。參数一水平x轴,參数二垂直y轴。第三个參数为Paint对象。

drawPoint(float x, float y, Paint paint)

//渲染文本,Canvas类除了上面的还能够描绘文字。參数一是String类型的文本,參数二x轴,

參数三y轴,參数四是Paint对象。

drawText(String text, float x, floaty, Paint paint)

//画椭圆,參数一是扫描区域,參数二为paint对象;

drawOval(RectF oval, Paint paint)

// 绘制圆,參数一是中心点的x轴。參数二是中心点的y轴,參数三是半径,參数四是paint对象;

drawCircle(float cx, float cy, float radius,Paint paint)

//画弧。參数一是RectF对象。一个矩形区域椭圆形的界限用于定义在形状、大小、电弧,參数二是

起始角(度)在电弧的開始,參数三扫描角(度)開始顺时针測量的,參数四是假设这是真的话,包含

椭圆中心的电弧,并关闭它,假设它是假这将是一个弧线,參数五是Paint对象;

drawArc(RectF oval, float startAngle, float sweepAngle, boolean useCenter, Paint paint)

接下来就要開始画了。还须要工具Paint,path

Paint ,就是画笔。我们new paint();等到一仅仅画笔,然后设置它的一些属性。

Paint类经常用法:

setARGB(int a, int r, int g, int b) // 设置 Paint对象颜色,參数一为alpha透明值

setAlpha(int a) // 设置alpha不透明度,范围为0~255

setAntiAlias(boolean aa) // 是否抗锯齿

setColor(int color)  // 设置颜色,这里Android内部定义的有Color类包括了一些常见颜色定义

setTextScaleX(float scaleX)  // 设置文本缩放倍数,1.0f为原始

setTextSize(float textSize)  // 设置字体大小

setUnderlineText(booleanunderlineText)  // 设置下划线

setStyle(Style.STROKE)//设置画笔空心

直接上样例:

public class DrawviewActivity extends Activity {

	@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// set DrawView's width and height
Display d = getWindowManager().getDefaultDisplay();
DrawView dv = new DrawView(this);
dv.width = d.getWidth();
dv.height = d.getHeight();
setContentView(dv);
}
class DrawView extends View { public float width;
public float height;
private Paint mpaint; public DrawView(Context context) {
super(context);
mpaint = new Paint();
mpaint.setColor(Color.RED);
mpaint.setAntiAlias(true); } @Override
protected void onDraw(Canvas canvas) {
// TODO Auto-generated method stub
super.onDraw(canvas); // drawtext
canvas.save();
mpaint.setTextSize(30);
canvas.drawText("hello honjane", 20, 20, mpaint);
canvas.restore(); // drawRect
canvas.save();
RectF r = new RectF(40, 40, 60, 60);
mpaint.setColor(Color.BLUE);
canvas.drawRect(r, mpaint);
canvas.restore(); canvas.save();
mpaint.setColor(Color.BLUE);
canvas.drawRect(65, 40, 85, 60, mpaint);
canvas.restore(); // drawCircle
canvas.save();
mpaint.setStyle(Style.STROKE);
canvas.drawCircle(width / 2, height / 2, 100, mpaint);
canvas.restore(); // drawArc
canvas.save();
RectF oval1 = new RectF(150, 300, 180, 400);
canvas.drawArc(oval1, 180, 250, false, mpaint);// 小弧形
oval1.set(300, 300, 600, 780);
canvas.drawArc(oval1, 230, 170, false, mpaint);
oval1.set(200, 300, 500, 780);
canvas.drawArc(oval1, 230, 170, true, mpaint); canvas.restore(); // 三角形 canvas.save();
mpaint.setStyle(Style.FILL);
Path p = new Path();
p.moveTo(80, 100);
p.lineTo(140, 300);
p.lineTo(20, 300);
p.close();
canvas.drawPath(p, mpaint);
canvas.restore(); canvas.save();
mpaint.setStyle(Paint.Style.FILL);// 充满
mpaint.setColor(Color.LTGRAY);
mpaint.setAntiAlias(true);// 设置画笔的锯齿效果
canvas.drawText("画圆角矩形:", 10, 260, mpaint);
RectF oval3 = new RectF(80, 260, 200, 300);// 设置个新的长方形
canvas.drawRoundRect(oval3, 20, 15, mpaint);// 第二个參数是x半径。第三个參数是y半径
canvas.restore(); // 可变色的
canvas.save();
Shader shader = new LinearGradient(0, 0, 100, 100, new int[] {
Color.BLACK, Color.CYAN, Color.DKGRAY, Color.GRAY }, null,
Shader.TileMode.MIRROR);
mpaint.setShader(shader);
RectF oval2 = new RectF(250, 100, 450, 300);
canvas.drawArc(oval2, 200, 130, true, mpaint);
canvas.restore(); //绘图片
canvas.save();
Bitmap bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.ic_launcher);
canvas.drawBitmap(bitmap, 250,360, mpaint);
canvas.restore();
}
}
}

版权声明:本文博主原创文章,博客,未经同意不得转载。

Android采用canvas绘制各种图形的更多相关文章

  1. Android利用canvas画各种图形

    Android利用canvas画各种图形(点.直线.弧.圆.椭圆.文字.矩形.多边形.曲线.圆角矩形) 本文链接:https://blog.csdn.net/rhljiayou/article/det ...

  2. 学习笔记:HTML5 Canvas绘制简单图形

    HTML5 Canvas绘制简单图形 1.添加Canvas标签,添加id供js操作. <canvas id="mycanvas" height="700" ...

  3. Canvas学习:封装Canvas绘制基本图形API

    Canvas学习:封装Canvas绘制基本图形API Canvas Canvas学习   从前面的文章中我们了解到,通过Canvas中的CanvasRenderingContext2D对象中的属性和方 ...

  4. Android自定义控件 -Canvas绘制折线图(实现动态报表效果)

    有时候我们在项目中会遇到使用折线图等图形,Android的开源项目中为我们提供了很多插件,但是很多时候我们需要根据具体项目自定义这些图表,这一篇文章我们一起来看看如何在Android中使用Canvas ...

  5. android用canvas绘制两种波纹效果

     波形效果有几种不同的呈现形式,比如从中间向四周散开的波形,也就是熟知的水涟漪:还有上下波动的曲线,像五线谱等.英文中可以称作Wave或者Ripple,所以暂且叫它们WaveView.WaveLayo ...

  6. [html5] 学习笔记-Canvas 绘制渐变图形与绘制变形图形

    在 HTML5 中,使用 Canvas API 绘制图形的知识,可以对绘制图形进行处理,包含使用 Canvas API 绘制渐变图形,使用 Canvas API 的坐标轴变换处理功能绘制变形图形.其中 ...

  7. canvas绘制简单图形

    canvas绘图篇: canvas绘制矩形: <!DOCTYPE html> <html> <head lang="en"> <meta ...

  8. h5 的canvas绘制基本图形

    文章地址:https://www.cnblogs.com/sandraryan/ canvas是一个标签,可用于绘制复杂图形,渲染效果比普通DOM快 某些低版本浏览器不支持 canvas 使用原生几乎 ...

  9. Android利用canvas画各种图形(点、直线、弧、圆、椭圆、文字、矩形、多边形、曲线、圆角矩形) .

    1.首先说一下canvas类: Class Overview The Canvas class holds the "draw" calls. To draw something, ...

随机推荐

  1. html中返回上一页

    <a href="<a href="javascript :history.back(-1)">返回上一页</a>或<a href=& ...

  2. 关于QTP

    关于QTP,我也才接触,只是上来记录一下安装过程,免得以后忘记,又要查一堆资料. 简单介绍一下QTP: QTP的基本功能包括2个部分:一部分是提供给初级用户使用的关键字视图:另一部分是提供给熟悉VBS ...

  3. NSPredicate的用法

    一般来说这种情况还是蛮多的,比如你从文件中读入了一个array1,然后想把程序中的一个array2中符合array1中内容的元素过滤出来. 正 常傻瓜一点就是两个for循环,一个一个进行比较,这样效率 ...

  4. mongodb实现简单的增删改查

    package mongoDB; import java.net.UnknownHostException; import java.util.ArrayList; import java.util. ...

  5. (视频)《高速创建站点》 4.2 完结篇 – 应用运营vs.发射卫星,遥測(Telemetry) 技术

    本文是<高速创建站点>系列的第10篇(完结篇),假设你还没有看过之前的内容,建议你点击下面文件夹中的章节先阅读其它内容再回到本文.訪问本系列文件夹.请点击:http://anb.io/bl ...

  6. HP服务器更换主板前后的注意事项

    问题 X86服务器免不了会出现故障,以我们实验室使用的HP服务器为例,已经有几台因为各种故障更换过主板了,更换主板前后有些事情需要我们应该注意或处理, 这里记录如下,其中第二.三点是针对我们所使用的C ...

  7. 【Android接口实现】ActionBar利用整理的一些细节

    转载请注明出处:http://blog.csdn.net/zhaokaiqiang1992 关于ActionBar的使用,非常多大神早就已经写了非常好的文章进行了介绍,所以ActionBar的基本使用 ...

  8. CentOS tripwire-文件指纹

    Tripwire是目前最为著名的unix下文件系统完整性检查的软件工具,这一软件采用的技术核心就是对每个要监控的文件产生一个数字签名,保留下来.当文件现在的数字签名与保留的数字签名不一致时,那么现在这 ...

  9. WindowsPhone 在 根据公历 获取月球日期数据

    WindowsPhone 在 根据公历 获取月球日期数据 WindowsPhone 在 它们的定义 类,根据公历 获取月球日期数据 using System; using System.Collect ...

  10. Sliverlight之 画刷

    1,5种画刷 (见Project15) (1)TextBlock控件中的Forground和BackGround属性是一个什么对象?它在前台的完整的写法是什么?(实际是.net做了一个转换,可以直接写 ...