# 1. 前言
在自定义View的时候总是会涉及到View大小的测量,而且自己总是很粗糙的来处理其大小。而当遇到ViewGroup的时候,却总是缺点意思。故而这里想比较系统的整理一下在onMeasure的一些知识点。
# 2. 知识回顾
## 2.1 ViewGroup绘制流程
我们都知道,ViewGroup的绘制流程分为三步:**测量**、**布局**、**绘制**。对应onMeasure()、onLayout()、onDraw() 函数。这三个函数的作用分别如下。
* onMeasure():测量当前控件的大小。
* onLayout():使用 layout()函数对所有子控件进行布局。
* onDraw():根据布局的位置绘图。
对应的,自定义ViewGroup的三个步骤为:
* 测量它的每个子View的大小,计算出自身的宽高;
* 根据实际需求来放置其中的每个子View的位置;
* 重写触摸事件以及其余的方法;
### 2.1.1 onMeasure()
```
override fun onMeasure(widthMeasureSpec: Int, heightMeasureSpec: Int) {
super.onMeasure(widthMeasureSpec, heightMeasureSpec)
}
```
这里可以看见传入了两个Int类型的参数widthMeasureSpec和heightMeasureSpec。它们是指父类传递过来给当前View的一个建议值,即想把当前 View 的尺寸设置为宽widthMeasureSpec、高 heightMeasureSpec。至于它们的组成这里不再详细介绍,其实也就是测量模式(前2位)+测量宽度(后30位)。简单来说XML布局和这里的测量模式的对应关系如下:
| XML布局 | 测量模式 |
| --- | --- |
| wrap_content | AT\_MOST |
| match_parent | EXACTLY |
| 具体值 | EXACTLY |
注意到:当我们得到的测量模式为EXACTLY 的时候,就不需要处理了,因为这是在xml中指定的,不应该更改。 AT\_MOST的时候,需要进行计算。
那么,我们在onMeasure中需要完成对每个子View大小的测量,然后计算出自己需要多大的宽高。这里可以简单的给出一个示例:
- 介绍
- UI
- MaterialButton
- MaterialButtonToggleGroup
- 字体相关设置
- Material Design
- Toolbar
- 下拉刷新
- 可折叠式标题栏
- 悬浮按钮
- 滑动菜单DrawerLayout
- NavigationView
- 可交互提示
- CoordinatorLayout
- 卡片式布局
- 搜索框SearchView
- 自定义View
- 简单封装单选
- RecyclerView
- xml设置点击样式
- adb
- 连接真机
- 小技巧
- 通过字符串ID获取资源
- 自定义View组件
- 使用系统控件重新组合
- 旋转菜单
- 轮播图
- 下拉输入框
- 自定义VIew
- 图片组合的开关按钮
- 自定义ViewPager
- 联系人快速索引案例
- 使用ListView定义侧滑菜单
- 下拉粘黏效果
- 滑动冲突
- 滑动冲突之非同向冲突
- onMeasure
- 绘制字体
- 设置画笔Paint
- 贝赛尔曲线
- Invalidate和PostInvalidate
- super.onTouchEvent(event)?
- setShadowLayer与阴影效果
- Shader
- ImageView的scaleType属性
- 渐变
- LinearGradient
- 图像混合模式
- PorterDuffXfermode
- 橡皮擦效果
- Matrix
- 离屏绘制
- Canvas和图层
- Canvas简介
- Canvas中常用操作总结
- Shape
- 圆角属性
- Android常见动画
- Android动画简介
- View动画
- 自定义View动画
- View动画的特殊使用场景
- LayoutAnimation
- Activity的切换转场效果
- 属性动画
- 帧动画
- 属性动画监听
- 插值器和估值器
- 工具
- dp和px的转换
- 获取屏幕宽高
- JNI
- javah命令
- C和Java相互调用
- WebView
- Android Studio快捷键
- Bitmap和Drawable图像
- Bitmap简要介绍
- 图片缩放和裁剪效果
- 创建指定颜色的Bitmap图像
- Gradle本地仓库
- Gradle小技巧
- RxJava+Okhttp+Retrofit构建网络模块
- 服务器相关配置
- node环境配置
- 3D特效