转点来存着

Android - Canvas 简单总结: http://www.cnblogs.com/hwgt/p/5416866.html

在自定义控件时,经常需要使用canvas、paint等,在canvas类中,绘画基本都是靠drawXXX()方法来完成的,在这些方法中,很多时候都需要用到paint类型的参数,本文先对paint类常用的一些设置做个简单总结

paint 属性设置简单总结

图形绘制相关:

public void set(Paint src)  根据已有画笔的属性进行赋值

public void setColor(int color) 设置颜色

public void setAlpha(int alpha) 设置透明度,alpha为透明度,取值范围为0~255,数值越小越透明

public void setARGB(int a, int r, int g, int b)  设置透明度和颜色,a代表透明度,r,g,b代表颜色值

public void setAntiAlias(boolean aa) 设置是否使用抗锯齿功能,比较耗资源,减慢绘制速度

public void setDither(boolean dither) 设定是否使用图像抖动,如true,绘制出来的图片颜色更饱满、清晰

public void setStyle(android.graphics._Original_Paint.Style style) 设置画笔的样式,为FILL,FILL_OR_STROKE,或STROKE

以下这段文字来源于网络,谢谢作者!

当我们在调用drawCircle、drawOval、drawArc、drawRect等方法时,我们既可以绘制对应图形的填充面,也可以只绘制该图形的轮廓线,控制的关键在于画笔Paint中的style。Paint通过setStyle方法设置要绘制的类型,style有取三种值:Paint.Style.FILL、Paint.Style.STROKE和Paint.Style.FILL_AND_STROKE。

当style为FILL时,绘制是填充面,FILL是Paint默认的style;

当style为STROKE时,绘制的是图形的轮廓线;

当style为FILL_AND_STROKE时,同时绘制填充面和轮廓线,不过这种情况用的不多,因为填充面和轮廓线是用同一种颜色绘制的,区分不出轮廓线的效果。

public void setStrokeCap(Cap cap)

当画笔样式为STROKE或FILL_OR_STROKE时,设置笔刷的图形样式,如圆形样式  Cap.ROUND,或方形样式Cap.SQUARE

public void setStrokeWidth(float width) 当画笔样式为STROKE或FILL_OR_STROKE时,设置笔刷的粗细度

文字绘制相关:

public void setTextSize(float textSize) 设置文字大小

public void setTextScaleX(float scaleX) 设置文字x轴的缩放比例,可以实现文字的拉伸效果

public void setTextSkewX(float skewX)  设置文字倾斜弧度

public void setUnderlineText(boolean flag) 设置文字下划线效果

public void setStrikeThruText(boolean flag) 设置删除线效果

public Typeface setTypeface(Typeface typeface) 设置字体风格

public void setTextAlign(android.graphics._Original_Paint.Align align) 设置文字的对齐方向

其中有两个属性设置需要作说明:

1、public Typeface setTypeface(Typeface typeface) ,接收参数为 Typeface对象,在Typeface.java类中,比较简单的,有defaultFromStyle方法返回Typeface对象:

public static Typeface defaultFromStyle(int style) {}

2、public void setTextAlign(android.graphics._Original_Paint.Align align) 设置文字的对齐方向,接收的参数为Paint的内部枚举类Align的值,可选LEFT、CENTER和RIGHT。

下边是文字绘制时常用的属性设置例子:

publicvoid draw(Canvas canvas) {

super.draw(canvas);

paint.setTypeface(Typeface.defaultFromStyle(Typeface.BOLD));

paint.setColor(Color.RED);

paint.setTextSize(41);

paint.setTextAlign(Align.CENTER);

paint.setTextScaleX(2.5f);

paint.setTextSkewX(-0.5f);

paint.setUnderlineText(true);

paint.setStrikeThruText(true);

canvas.drawText("hwgt的博客",0,41, paint);

... ...

}

另外,需要注意的是:Canvas的drawText()方法中,如不setTextAlign(... ...)的话,第二个参数 x 默认是字符串的左边的位置,第三个参数则固定为这个字符串的baseline的位置。

Canvas属性与方法

首先列出canvas以draw开头的方法:

设置ARGB、颜色填充画布:

publicvoid drawARGB(int a,int r,int g,int b) {}

publicvoid drawColor(int color) {}

publicvoid drawRGB(int r,int g,int b) {}

canvas.drawARGB(50,255,0,0);//参数即为ARGB的值

画点:

publicnativevoid drawPoint(float x,float y, Paint paint);

//参数比较明显,就是点的坐标,需要注意的是,在绘制点之前,需要设置画笔的宽度,否则不能画出来

paint.setStrokeWidth(13);

//另外,还可以设置画笔的样式,来指定所画的点的样式,圆形还是方形

