app外观在不同设备中的变化

时间:2013-01-14 09:11:53

标签: android android-xml

我创建了一个应用,当我将它交给不同设备的不同朋友时,他们就会遇到错误。例如,其中一个是我的设备(三星galaxy S2)它看起来像这样:

enter image description here

在另一部手机(在这种情况下是三星Galaxy S3)中就像这样:

enter image description here

这是我使用的xml代码:

    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:background="@android:color/black"
        android:orientation="vertical" >


        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="50dp" 
            android:orientation="horizontal">


            <ImageView
                android:id="@+id/imageView1"
                android:layout_width="70dp"
                android:layout_height="match_parent"
                android:paddingTop="4dp"
                android:paddingBottom="4dp"
                android:paddingLeft="10dp"
                android:paddingRight="10dp"
                android:src="@drawable/logo_nuevo_ver2" >
    </ImageView>

            <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="match_parent"
                android:background="@drawable/rect_rojo">


                <ImageView
                    android:id="@+id/imageView2"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:src="@drawable/shopping_cart"
                    android:paddingLeft="25dp"
                    android:paddingRight="10dp" />






                <TextView
                    android:id="@+id/txtShopingCart"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:text="My shopping cart"
                    android:paddingLeft="20dp"
                    android:paddingRight="15dp"
                    android:paddingTop="15dp"
                    android:textColor="@android:color/white" >
                    </TextView>

                 <LinearLayout
                android:layout_width="fill_parent"
                android:layout_height="match_parent"
                android:layout_margin="10dp"
                android:background="@drawable/recuadro_blanco">

                    <TextView
                    android:id="@+id/txtShopingCart"
                    android:layout_width="wrap_content"
                    android:layout_height="match_parent"
                    android:text="0"
                    android:paddingLeft="13dp"
                    android:gravity="center"
                    android:textColor="@android:color/white" >
                    </TextView>
            </LinearLayout>


            </LinearLayout>

        </LinearLayout>


        <ImageView
            android:id="@+id/imageView3"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:src="@drawable/linea_gris"
            android:scaleType="fitXY"></ImageView>


        <LinearLayout
            android:id="@+id/llPhoto"
            android:layout_width="match_parent"
            android:layout_height="340dp"
            android:layout_margin="15dp"
            android:background="@android:color/white"
            android:orientation="vertical">

            <ImageView
                android:id="@+id/camara"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginBottom="20dp"
                android:layout_marginTop="100dp"
                android:src="@drawable/camara" />




             <TextView
                 android:id="@+id/txtShopingCart"
                 android:layout_width="match_parent"
                 android:layout_height="match_parent"
                 android:layout_marginLeft="40dp"
                 android:text="Click in the image to take a photo" >

                    </TextView>

        </LinearLayout>

        <ImageView
            android:id="@+id/imageLinea"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:src="@drawable/linea_gris"
            android:scaleType="fitXY"></ImageView>

         <LinearLayout
             android:id="@+id/llTab"
             android:layout_width="match_parent"
             android:layout_height="match_parent"
             android:weightSum="90">






             <LinearLayout
                 android:id="@+id/llTab1"
                 android:layout_width="wrap_content"
                 android:layout_height="match_parent"
                 android:orientation="vertical" >

             <ImageView
                 android:id="@+id/imageMonkey"
                 android:paddingTop="5dp"
                 android:layout_width="match_parent"
                 android:layout_height="40dp"
                 android:src="@drawable/do_the_monkey" >
            </ImageView>



             <TextView
                 android:id="@+id/txtMonkey"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
                 android:text="  Do the Monkey  " >

    </TextView>
    </LinearLayout>
            <ImageView
                         android:id="@+id/imageLineaVertical"
                         android:layout_width="2dp"
                         android:layout_height="match_parent"
                         android:src="@drawable/linea_gris_vertical" >
            </ImageView>




           <LinearLayout
               android:id="@+id/llTab2"
               android:layout_width="wrap_content"
               android:layout_height="match_parent"
               android:layout_weight="39.79"
               android:orientation="vertical" >

             <ImageView
                 android:id="@+id/imageCart"
                 android:layout_width="match_parent"
                 android:paddingTop="5dp"
                 android:layout_height="40dp"
                 android:src="@drawable/add_to_cart" >
    </ImageView>



             <TextView
                 android:id="@+id/txtCart"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
                 android:text="    Add to cart" >

    </TextView>
    </LinearLayout>

           <ImageView
                         android:id="@+id/imageLineaVertical"
                         android:layout_width="2dp"
                         android:layout_height="match_parent"
                         android:src="@drawable/linea_gris_vertical" >
            </ImageView>


    <LinearLayout
        android:id="@+id/llTab3"
        android:paddingLeft="15dp"
        android:layout_width="wrap_content"
        android:layout_height="match_parent"
        android:layout_weight="40.42"
        android:orientation="vertical" >

             <ImageView
                 android:id="@+id/imageShare"
                 android:layout_width="match_parent"
                 android:paddingTop="5dp"
                 android:layout_height="40dp"
                 android:src="@drawable/share" >
    </ImageView>



             <TextView
                 android:id="@+id/txtShare"
                 android:layout_width="match_parent"
                 android:layout_height="wrap_content"
                 android:text="    Share" >

    </TextView>
    </LinearLayout>
         </LinearLayout>

    </LinearLayout>

如何让它在所有设备中看起来都一样?

2 个答案:

答案 0 :(得分:2)

我会将你的3个底部按钮贴在屏幕的底部,然后让任何白色空间向下扩展以占据剩下的空间。在设计android界面时尽量不要处理绝对值。

我会看看这一点,肯定会有所帮助:http://developer.android.com/guide/practices/screens_support.html

答案 1 :(得分:1)

一步是删除llPhoto的绝对高度定义,而是依赖于相对自动定位。如果您需要将一个项目具有特定高度,请将其嵌入另一个自动居中的布局中或提供滚动(如果设备没有提供足够的空间来显示该项目)。