现在的位置: 首页 > 综合 > 正文

Launcher笔记

2013年10月11日 ⁄ 综合 ⁄ 共 1619字 ⁄ 字号 评论关闭

*
 * Draw traversal performs several drawing steps which must be executed
 * in the appropriate order:
 *
 *  1. Draw the background  (绘制控件设置的背景,系统已在view.draw()中绘制,只要在xml中指定背景即可)
 *  2. If necessary, save the canvas' layers to prepare for fading  
 *  3. Draw view's content  (可以重写, onDraw(canvas);)
 *  4. Draw children      (可重写,用来分发canvas到子控件,具体看ViewGroup。对应方法dispatchDraw(canvas);此方法依次调用了子控件的draw()方法)
 *  5. If necessary, draw the fading edges and restore layers (绘制控件四周的阴影渐变效果)
 *  6. Draw decorations (scrollbars for instance) (用来绘制滚动条,对应方法onDrawScrollBars(canvas);。
 *      onDrawHorizontalScrollBar()和onDrawVerticalScrollBar()被隐藏了无法重写,也许有其他方法重写滚动条)

 */

Android的view组件显示主要经过mesure, layout和draw这三个过程。在mesure阶段里调用mesure(int widthSpec, int heightSpec)方法,这个方法是final不能被重写,在这个过程里会调用onMesure(int widthSpec, int heightSpec)方法。当组件设置好大小后,调用final layout(int l, int t, int r, int b)方法进行布局,在这个过程里会调用onLayout(boolean changed,
int l, int t, int r, int b)方法,所以处理组件的布局通常要重写onMesure和onLayout这两个方法。
    View组件的绘制会调用draw(Canvas canvas)方法,这个方法在源代码里看不到在哪里调用...draw过程中主要是先画Drawable背景,对drawable调用setBounds()然后是draw(Canvas c)方法.有点注意的是背景drawable的实际大小会影响view组件的大小,drawable的实际大小通过getIntrinsicWidth()和getIntrinsicHeight()获取,当背景比较大时view组件大小等于背景drawable的大小,不过俺没有在源代码里找到布局时调用过
getIntrinsicWidth()和getIntrinsicHeight()方法...
    画完背景后,draw过程会调用onDraw(Canvas canvas)方法,然后就是dispatchDraw(Canvas canvas)方法, dispatchDraw()主要是分发给子组件进行绘制,我们通常定制组件的时候重写的是onDraw()方法。值得注意的是ViewGroup容器组件的绘制,当它没有背景时直接调用的是dispatchDraw()方法, 而绕过了draw()方法,当它有背景的时候就调用draw()方法,而draw()方法里包含了dispatchDraw()方法的调用。因此要在ViewGroup上绘制东西的时候往往重写的是dispatchDraw()方法而不是onDraw()方法,或者自定制一个Drawable,重写它的draw(Canvas
c)和getIntrinsicWidth(),
getIntrinsicHeight()方法,然后设为背景。

还在纠结中,搞懂了再整理。

1.WorkSpace怎么画出5个屏幕大小的View.

抱歉!评论已关闭.