码迷,mamicode.com
首页 > 其他好文 > 详细

绘制视图

时间:2017-03-08 22:37:16      阅读:188      评论:0      收藏:0      [点我收藏+]

标签:sla   ova   save   规则   canvas   覆盖   等等   res   绘制矩形   

1.三个可进行绘制的方法:

在自定义视图中,有三个函数可以重写用于界面绘制,在视图创建过程中,三个函数的执行顺序依次是:onLayout、onDraw、dispatchDraw。
1、onLayout(boolean changed, int left, int top, int right, int bottom) : 
onLayout用于定位该视图在上级视图中的位置,从其参数中就可以看出来。由于该函数没有画布,因此只适合绘制现成的视图控件。
2、onDraw(Canvas canvas) : 
自定义控件一般是重写onDraw方法,在画布中绘制各种图形。
3、dispatchDraw(Canvas canvas) : 
dispatchDraw与onDraw的区别在于:onDraw在绘制下级视图之前,而dispatchDraw在绘制下级视图之后,所以如果不想自己的绘图被下级视图覆盖的话,就要在dispatchDraw中进行绘制操作。为方便记忆,只要是从ViewGroup衍生出的视图,都用dispatchDraw,其他小控件都用onDraw

 

2.Canvas画布的使用

Canvas是Android提供的图形操作类。下面列出Canvas的常用方法:

①划定可绘制的区域(裁剪区域)

虽然本视图内的所有区域都是可以绘制的,但是有时候我们还是只想在某个圆形区域或者矩形区域内部画画,那么在绘制之前就得指定允许绘制的区域大小
clipPath : 裁剪不规则曲线区域
clipRect : 裁剪矩形区域
clipRegion : 裁剪一块组合区域

 

②在区域内部绘制图形

drawArc : 绘制扇形
drawBitmap : 绘制图像
drawCircle : 绘制圆形
drawLine : 绘制直线
drawOval : 绘制椭圆
drawPath : 绘制路径,即不规则曲线
drawPoint : 绘制点
drawRect : 绘制矩形
drawRoundRect : 绘制圆角矩形
drawText : 绘制文本

③移动整个画布

rotate : 旋转画布
scale : 缩放画布
translate : 平移画布

④存取画布的状态

Canvas的不同绘制操作会互相影响,比如说我们想对整个画布做旋转,除了某个直线(即该直线保持不动),如果没有状态机制,那么该直线也只能跟着旋转。有了状态机制,我们就可以在绘制该直线前保存画布状态(保存旋转操作),然后画直线,最后再恢复画布状态。这样在save-restore代码之间绘制的任何图形,都不会收到save-restore代码以外其他图形操作的影响。
save : 保存画布状态
restore : 恢复画布状态

⑤画笔Paint的使用

在上述绘制图形函数当中,都需要指定Paint,Paint上定义了画笔的颜色、样式、粗细、阴影、下划线等等。Paint的常用操作包括:
setAntiAlias : 设置是否使用抗锯齿功能,主要用于画圆圈等曲线
setColor : 设置画笔的颜色
setShader : 设置画笔的渐变效果
setShadowLayer :  设置画笔的阴影
setStyle : 设置画笔的样式(线条还是填充)
setStrokeWidth : 设置线条的粗细
setUnderlineText : 设置文本的下划线
setStrikeThruText : 设置文本的删除线

绘制视图

标签:sla   ova   save   规则   canvas   覆盖   等等   res   绘制矩形   

原文地址:http://www.cnblogs.com/ganchuanpu/p/6523287.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!