Android 多个设备上的布局问题
正如我们所知,通过使用dp中的大小,我们可以为所有类型的设备创建单一布局。我已经用dp创建了一个xml,但它在其他设备上显示不同,如7',10'选项卡,5.4,5.1 3.7等 我已经把文件放在“布局”文件夹中,现在为了支持所有这些设备,我必须为所有设备创建不同的布局文件夹,这很难维护,即使我已经创建了hdpi、xhdpi等,但仍然需要创建大量布局。请查找以下xml:Android 多个设备上的布局问题,android,android-layout,android-layout-weight,Android,Android Layout,Android Layout Weight,正如我们所知,通过使用dp中的大小,我们可以为所有类型的设备创建单一布局。我已经用dp创建了一个xml,但它在其他设备上显示不同,如7',10'选项卡,5.4,5.1 3.7等 我已经把文件放在“布局”文件夹中,现在为了支持所有这些设备,我必须为所有设备创建不同的布局文件夹,这很难维护,即使我已经创建了hdpi、xhdpi等,但仍然需要创建大量布局。请查找以下xml: <RelativeLayout xmlns:android="http://schemas.android.com/apk
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
xmlns:ads="http://schemas.android.com/apk/lib/com.google.ads"
android:id="@+id/ans4"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg_orange"
tools:context="com.kids.kidsmath.MainActivity"
tools:ignore="MergeRootFrame" >
<Button
android:id="@+id/mathCalculation"
android:layout_width="250dp"
android:layout_height="40dp"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:layout_marginTop="104dp"
android:background="@drawable/curve_shape"
android:onClick="openMa"
android:text="Play "
android:textColor="#000000"
android:textSize="20sp"
android:textStyle="bold"
android:typeface="sans" />
<Button
android:id="@+id/learnCounting"
android:layout_width="250dp"
android:layout_height="40dp"
android:layout_alignLeft="@+id/mathCalculation"
android:layout_alignRight="@+id/mathCalculation"
android:layout_below="@+id/mathCalculation"
android:layout_marginTop="46dp"
android:background="@drawable/curve_shape"
android:onClick="openL"
android:text="Lg"
android:textColor="#000000"
android:textSize="20sp"
android:textStyle="bold"
android:typeface="sans" />
<Button
android:id="@+id/greatersmaller"
android:layout_width="250dp"
android:layout_height="40dp"
android:layout_alignLeft="@+id/learnCounting"
android:layout_alignRight="@+id/learnCounting"
android:layout_below="@+id/learnCounting"
android:layout_marginTop="40dp"
android:background="@drawable/curve_shape"
android:onClick="openS"
android:text="Gr"
android:textColor="#000000"
android:textSize="20sp"
android:textStyle="bold"
android:typeface="sans" />
</RelativeLayout>
如果我在这个xml中做错了,请帮助我。我们还需要为所有人定义不同的xml吗?我想有点误解了密度无关像素的真正含义。因此,我将尝试用一种非传统的方式来解释它: 让我们以你的一个按钮为例。您定义了android:layout\u width=“250dp”。因此,无论分辨率如何,您的按钮在每5英寸的设备上都具有相同的宽度。相对于实际可用的宽度,它在7英寸或10英寸的设备上的宽度将不同。 为了让事情更清楚一点,这里是Nexus5、7和10的dp分辨率与px分辨率的比较
Nexus 5 1920x1080px 640x360dp
Nexus 7 1920x1200px 960x600dp
Nexus 10 2560x1600px 1280x800dp
注意:正如您所看到的,N5和N7的分辨率几乎相同,但dp中的高度仍然相差很大。(640dp vs 960dp)
这是因为密度差异(xxhdpi vs xhdpi)
那么,如何优化各种设备的布局呢?正如您所说,所有设备的布局文件夹都很难维护,特别是如果您以后想更改布局中的某些内容。这就是为什么您应该使用维度文件
我会试着用文本大小来解释。
假设我们将textSize定义为18sp
。这在智能手机上相当大。在7英寸的平板电脑上它仍然可以,但在10英寸的平板电脑上它相当小。因此,我们不为所有三个设备创建布局文件,而是定义一个尺寸参考。
首先,您需要在values文件夹中创建一个dimens.xml
,然后定义维度,例如:
<dimen name="my_text_size">18sp</dimen>
为了适应不同设备的文本大小,您创建一个values-sw600dp
(由Nexus 7使用)和一个values-sw720dp
(由Nexus 10使用)文件夹。然后将dimens.xml
复制到这两个文件夹中,并将值更改为例如22sp
(@sw600dp)和26sp
(@720dp).现在,您的布局已针对智能手机和平板电脑进行了优化,无需创建多个布局文件
注意:如果要重新排列视图,只需要多个布局文件
下面的android开发者页面也应该很有帮助:在您的解释之后,许多困惑会被弄清楚。非常感谢。
android:textSize="@dimension/my_text_size"