一、setContentView是如何添加到屏幕上显示
1.顶层创建DecorView,是在PhoneWindow里使用
2.在DecordView添加ViewGroup
3.在ViewGroup去添加控件以及ViewGroup
data:image/s3,"s3://crabby-images/1e7eb/1e7ebf26002a09ed71eba7c5c8377a4567c14190" alt=""
二、view绘制大致流程
data:image/s3,"s3://crabby-images/1e367/1e3677bbe96786f1e7d058f2a4e7d7504e39b3b2" alt=""
requestLayout和invalidate的区别:
requestLayout : 它是重新调用onMeasure、onLayout() 方法
invalidate : 重新调用onDraw的方法
三、深度解析UI测量的过程
DecorView的MeasureSpec的测量规则和计算:
LayoutParams.MATCH_PARENT: 最大模式,窗口大小,也就是windowSize的大小
LayoutParams.WRAP_CONTENT : 自适应模式,最大设置为decorView的大小
固定大小 : 精确模式,大小为LayoutParams的大小
data:image/s3,"s3://crabby-images/8aecd/8aecd6fffbfbf87f696fb26376fb733c15cbce18" alt=""
自己写的控件的MeasureSpec的测量规则和计算
getChildMeasureSpec的参数讲解:
int spec : 父容器的测量格式
int padding : 父容器当前使用情况
int childDimension : 代表子空间LayoutParams的宽度、高度的大小
data:image/s3,"s3://crabby-images/2fd22/2fd22f2dec33871c6be7a2f006e0212d53e8ef12" alt=""
data:image/s3,"s3://crabby-images/da7e6/da7e6ff29c5a9e634058fe960fd6ba3a485dbf4f" alt=""
ViewGroup测量过程:onMeasure(测量子控件宽、高) --> setMeasuredDimension(设置测量父布局的宽、高,在自定义view中用的比较多)-->setMeasuredDimensionRaw(设置最终值)
View测量过程:onMeasure(测量自身宽、高) --> setMeasuredDimension(设置自身的宽、高,在自定义view中用的比较多)-->setMeasuredDimensionRaw(设置最终值)
四、深度解析UI布局的过程
ViewGroup : 调用onLayout的方法,调用child.layout递归来摆放子控件位置
View :调用view.layout通过left、right、top、buttom来确定自身位置
五、深度解析UI绘制的过程
1.Paint常用的API讲解
data:image/s3,"s3://crabby-images/1011f/1011f7a20daf30b963f8541515ffd486a5291f06" alt=""
2.接口显示效果图
setStrokeJoin接口显示
data:image/s3,"s3://crabby-images/b56a7/b56a74c8e40a708ee6d2685b192601f68dd8bd76" alt=""
setStrokeCap接口显示效果
data:image/s3,"s3://crabby-images/4e389/4e3896e1c4aff0bafe7ff15a9cef1f6a48a8aba4" alt=""
3.代码演示以及展示效果
data:image/s3,"s3://crabby-images/6bc05/6bc0549ef2d10040a4a25f40e2473bf6176f78f3" alt=""
LinearGradient 线性渲染器展示效果
data:image/s3,"s3://crabby-images/ca1bc/ca1bcfd7ca148cb5d5f353d7d7644d6cf353a571" alt=""
RadialGradient环形渲染器展示效果
data:image/s3,"s3://crabby-images/197a5/197a53bf1355d4e775655ae56c44486471c098fe" alt=""
SweepGradient扫描渲染器展示效果
data:image/s3,"s3://crabby-images/3bf3f/3bf3fc7c841382250aa79fc0d25f4150de60380b" alt=""
BitmapShader 有三种不同模式展示,这里只展示两种效果
data:image/s3,"s3://crabby-images/967c5/967c55f91c46caffa44fc28762f946b80f387f25" alt=""
data:image/s3,"s3://crabby-images/909cf/909cf02831e45e1bfd15fe6ff99c40371fc1e39f" alt=""
ComposeShader组合渲染图展示效果
data:image/s3,"s3://crabby-images/d43a9/d43a9f3452ce57998ef2e1928f7ed0e3df6e162e" alt=""
六、涂层渲染混合模式讲解
1.常见使用的方法mPaint.setXfermode() 、ComposeShader、PorterDuffColorFilter
注意:在有些版本不支持硬件加速,所以使用涂层必须关掉硬件加速,可以看看刮刮卡实现,和这个原理很类似
2.十八种模式具体讲解
CLEAR : 绘制都不会提交到画布上
SRC :显示上层绘制图像
DST : 显示下层绘制图像
SRC_OVER : 正常绘制,上层居上显示
DST_OVER : 正常绘制,下层居上绘制
SRC_IN : 取两层交集的地方,显示上层
DST_IN : 取两层交集的地方,显示下层
SRC_OUT : 取上层绘制非交集部分,交集部分为透明
DST_OUT : 取下层绘制非交集部分,交集部分为透明
SRC_ATOP : 取上层交集部分和下层非交集部分
DST_ATOP : 取下层交集部分和上层非交集部分
XOR : 去除两图层交集地方
DARKEN : 取两层图全部区域,交集部分颜色变暗
LIGHTEN : 取两图层全部区域,交集部门颜色变亮
MULTIPLY : 取两图层交集地方,重叠地方颜色叠加
SCREEN : 取两图层全部区域,交集部分滤色
ADD : 取两图层全部区域,交集部分饱和度相加
OVERLAY :取两图层全部区域,交集部分叠加
data:image/s3,"s3://crabby-images/22590/2259078781c52af8e70858864f887fb1d64ba6bc" alt=""
data:image/s3,"s3://crabby-images/df0f5/df0f53a0c7fe4a066753f9434ce1e988cb7f313d" alt=""
七、图片做滤镜处理
1.去除颜色或者让某些颜色更亮
data:image/s3,"s3://crabby-images/c4310/c43104e0bbd7de6e421408b71f673ce4d5329bd7" alt=""
2.图片和颜色混合
data:image/s3,"s3://crabby-images/68709/6870928a6ed2a9f824ed148327ec05a42dbc3fd2" alt=""
3.修改图片颜色方法:修改偏移量、颜色数字变大或者变小
data:image/s3,"s3://crabby-images/9b5b2/9b5b24ce793ee212bd922342c396de43cb83ea6c" alt=""
八、Canvas的使用
1.位置、形状变化的API接口
data:image/s3,"s3://crabby-images/a91eb/a91eb4b54bdb6edec071a33cdf24b9b4f98a395e" alt=""
2.保存canvas画布的存储、恢复的API接口
data:image/s3,"s3://crabby-images/4e643/4e643ba78da888419a15ebe7d3f783e6a68991ad" alt=""
网友评论