[Android] 零碎知识汇总 - View相关

前言

开始意识到,知识"缝合"的重要性,只要没有开始学会表述,看书再多,终究会忘记。

ok,这一篇,用来记录View的相关小知识点,持续更新与整理。

关于 View 绘制流程

  • onMeasure(): 尺寸大小
  • onLayout(): 摆放位置
  • onDraw(): 图层绘制

简单来说,自定义 View 时,最重要的就是这三个方法。个人认为,其中 onDraw() 是最关键的,也是最难的,其中牵扯到一大堆坐标的计算,晕~

简单说一下,自己的理解:

  • onMeasure()
    • 继承自 View 的话,就只是计算自己的尺寸。
    • 继承自 ViewGroup 的话,就先要计算每一个子 View 的宽高,并为其 mMeasuredWidth 和 mMeasuredHeight 这两个属性赋值,最近才计算出自己的尺寸。
    • 为了适配的话,可以尝试使用 resolveSize()。
  • onSizeChanged()
    • 提一嘴这个,个人比较常用,它在构造方法、onMeasure() 之后,又在 onDraw() 之前,此时已经完成全局变量初始化,也得到了控件的宽高;
    • 所以可以在这个方法中确定一些与宽高有关的数值,比如这个 View 的宽高半径,Padding 等,方便绘制的时候计算大小和位置。
  • onLayout()
    • 这个方法本身,其实是为了控制子 View 在自己中的摆放位置。
    • 继承自 View 的话,onLayout() 方法为空实现,毕竟没娃 = =
    • 继承自 ViewGroup 的话,需要复写,因为有孩子啊~
  • onDraw()
    • 其实 View 最终都是调用 draw() 方法进行绘制的,然而平常都是复写onDraw()方法进行绘制,没懂这两者之间的关系 = =
    • 需要先调用 super.draw() 完成系统的绘制,再进行自定义的绘制。
    • ViewGroup 中,dispatchDraw() 发起对子视图的绘制,具体没研究过。

附图一张,能够非常清晰的说明,整个绘制流程。同时,也说明了,invalidate() 和 requestLayout() 的区别。


奉上原图链接: https://lh3.googleusercontent.com/-TTZ-LN41ygA/UIQt75DBSEI/AAAAAAAAFAY/v8jAR9WWg5w/w829-h1463-p-rw/android.png

关于 View 的刷新机制

所谓的刷新机制,一句话说清楚,就是:子通知父开始刷新,父控制子的刷新操作。
常用的有两种刷新方式,invalidate(),requestLayout();
其实区别,再上图中已经说明了,
** requestLayout() 比 invalidate() 多走了 measure 与 layout 这两个流程 **
因此:

  • requestLayout() 常用于当 View 发生位移,旋转等 LayoutParams 发生变化的场景;
  • invalidate() 则只是对当前 View 进行重绘,不会进行测量、布局流程

额外提一句,
** postInvalidate() 是在非UI线程中调用,invalidate() 则是在UI线程中调用。**

关于 onDraw() 再多BB两句

我真正想说的是,drawText(),这个很奇葩,吃了不少苦头,先看看官方描述:



** 注意,关于 y 的描述,有一个词 baseline ** ,Android中,对文字有显示,划分了五条线,有点像小时候写拼音时的那个,其中第三条线,叫做 baseline,也就是说,xy参数,并不是常用的左上角坐标 = =




另外再说一句,在使用drawText(),处理文本(单个字符)居中时,有时候总是对不齐,请检查,** 文字的宽度,和,外接矩形的宽度是否一致 **,找不到特别合适的图,将就一下吧 = =

textSmallWidth 是数字3的真实宽度,而 mTextRect.height() 是外接矩形的高度,
额,这个解释一下,mTextRect.height() 是大于等于 mTextRect.width() 的,当内容是单个字符的时候,height = width

mTextPaint.getTextBounds("3", 0, timeText.length(), mTextRect); 

这段代码可以获取到,数字3绘制时的真实宽度。

对自定义View进行控制

这一段是在别人的博客上看到的,我觉得很有用,摘抄至此。尽管我都知道,但是没有总结过。

  1. 如果想控制 View 在屏幕上的渲染效果,就在重写 onDraw() 方法,在里面进行相应的处理。

  2. 如果想要控制用户与 View 之间的交互操作,则在 onTouchEvent() 方法中对手势进行控制处理。

  3. 如果想要控制 View 中内容在屏幕上显示的尺寸大小,就重写 onMeasure() 方法中进行处理。

  4. 在 XML文件中设置自定义View的XML属性。

  5. 如果想避免失去 View 的相关状态参数的话,就在 onSaveInstanceState() 和 onRestoreInstanceState() 方法中保存有关View的状态信息。

总结

第一次开始写,没有想象中的难,只要一开始写,就会不断面临选择从而最终达到目的,最可怕的就是,永远停留在开始前的那一刻,迟迟不肯动笔。
整个过程,花了很久,整理自己的思路,找合适的图,本以为30分钟就该搞定了,= =
果然,项目实际时间 = 预估时间 * 5;
写的有错的地方,望各位大牛指正,可能逻辑不够清晰,语言有些啰嗦,奈何小学语文没毕业~

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

推荐阅读更多精彩内容