Android利用dimens.xml进行适配,使用代码生成不同的dimens.xml文件

在利用dimens.xml进行android设备适配的时候,在xml中我们不能直接定义写死的各个dp,px,sp等。应该使用@dimens/*******的方法,根据android设备的dpi和分辨率来获取不同文件夹中的dimens.xml文件。

而各个文件夹的dimes.xml存在比例关系,例如xhdpi中的dimens.xml比hdpi中的dimens.xml的数值大1.5倍。dimens.xml中的数值按照 ldpi,mdpi,hdpi,xhdpi,xxhdpi,依次升级1.5倍。

在dimens.xml中全部使用px来进行适配,这是因为对于相同分辨率有不同尺寸的屏幕,我们根据px来适配,可以直接按照px来缩放UI,而不会出现根据dp来适配出现的问题(不同尺寸的屏幕手机,相同的控件大小)

比如1920*1080分辨率的手机,当手机尺寸为6寸多,那么这手机的ppi为320,程序调用的是xhdpi-values中的dimens.xml,如果直接这样调用,那么会出现问题,我们实际所需的是xxhdpi中的dimens.xml,我们可以这样做:

新建一个文件夹xhdpi-values-1920x1080,将xxhdpi中的dimens.xml复制到这个文件夹,那么适配就完成了,很轻松。但是写不同的dimens.xml会比较累,然后dimens.xml中存在倍数关系,1.5倍,这样我们可以通过程序来自动帮我们完成,

下面就是我写的,根据xhdpi中的dimens.xml来生成其余文件夹中的dimens.xml。

import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileInputStream;

import java.io.FileWriter;

import java.io.InputStream;

import java.io.InputStreamReader;

/**

* @date       2014年5月29日

* @author     谭帅

* @说明         以values-xhdpi中的dimens.xml为标准,

*         更新其余dimens.xml的数据以适配不同分辨率和密度的屏幕手机

*/

