码迷,mamicode.com
首页 > 移动开发 > 详细

Android自定义View的一些不知道的细节

时间:2015-02-12 16:22:19      阅读:180      评论:0      收藏:0      [点我收藏+]

标签:

原因:

之所以写这个主要是因为我自认为自己对自定义View已经了如指掌,但是后来才发现自己犯了很多低级错误。

详解:

按照源码的注释,View的绘制过程是这样子的:
        /*
         * Draw traversal performs several drawing steps which must be executed
         * in the appropriate order:
         *
         *      1. Draw the background
         *      2. If necessary, save the canvas' layers to prepare for fading
         *      3. Draw view's content
         *      4. Draw children
         *      5. If necessary, draw the fading edges and restore layers
         *      6. Draw decorations (scrollbars for instance)
         */

先绘制背景,如果有必要,保存画布层,绘制内容,绘制孩子,绘制渐变,绘制装饰物。
让我们再看下源码的draw()方法里的一段代码
  if (!verticalEdges && !horizontalEdges) {
            // Step 3, draw the content
            if (!dirtyOpaque) onDraw(canvas);

            // Step 4, draw the children
            dispatchDraw(canvas);

            // Step 6, draw decorations (scrollbars)
            onDrawScrollBars(canvas);

            // we're done...
            return;
        }
从这里我们可以看出draw方法的调用过程是这样子。
onDraw -> <span style="font-family: Arial, Helvetica, sans-serif;">dispatchDraw -> </span><span style="font-family: Arial, Helvetica, sans-serif;">onDrawScrollBars</span>
这样我们基本可以明白我们重写的onDraw方法是干什么的了,以及draw()  ondraw() dispatchdraw的关系了。
如果你想在最顶层绘制,直接重写draw方法,因为draw方法里包含ondraw和dipatchdraw。
其实主要想写的一个细节就是这个东西。
如果你想让你绘制的东西一直在控件的某个位置一定要这样写
canvas.translate(getScrollX(), getScrollY());
这里就不解释了,明白了我之前说的就知道为什么要这么写了。我重写了listview然后发现我写的控件会出现跳帧现象,就是在滑动的时候出现fading edges的时候,后来才发现是因为这个原因。

Android自定义View的一些不知道的细节

标签:

原文地址:http://blog.csdn.net/windowsxp2014/article/details/43761595

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