Android进程间通讯的实现方式以及自定义view的基本流程

进程间通讯的几种实现方式

  1. Intent
  2. Binder(AIDL)
  3. Messenger
  4. BroadcastReceiver

自定义View的基本流程

  1. 如果需要自定义属性的话,需要在styles文件夹中编写attrs.xml的文件
  2. 在Layout布局文件中引用,同时引用命名空间
  3. 在自定义View的构造方法中获取我们的自定义的属性,在自定义控件中进行读取
  4. 重写onMesure方法
  5. 当自定义View的宽高设为match_parent的时候自定义View会填满整个屏幕,当宽高设为一个固定值的时候,自定义View的宽高也会按照这个宽高显示,但是当把宽高设置为wrap_content的时候,它依旧会填满整个屏幕,所以为了解决这个问题,我们需要重写onMesure()方法 ,我们需要获取两个数据,一是父视图希望子视图的大小,二是子视图的模式 //获取模式 int specMode = MeasureSpec.getMode(measureSpec); //获取大小 int specSize = MeasureSpec.getSize(measureSpec);
  6. 重写onDraw()方法
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()方法,然后设为背景
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值