一、setTextSize方法的坑
mText.setTextSize(18);18spmText.setTextSize(TypedValue.COMPLEX_UNIT_SP, 18);18spmText.setTextSize(getResources().getDimension(R.dimen.sp_18));(sp2px(18))spmText.setTextSize(TypedValue.COMPLEX_UNIT_PX,getResources().getDimension(R.dimen.sp_18));(sp2px(18))px
∴ 方法1 = 方法3 = 方法4 != 方法2
Tips:
- 代码中的单位基本都是px,在xml中设置的size,在代码中也会转化为px
- 在自定义view中
textSize = typedArray.getDimension(R.styleable.textSizeInput, sp2px(context, 14f))获取到的是px,所以设置大小的时候要用setTextSize(TypedValue.COMPLEX_UNIT_PX, textSize )
public int dp2px(Context context,float dpValue){
final float scale = context.getResources ().getDisplayMetrics ().density;
return (int) (dpValue * scale + 0.5f);
}
public int sp2px(Context context, float spValue) {
final float fontScale = context.getResources().getDisplayMetrics().scaledDensity;
return (int) (spValue * fontScale + 0.5f);
}
二、坐标
1. View的坐标
1. view.left view左边到viewGroup左边的距离
2. view.right view右边到viewGroup左边的距离
3. view.top view上边到viewGroup上边的距离
4. view.bottom view下边到viewGroup上边的距离
5. view.height = view.bottom - view.top
6. view.width = view.right - view.left
7. view.x view左上角到viewGroup左边的距离 未移动的情况下为view.left
8. view.y view左上角到viewGroup上边的距离 未移动的情况下为view.top
9. view.translationX x - left 即水平移动的距离
10. view.translationY y - top 即纵向移动的距离
2. MotionEvent触摸坐标
1. event.x 触摸点相对父控件左边的位置
2. event.y 触摸点相对父控件上边的位置
3. event.rawX 触摸点相对屏幕左边的位置
2. event.rawY 触摸点相对屏幕上边的位置
三、Drawable中的shape
corners(圆角)
gradien(渐变)
padding(间隔)
size(尺寸)
solid(填充)
stroke(描边)

3550

被折叠的 条评论
为什么被折叠?



