首先说明一点 :这个方法不能说万能的,但是最起码它解决了分辨率跟密集度的关系,就是所有分辨率,只要传了第一次的参数,后面都不需要改动了,但是也引来一个问题,就是布局会因为图片资源小而失真,所以这也需要美工的同志多多配合的,废话不说,贴代码:
第一步,先创建一个view信息的javabean类:
package
com.zte.layout.adapter;
import
android.view.View;
/**
* 存储View信息的JavaBean类
*
*
@author
*
*/
public
class
LayoutInformation
{
/**
* View的对象
*/
private
View view;
/**
* View的宽度
*/
private
double
viewWidth;
/**
* View的高度
*/
private
double
viewHeight;
/**
* View距左边的距离,即marginLeft
*/
private
double
viewMarginLeft;
/**
* View距顶部的距离,即MarginTop;
*/
private
double
viewMarginTop;
/**
* 父类布局的类型为相对布局
*/
public
static
int
R=-1
;
/**
* 父类布局的类型为线性布局
*/
public
static
int
L=-2
;
/**
* 此View的父类布局的类型
*/
private
int
parentLayoutType;
/**
* 存储View信息的JavaBean类
*
*
@param
view
* View的对象
*
@param
viewWidth
* View的宽
*
@param
viewHeight
* View的高
*
@param
viewMarginLeft
* View距左边的距离
*
@param
viewMargdoubleop
* View距上部的距离
*
@param
parentLayoutType
* 父类布局的类型,LayoutInformation.R
* (表示相对布局)或者LayoutInformation.L(表示线性布局)
*/
public
LayoutInformation(View view,
double
viewWidth,
double
viewHeight,
double
viewMarginLeft,
double
viewMarginTop,
int
parentLayoutType)
{
this
.view =
view;
this
.viewWidth =
viewWidth;
this
.viewHeight =
viewHeight;
this
.viewMarginLeft =
viewMarginLeft;
this
.viewMarginTop =
viewMarginTop;
this
.parentLayoutType=
parentLayoutType;
}
/**
* 获取View的对象
*
*
@return
View对象
*/
public
View getView()
{
return
view;
}
/**
* 设置View的对象
*/
public
void
setView(View view)
{
this
.view =
view;
}
/**
* 获取View的宽度
*
*
@return
View的宽度,double型
*/
public
double
getViewWidth()
{
return
viewWidth;
}
/**
* 设置View的宽度,double型
*
*
@param
viewWidth
*/
public
void
setViewWidth(
double
viewWidth)
{
this
.viewWidth =
viewWidth;
}
/**
* 获取View的高度
*
*
@return
View的高度,double型
*/
public
double
getViewHeight()
{
return
viewHeight;
}
/**
* 设置View的高度,double型
*
*
@param
viewHeight
*/
public
void
setViewHeight(
double
viewHeight)
{
this
.viewHeight =
viewHeight;
}
/**
* 获取View距离左边的距离
*
*
@return
View距离左边的距离,double型
*/
public
double
getViewMarginLeft()
{
return
viewMarginLeft;
}
/**
* 设置View距离左边的距离,double型
*
*
@param
viewMarginLeft
*/
public
void
setViewMarginLeft(
double
viewMarginLeft)
{
this
.viewMarginLeft =
viewMarginLeft;
}
/**
* 获取View距离上部的距离
*
*
@return
View距离上部的距离,double型
*/
public
double
getViewMarginTop()
{
return
viewMarginTop;
}
/**
* 设置View距离上部的距离,double型
*
*
@param
viewMargdoubleop
*/
public
void
setViewMarginTop(
double
viewMarginTop)
{
this
.viewMarginTop =
viewMarginTop;
}
/**
* 获取父类布局的类型
*
@return
parentLayoutType,int型
*/
public
int
getParentLayoutType()
{
return
parentLayoutType;
}
/**
* 设置父类布局的类型
*
@param
parentLayoutType
*/
public
void
setParentLayoutType(
int
parentLayoutType)
{
this
.parentLayoutType =
parentLayoutType;
}
}
第二步:创建一个计算方法:
import
java.util.List;
import
android.app.Activity;
import
android.content.Context;
import
android.util.DisplayMetrics;
import
android.view.View;
import
android.view.ViewGroup.LayoutParams;
import
android.widget.LinearLayout;
import
android.widget.RelativeLayout;
/**
* 分配率通配类
*
*
@author
*
*/
public
class
MyLayoutAdapter
{
/**
* 基准分辨率的宽
*/
public
double
STANDARD_SCREEN_WIDTH;
/**
* 基准分辨率的高
*/
public
double
STANDARD_SCREEN_HEIGHT;
/**
* 系统当前的分辨率的宽
*/
public
double
CURRENT_SCREEN_WIDTH;
/**
* 系统当前的分辨率的高
*/
public
double
CURRENT_SCREEN_HEIGHT;
/**
* 基准屏幕密度
*/
public
static
final
double
STANDARD_DENSITY = 160
;
/**
* 当前屏幕密度
*/
private
double
CURRENT_DENSITY;
/**
* 屏幕密度比例
*/
private
double
DENSITY_RATIO;
/**
* 屏幕宽度比例
*/
private
double
WIDTH_RATIO;
/**
* 屏幕高度比例
*/
private
double
HEIGHT_RATIO;
/**
* 组件基准的宽度
*/
private
double
viewStandardWidth;
/**
* 组件基准的高度
*/
private
double
viewStandardHeight;
/**
* 组件基准的距离左边的距离
*/
private
double
viewStandardMarginLeft;
/**
* 组件基准的距离顶部的距离
*/
private
double
viewStandardMarginTop;
/**
* 组件当前的宽
*/
private
double
viewCurrentWidth;
/**
* 组件当前的高
*/
private
double
viewCurrentHeight;
/**
* 组件当前距离左边的距离
*/
private
double
viewCurrentMarginLeft;
/**
* 组件当前距离顶部的距离
*/
private
double
viewCurrentMarginTop;
/**
* UI组件的对象
*/
private
View view;
/**
* 此View的父类布局的类型
*/
private
int
parentLayoutType;
/**
* 父类布局的类型为相对布局
*/
private
final
int
LAYOUT_TYPE_RELATiVELAYOUT =
LayoutInformation.R;
/**
* 父类布局的类型为线性布局
*/
private
final
int
LAYOUT_TYPE_LINEARLAYOUT =
LayoutInformation.L;
/**
* 布局属性为wrap_content
*/
private
final
int
LAYOUTPARAMS_WARP_CONTENT =
LayoutParams.WRAP_CONTENT;
/**
* 布局属性为fill_parent
*/
private
final
int
LAYOUTPARAMS_FILL_PARENT =
LayoutParams.FILL_PARENT;
private
Context context;
/**
* 类对象实例化时,设置 基准屏幕宽度,高度
*
*
@param
context
* Context
*
@param
standardWidth
* 基准屏幕的宽
*
@param
standardHeight
* 基准屏幕的高
*/
public
MyLayoutAdapter(Context context,
double
standardWidth,
double
standardHeight)
{
this
.context =
context;
getScreenSize();
STANDARD_SCREEN_HEIGHT
=
standardHeight;
STANDARD_SCREEN_WIDTH
=
standardWidth;
//
计算宽高比率
WIDTH_RATIO = CURRENT_SCREEN_WIDTH /
STANDARD_SCREEN_WIDTH;
HEIGHT_RATIO
= CURRENT_SCREEN_HEIGHT /
STANDARD_SCREEN_HEIGHT;
}
/**
* 获取当前屏幕大小和密度
*/
private
void
getScreenSize()
{
DisplayMetrics displayMetrics
=
new
DisplayMetrics();
((Activity) context).getWindowManager().getDefaultDisplay()
.getMetrics(displayMetrics);
CURRENT_SCREEN_WIDTH
=
displayMetrics.widthPixels;
CURRENT_SCREEN_HEIGHT
=
displayMetrics.heightPixels;
CURRENT_DENSITY
=
displayMetrics.densityDpi;
DENSITY_RATIO
= STANDARD_DENSITY /
CURRENT_DENSITY;
}
/**
* 进行通配
*
*
@param
listdata
*/
public
void
setViewLayout(List<LayoutInformation>
listdata)
{
for
(
int
i = 0; i < listdata.size(); i++
)
{
view
=
listdata.get(i).getView();
viewStandardWidth
=
listdata.get(i).getViewWidth();
viewStandardHeight
=
listdata.get(i).getViewHeight();
viewStandardMarginLeft
=
listdata.get(i).getViewMarginLeft();
viewStandardMarginTop
=
listdata.get(i).getViewMarginTop();
setLayoutParams();
viewCurrentMarginLeft
= viewStandardMarginLeft *
WIDTH_RATIO;
viewCurrentMarginTop
= viewStandardMarginTop *
HEIGHT_RATIO;
parentLayoutType
=
listdata.get(i).getParentLayoutType();
setLayoutByParentLayoutType();
}
}
/**
* 判断布局属性的值,设置布局的属性
*/
private
void
setLayoutParams()
{
//
如果基准的宽是wrap_content或者fill_parent则使用原值,否则进行计算得到通配后的值
if
(viewStandardWidth ==
LAYOUTPARAMS_WARP_CONTENT
|| viewStandardWidth ==
LAYOUTPARAMS_FILL_PARENT)
{
viewCurrentWidth
=
viewStandardWidth;
}
else
{
viewCurrentWidth
= viewStandardWidth *
WIDTH_RATIO;
}
//
如果基准的宽是wrap_content或者fill_parent则使用原值,否则进行计算得到通配后的值
if
(viewStandardHeight ==
LAYOUTPARAMS_WARP_CONTENT
|| viewStandardHeight ==
LAYOUTPARAMS_FILL_PARENT)
{
viewCurrentHeight
=
viewStandardHeight;
}
else
{
viewCurrentHeight
= viewStandardHeight *
HEIGHT_RATIO;
}
}
/**
* 通过判断此View父类的布局类型,给此View设置布局
*/
private
void
setLayoutByParentLayoutType()
{
if
(parentLayoutType ==
LAYOUT_TYPE_RELATiVELAYOUT)
{
RelativeLayout.LayoutParams params
=
new
RelativeLayout.LayoutParams(
(
int
) viewCurrentWidth, (
int
) viewCurrentHeight);
params.setMargins((
int
) viewCurrentMarginLeft,
(
int
) viewCurrentMarginTop, 0, 0
);
view.setLayoutParams(params);
}
else
if
(parentLayoutType ==
LAYOUT_TYPE_LINEARLAYOUT)
{
LinearLayout.LayoutParams params
=
new
LinearLayout.LayoutParams(
(
int
) viewCurrentWidth, (
int
) viewCurrentHeight);
params.setMargins((
int
) viewCurrentMarginLeft,
(
int
) viewCurrentMarginTop, 0, 0
);
view.setLayoutParams(params);
}
}
/**
* 设置字体大小
*
*
@param
standardSize
* 原始大小
*
@return
int
*/
public
int
setTextSize(
int
standardSize)
{
int
currentSize;
currentSize
= (
int
) (standardSize * WIDTH_RATIO *
DENSITY_RATIO);
return
currentSize;
}
}
第三步,写一个接口:
public
interface
InitAllView{
/**
* 初始化控件的大小
*/
public
void
initAllView();
}
第四步:代码控制:
/**
* 通配方法
*/
private
void
initWildcard() {
myLayout
=
new
MyLayoutAdapter(
this
, 320, 480
);
listInfo
=
new
ArrayList<LayoutInformation>
();
listInfo.add(
new
LayoutInformation(mBtn1, LayoutParams.WRAP_CONTENT,
LayoutParams.WRAP_CONTENT,
0, 0
, LayoutInformation.R));
listInfo.add(
new
LayoutInformation(mNowRegisterBtn, 80, 27.3, 14.7, 0
,
LayoutInformation.R));
listInfo.add(
new
LayoutInformation(mNextRegisterBtn, 80, 27.3, 14.7, 0
,
LayoutInformation.R));
//
listInfo.add(new LayoutInformation(mCheckBtn, 17.3,17.3, 14.7, 0,
//
LayoutInformation.L));
mBtn1.setTextSize(myLayout.setTextSize(12
));
mNowRegisterBtn.setTextSize(myLayout.setTextSize(
12
));
mNextRegisterBtn.setTextSize(myLayout.setTextSize(
12
));
myLayout.setViewLayout(listInfo);
}
效果对比如下:
小的图片是通过适应过的,大的图片是没有做适配的。可以看得出来他们的差异很明显。如果各位大婶有什么新的方法,希望多多推荐
效果对比

