1

我创建了一个小部件。我故意用layout_weight

所以它适合任何屏幕尺寸。

小部件始终跨越 1X4。

我现在查看不同的设备,graphic editor我发现重量没有帮助。

我应该换成蘸料尺寸吗?

线性布局相对于背景图像的跨度不同。

在此处输入图像描述

在此处输入图像描述

在此处输入图像描述

我的 XML:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/app_widget_root"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:background="@drawable/widget_bg_main"
    android:clickable="true"
    android:focusable="true"
    android:gravity="center_vertical"
    android:orientation="horizontal"
    android:padding="0dp" >

    <RelativeLayout
        android:id="@+id/layout_status_image"
        android:layout_width="0dp"
        android:layout_height="fill_parent"
        android:layout_gravity="center"
        android:gravity="center"
        android:orientation="horizontal" 
android:layout_weight="0.21"
>

        <ImageView
            android:id="@+id/image_status"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:src="@drawable/widget_icon_no_data"
            android:visibility="invisible" />
        <!--
                              Layout is necessary because the setVisibility of ProgressBar is not working 
                              through remote views in 2.1. So wrapped by this layout 
        -->

        <FrameLayout
            android:id="@+android:id/widget_progress"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:layout_marginLeft="1dp"
            android:layout_marginTop="1dp" >

            <ProgressBar
                style="?android:attr/progressBarStyle"
                android:layout_width="39dp"
                android:layout_height="39dp"
                android:indeterminateOnly="true"
                android:orientation="vertical" />
        </FrameLayout>
    </RelativeLayout> <!-- Status image layout -->


    <!--
                            ========================================================================
                            * Information layout - contains all the texts 
                            ========================================================================
    -->

    <LinearLayout
        android:id="@+id/layout_information"
        android:layout_width="0dp"
        android:layout_height="fill_parent"
        android:gravity="center"
        android:orientation="vertical" 
        android:paddingLeft="20dp"
        android:layout_weight="0.56"
        >

        <TextView
            android:id="@+id/text_view_destination"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="\@ Home in"
            android:textColor="@color/solid_white"
            android:textSize="19sp"
            android:textStyle="bold" 
            android:layout_gravity="left" 

            />

        <TextView
            android:id="@+id/text_view_time"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="5dp"
            android:textColor="@color/solid_white"
            android:textSize="25sp"
            android:textStyle="normal" 
            android:layout_gravity="left"
            />
    </LinearLayout> <!-- Information layout -->
    <!--
                            ========================================================================
                            * Action layout - action buttons container
                            ========================================================================
    -->

    <LinearLayout
        android:id="@+id/layout_action"
        android:layout_width="0dp"
        android:layout_height="fill_parent"
        android:layout_gravity="center"
        android:gravity="center"
        android:orientation="vertical" 
        android:layout_weight="0.23"
        >

        <ImageView
            android:id="@+id/image_action"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:src="@drawable/widget_bt_drive_disabled" />

        <TextView
            android:id="@+id/text_view_action"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginTop="2dp"
            android:text="Drive!"
            android:textColor="@color/disabled_white"
            android:textSize="15sp"
            android:textStyle="bold" 
            android:layout_gravity="center"
            />
    </LinearLayout> <!-- Action layout -->

4

1 回答 1

0

很明显,因为单一布局在普通屏幕尺寸的设备上完美运行并不意味着它在大/超大尺寸的屏幕上也能以同样的方式工作。因此,在 res“layout-large”或“layout-xlarge”中创建一个文件夹(取决于设备屏幕大小)。将相同的布局复制到新创建的文件夹中,然后对其进行一些更改,以便根据您的要求适合大/超大屏幕。您也可以将图像复制到 ldpi、mdpi、hdpi 和 xhdpi 以支持多种密度。

欲了解更多信息:http: //developer.android.com/guide/practices/screens_support.html

希望这可以帮助。

于 2013-07-29T11:57:55.537 回答