public class DimensUtils {

// xhdpi中dimens.xml所在目录

static String srcFilePath = "E:\\kw_WorkSpace\\KuwoPlayerV3_UI_aspect\\res\\values-xhdpi\\dimens.xml";

// 新生成的xxhdpi中dimens.xml所在目录

static String xxhdpiFilePath = "C:\\Users\\Administrator\\Desktop\\new_dimens\\values_xxhdpi_dimens.xml";

// 新生成的hdpi中dimens.xml所在目录

static String hdpiFilePath = "C:\\Users\\Administrator\\Desktop\\new_dimens\\values_hdpi_dimens.xml";

// 新生成的mdpi中dimens.xml所在目录

static String mhdpiFilePath = "C:\\Users\\Administrator\\Desktop\\new_dimens\\values_mdpi_dimens.xml";

// 新生成的ldpi中dimens.xml所在目录

static String lhdpiFilePath = "C:\\Users\\Administrator\\Desktop\\new_dimens\\values_ldpi_dimens.xml";

// 缩放比例(xxhdpi中为乘,其余为除)

static float factor = 1.5f;

public static void main(String[] args) {

File file = new File(srcFilePath);

File xxhFile = new File(xxhdpiFilePath);

File hFile = new File(hdpiFilePath);

File mFile = new File(mhdpiFilePath);

File lFile = new File(lhdpiFilePath);

InputStream inStream;

try {

inStream = new FileInputStream(file);

BufferedReader br = new BufferedReader(new InputStreamReader(

inStream));

String brLine = br.readLine();

FileWriter xxhWriter = new FileWriter(xxhFile);

BufferedWriter xxhBw = new BufferedWriter(xxhWriter);

FileWriter hWriter = new FileWriter(hFile);

BufferedWriter hBw = new BufferedWriter(hWriter);

FileWriter mWriter = new FileWriter(mFile);

BufferedWriter mBw = new BufferedWriter(mWriter);

FileWriter lWriter = new FileWriter(lFile);

BufferedWriter lBw = new BufferedWriter(lWriter);

while (brLine != null) {

if (brLine.endsWith("px</dimen>")) {

int start = brLine.indexOf("\">") + 2;

int end = brLine.indexOf("px<");

String temp = brLine.substring(start, end);

int px = Integer.parseInt(temp);

// 写入xxhdpi中-乘以(1.5)

xxhBw.append(brLine.subSequence(0, start)

+ getNewPxString("xxhdpi", px)

+ brLine.substring(end) + "\n");

// 写入hdpi中-除以(1.5)

hBw.append(brLine.subSequence(0, start)

+ getNewPxString("hdpi", px)

+ brLine.substring(end) + "\n");

// 写入mdpi中-除以(1.5*1.5)

mBw.append(brLine.subSequence(0, start)

+ getNewPxString("mdpi", px)

+ brLine.substring(end) + "\n");

// 写入ldpi中-除以(1.5*1.5)

lBw.append(brLine.subSequence(0, start)

+ getNewPxString("ldpi", px)

+ brLine.substring(end) + "\n");

} else {

xxhBw.append(brLine + "\n");

hBw.append(brLine + "\n");

mBw.append(brLine + "\n");

lBw.append(brLine + "\n");

}

brLine = br.readLine();

}

br.close();

xxhBw.close();

hBw.close();

mBw.close();

lBw.close();

} catch (Exception e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

System.out.println("run over");

}

private static String getNewPxString(String fileSrc, int px) {

float tempFloat = getFactor(fileSrc, px) - (int) getFactor(fileSrc, px);

int newPx;

if (tempFloat >= 0.5) {

newPx = (int) getFactor(fileSrc, px) + 1;

} else {

newPx = (int) getFactor(fileSrc, px);

}

String newPxString = newPx + "";

return newPxString;

}

private static float getFactor(String fileSrc, int px) {

if (fileSrc.equals("xxhdpi")) {

return px * factor;

} else if (fileSrc.equals("hdpi")) {

return px / factor;

} else if (fileSrc.equals("mdpi")) {

return px / (factor * factor);

} else if (fileSrc.equals("ldpi")) {

return px / (factor * factor * factor);

} else {

return 0;

}

}

}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: dimens.xml是一个XML资源文件,用于在Android应用程序中设置尺寸和间距等的数字值。在开发Android应用程序时,我们需要在布局文件或代码中指定宽度、高度、字体大小等具体的数值。然而,这些数值通常需要在不同的屏幕大小和分辨率的设备上适配dimens.xml的作用就在于,我们可以在这个文件中定义一系列的尺寸值,然后在布局文件或代码中引用这些尺寸值,使得我们的应用程序可以适配不同的屏幕大小和分辨率的设备。 一般来说,我们在res/values/文件夹下创建dimens.xml文件,这个文件中定义的尺寸值会被认为是默认值。如果我们需要适配不同的屏幕大小和分辨率的设备,只需要在res/values-swXXXdp/或res/values-wXXXdp/等针对不同屏幕大小和分辨率的文件夹下创建dimens.xml文件,并重新定义一些尺寸值即可,系统会根据当前设备的屏幕大小和分辨率自动选择正确的dimens.xml文件。在布局文件或代码中引用dimens.xml定义的尺寸值,只需要使用@dimen/尺寸名称即可。使用dimens.xml可以大大提高我们的开发效率,避免了手动计算不同屏幕大小和分辨率的数值的麻烦。 ### 回答2: dimens.xmlAndroid项目中的一个资源文件,用于定义尺寸值,如宽度、高度、边距等。在这个文件中,我们可以根据不同的屏幕密度和设备尺寸定义不同的尺寸值,以确保应用在不同设备上的显示效果一致。 在开发过程中,我们经常会遇到需要根据屏幕尺寸或者设备密度调整UI元素大小的情况。使用dimens.xml可以避免在代码中硬编码尺寸值,降低了修改难度和出错几率。实际上,使用dimens.xml可以使得应用的适应性更好,因为不同设备的大小和密度不同使用这种方式来定义尺寸值可以使得应用更好地适应各种尺寸的设备。 在dimens.xml文件中,我们可以定义一个或多个尺寸值,例如: <dimen name="button_width">100dp</dimen> 这是一种常见的定义方式,其中"button_width"是我们定义的一个名字,"100dp"是具体的尺寸值。在代码中使用时,可以通过R.dimen.button_width来引用这个值。通过定义不同的名字和尺寸值,我们可以在应用中使用不同的尺寸值,以适应不同的屏幕尺寸和密度。 总之,dimens.xml是一种非常实用的资源文件,可以帮助我们更好地管理尺寸值,提高应用的适应性和可维护性。 ### 回答3: dimens.xml是一种Android平台上的资源文件,用于存储不同尺寸的尺寸值。它可以帮助开发者轻松地处理不同屏幕分辨率和设备密度大小的问题。在应用程序中,使用dimens.xml可以实现屏幕适配和响应式布局。当应用在不同大小和分辨率的设备上运行时,系统将自动从dimens.xml中检索相应的值。这个文件包含了指定的尺寸值和单位。例如,如果要设置一个TextView的文本大小,在代码中使用dimens.xml定义的值来设置文本大小。在不同地区或语言环境下,dimens.xml也可以用于存储不同文本样式和尺寸值。总之,dimens.xml是确保应用程序在设备屏幕上正确展示的重要资源之一。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值