[看书日记20151226]MeasureSpec和LayoutParams的对应关系 , View的工作流程

MeasureSpec和LayoutParams的对应关系 :

1.DecorView 由窗口的尺寸和自身的LayoutParams决定MeasureSpec

2.普通view由父容器的MeasureSpec和自身的LayoutParams决定自己的MeasureSpec

(查看普通View的MeasureSpaec的创建规则p182)


 View的工作流程:

1.View的最终大小是在layout阶段确定的(p184)

2.重写onMeasure方法设置wrap_content时的自身大小的原因;(p186)

3.ViewGroup是抽象类,要重写onMeasure方法;

4.在onLayout方法中去获取View的测量宽/高

5.无法保证在onCreate.onStart, onResume时某个View已经测量完毕;

6.提供4种方法来获取宽/高onWindowFocusChanged, view.post(runnable) , ViewTreeObserver , view.measure



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在自定义 View 中,paddingLeft 和 paddingRight 可以通过以下方式来处理: 1. 在 onMeasure() 方法中,需要将 View 的实际宽度减去左右 padding 的值,这样可以确保 View 在绘制时不会被 padding 所占据。 2. 在 onDraw() 方法中,绘制的内容应该是从 padding 区域开始的,这样可以确保绘制的内容不会被 padding 所覆盖。 下面是一个简单的示例代码: ``` public class MyView extends View { public MyView(Context context) { super(context); } public MyView(Context context, AttributeSet attrs) { super(context, attrs); } @Override protected void onMeasure(int widthMeasureSpec, int heightMeasureSpec) { int width = MeasureSpec.getSize(widthMeasureSpec); int height = MeasureSpec.getSize(heightMeasureSpec); int paddingLeft = getPaddingLeft(); int paddingRight = getPaddingRight(); int contentWidth = width - paddingLeft - paddingRight; setMeasuredDimension(contentWidth, height); } @Override protected void onDraw(Canvas canvas) { int paddingLeft = getPaddingLeft(); int paddingTop = getPaddingTop(); int paddingRight = getPaddingRight(); int paddingBottom = getPaddingBottom(); int contentWidth = getWidth() - paddingLeft - paddingRight; int contentHeight = getHeight() - paddingTop - paddingBottom; canvas.drawRect(paddingLeft, paddingTop, paddingLeft + contentWidth, paddingTop + contentHeight, new Paint()); } } ``` 在这个示例中,我们在 onMeasure() 方法中处理了左右 padding,以确保 View 在绘制时不会被 padding 所占据。在 onDraw() 方法中,我们使用了 getPaddingLeft() 和 getPaddingRight() 方法来获取左右 padding 的值,然后绘制了一个矩形,确保绘制的内容不会被 padding 所覆盖。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值