最近开始研究安卓适配,发现有两种方案,一种是对每种适配像素写个文件夹对应比如:values_800*480等,另一种是用LinearLayout的weight去计算,再重写Layout,重写onAttachedToWIndow()函数,在这个函数里计算子view的高度,宽度,margin等。第二种方法是比较合理的,可以减少以后的修改量。
但在计算height的过程中,需要去掉状态栏高度,但状态栏高度又不能写在OnCreate()函数里,虽然可以写在onWindowFocusChanged()函数里,但也不太适合自己的,在网上找了个反射代码,在这里谢过:
public static int getStatusBarHeight(Context context){
Class<?> c = null;
Object obj = null;
Field field = null;
int x = 0, statusBarHeight = 0;
try {
c = Class.forName("com.android.internal.R$dimen");
obj = c.newInstance();
field = c.getField("status_bar_height");
x = Integer.parseInt(field.get(obj).toString());
statusBarHeight = context.getResources().getDimensionPixelSize(x);
} catch (Exception e1) {
e1.printStackTrace();
}
return statusBarHeight;
}
除此之外,还碰到华为机的虚拟键打开和隐藏时高度必须重新计算的问题,因为虚拟键打开或者隐藏后会涉及到Layout的重绘制,所以可以重写根Layout,因为我的根Layout是FrameLayout,所以重写FrameLayout,代码如下:
package com.cn21.xuanping.clock.adaption;
import com.cn21.xuanping.R;
import com.cn21.xuanping.clock.Util;
import com.cn21.xuanping.clock.activity.TimeActivity;
import android.R.integer;
import android.content.Context;
import android.util.AttributeSet;
import android.widget.FrameLayout;
public class ClockFrameLayoutContainer extends FrameLayout {
private ClockScrollView clockScrollView;
/**
* 构造方法
* @param context
* @param attrs
*/
public ClockFrameLayoutContainer(Context context, AttributeSet attrs) {
super(context, attrs);
}
@Override
protected void onAttachedToWindow() {
}
@Override
protected void onLayout(boolean changed, int left, int top, int right,
int bottom) {
super.onLayout(changed, left, top, right, bottom);
int tempWindowHeight = Util.windowManager.getDefaultDisplay().getHeight() - Util.getStatusBarHeight(getContext());
if(tempWindowHeight != Util.windowHeight) {
Util.windowHeight = tempWindowHeight;
Util.windowWidth = Util.windowManager.getDefaultDisplay().getWidth();
}
}
}
接下来要再回去看看view的layout触发条件了。