paint.setStrokeCap(Paint.Cap.ROUND);//或者paint.setStrokeCap(Paint.Cap.BUTT);

canvas.drawPoint(100,100, paint);

画直线:

publicvoid drawLine(float startX,float startY,float stopX,float stopY, Paint paint) {}

canvas.drawLine(100,100,500,500, paint);//参数为起点和终点的XY坐标

画圆:

publicvoid drawCircle(float cx,float cy,float radius, Paint paint) {}

canvas.drawCircle(200,200,100, paint);//参数为圆心坐标和半径

绘制矩形:

publicvoid drawRect(float left,float top,float right,float bottom, Paint paint) {}

publicvoid drawRect(RectF rect, Paint paint) {}

publicvoid drawRect(Rect r, Paint paint) {}

// RectF 和 Rect  都可用来定义一个矩形区域,主要区别是参数类型不同,一个是int类型,一个是float类型

private RectF mRectF;

mRectF =new RectF(100,100,200,500);

canvas.drawRect(mRectF, paint);

绘制圆角矩形:

publicvoid drawRoundRect(RectF rect,float rx,float ry, Paint paint) {}

private RectF mRectF;

mRectF =new RectF(100,100,500,500);//定义一个区域

canvas.drawRoundRect(mRectF,20,50, paint);//第二、三个参数分别定义x和y方向的圆角弧度

绘制一个区域的内切圆或椭圆(视所定义的矩形而定):

publicvoid drawOval(RectF oval, Paint paint) {}

private RectF mRectF;

mRectF =new RectF(100,100,200,500);

canvas.drawOval(mRectF, paint);

绘制弧形区域:

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

private RectF mRectF;

mRectF =new RectF(100,100,200,200);//定义一个矩形区域

canvas.drawArc(mRectF,0,90,false, paint);

//第二个参数为起始弧度,第三个为终止弧度,第四个为显示方式

绘制路径 — Path 的使用:

publicvoid drawPath(Path path, Paint paint) {}

paint.setStyle(Paint.Style.STROKE);

paint.setStrokeWidth(3);

mPath =new Path();

mPath.moveTo(100,100);

mPath.lineTo(200,100);

mPath.lineTo(150,150);

mPath.lineTo(150,350);

mPath.close();

canvas.drawPath(mPath, paint);

绘制路径,即指定几个点的坐标,然后按照顺序将这些点连接起来,那么,首先需要指定起点,使用moveTo方法,如果没有使用moveTo方法指定起点的话,默认起点为(0,9),然后用lineTo方法指定需要经过的点,最后,如果起点和终点的坐标不一样,并且需要将起点和终点连接起来的话,就调用close方法,如不调用close方法的话,起点和终点是不会被连接起来的。

绘制文本:

publicvoid drawText(String text,float x,float y, Paint paint) {}

publicvoid drawText(char[] text,int index,int count,float x,float y, Paint paint) {}

publicvoid drawText(String text,int start,int end,float x,float y, Paint paint) {}

canvas.drawText("hwgt",100,100, paint);

canvas.drawText(newchar [] {'h','w','g','t','3','1','3','3'},2,3,100,100, paint);

canvas.drawText("hwgt3133",2,4,100,100, paint);//含头不含尾

按照指定点的坐标绘制文本:

publicvoid drawPosText(String text,float[] pos, Paint paint) {}

publicvoid drawPosText(char[] text,int index,int count,float[] pos, Paint paint) {}

canvas.drawPosText("hwgt",newfloat[]{50.0f,50.0f,100.0f,100.0f,250.0f,250.0f,500.0f,500.0f,}, paint);

canvas.drawPosText(newchar[]{'h','w','g','t'},3,1,newfloat[]{50.0f,50.0f,100.0f,100.0f,250.0f,250.0f,500.0f,500.0f,}, paint);

//推荐使用第二个方法,if (index < 0 || index + count > text.length || count*2 > pos.length),就会报错

按照指定的路径绘制文本:

publicvoid drawTextOnPath(String text, Path path,float hOffset,float vOffset, Paint paint) {}

canvas的save和restore方法:

在绘制图形的过程中,会需要对画布进行旋转,缩放,平移等操作,但对画布进行比如平移操作之后,会对以后画上去的内容也产生影响,有时,我们只希望这种平移或是旋转操作只是临时作用于画布上的某些内容,这个时候就可以使用save和restore方法,save和restore方法一般是配对使用的,例如:

paint.setFakeBoldText(true);// 将画笔设置为粗体

canvas.drawText("00000000",0,75, paint);

canvas.save();

canvas.translate(0,250);

canvas.drawText("||||||||||||||||",0,75, paint);

canvas.restore();

canvas.drawText("—————",0,75, paint);

去掉save和restore方法即能看出效果。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容