解决问题:不同手机尺寸只须一张图搞定;
先来张图:这张图是按:720*1280尺寸做的
就拿“登录淘宝”的那块图;尺寸:720*200
现在我们知道(720*1280)手机上效果图是要达到屏幕高度是200;但是在其他手机上比如我们在布局文件的时候(320*480)(高度我们用的很少,先忽略);所以在布局是按比例搭建:如图
高度给了89dp;
怎么来的呢?下面重点来了:
在宽720的手机是200,在320的手机:h
720:320 = 200:h → h=89;
这样得出的是在宽度为320的手机(是在我们搭建布局是的效果);
在其他不同宽度手机上呢,为了解决这个问题,在代码里进行适配;
代码如下:
int height = getPhoneWidth()*200/720; //适配高度
由来:手机宽度可以获得:
再有比例计算: 720:200 = W : h → h = W *200/720 ;
代码如下:
LayoutParams params = new LinearLayout.LayoutParams(W, h);//确定适配的宽高;
ll_login.setLayoutParams(params);//给ll_login控件赋上适配宽高;
所以在不同的宽度的手机都可以这样适配,只要一个图就行;
附上代码示例:给定img的宽高是:144*112)
layout = (RelativeLayout) findViewById(R.id.layout);// 布局
int Width = getPhoneWidth();
int Height = Width * 112 / 144;
LayoutParams lp = new RelativeLayout.LayoutParams(Width, Height);
layout.setLayoutParams(lp);
注:
1.逻辑就是这样理解;
但是LayoutParams这个类有好多种类:
params = new LinearLayout.LayoutParams(W, h);
ll_login.setLayoutParams(params);
这个代码里的LinearLayout 注意下:
ll_login的父控件是LinearLayout 类型;
2.一般情况做适配都是根据手机的宽度来算图片的适配的;
效果图上的图片距离什么,你可以自己微调,也不用刻意去完全去按照的做。