绘制视图

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了绘制视图相关的知识,希望对你有一定的参考价值。

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 : 设置文本的删除线

以上是关于绘制视图的主要内容,如果未能解决你的问题,请参考以下文章

绘制视图

如何在 iOS 中在没有 UIImageView 的情况下在视图上绘制/绘制 UIIMage

Textview drawable 不在远程视图中显示可绘制图像

自定义视图 Canvas onDraw() 不绘制任何东西

基于视图的 NSOutlineView 在父视图之上绘制子视图

View的绘制流程