Android 4x2小部件

时间:2010-08-05 21:11:14

标签: android android-widget android-layout

看看Facebook小部件,我意识到它是一个4x2单元,这不是标准尺寸之一。我试图重新创建这个大小的小部件(无论是320x200还是294x146 px),但是小部件在所有设备上看起来都不太好。小部件布局为:

<?xml version="1.0" encoding="utf-8"?>
<!--  Portrait -->
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content"
    android:id="@+id/widget"
    android:background="@drawable/widget_bg"
    >

        <TextView android:id="@+id/widget_title"
            android:layout_width="fill_parent" 
            android:layout_height="60dip"
            android:layout_marginTop="1dip"
            android:textSize="20.0sp"
            android:maxLines="3"
            android:textColor="#000"
            android:textStyle="bold" 
            android:gravity="center"
            android:layout_marginLeft="10dip"
            android:layout_marginRight="10dip"
            android:layout_centerHorizontal="true"
            android:layout_alignParentTop="true"
            android:ellipsize="end"
             />

            <ImageView android:id="@+id/widget_thumb"
            android:layout_width="304dip" 
            android:layout_height="90dip"
            android:layout_alignParentLeft="true"
            android:layout_marginLeft="7dip"
            android:src="@drawable/thumb_placeholder_large"
            android:adjustViewBounds="true"
            android:layout_below="@+id/widget_title"
            android:background="#000"
            />

    <!--  previous button -->
    <Button 
        android:id="@+id/widget_previous"
        android:layout_height="wrap_content" 
        android:layout_width="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_marginLeft="5dp"
        android:layout_marginBottom="35dp"
        android:layout_alignParentBottom="true"
        android:background="@drawable/left_button"/>

    <!--  Next Button -->
    <Button
        android:id="@+id/widget_next"
        android:layout_width="wrap_content" 
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_marginRight="5dp"
        android:layout_marginBottom="35dp"
        android:layout_alignParentBottom="true"
        android:background="@drawable/right_button"  />


    <!-- Indicator -->

    <LinearLayout 
        android:id="@+id/widget_progressbar"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentRight="true"
        android:layout_marginBottom="33dp"
        android:layout_marginRight="50dp"
        android:layout_alignParentBottom="true">

        <!--  ProgressBar throws exception when it's set invisible from RemoteViews use a layout wrapper instead -->
        <ProgressBar
            android:layout_width="15dp" 
            android:layout_height="15dp">
        </ProgressBar>
    </LinearLayout>

</RelativeLayout>

在摩托罗拉Droid上,此布局适合,但在其他设备上,ImageView位于下方。任何帮助/建议都表示赞赏。

drawable_bg.png是294x146px。

  • 和Sandeep

2 个答案:

答案 0 :(得分:1)

小部件的实际大小取决于

  • 设备的显示分辨率(像素)
  • 用过的家庭应用程序(它们有不同的通知栏和底栏)
  • Android操作系统版本(不同版本也有不同的家庭应用)

这样可以更好地使您的布局“fill_parent”和您的背景图像成为“9patch”图像。 还可以使用不同的背景图像来获得不同的显示分辨率(dpi),以使背景图像看起来更完美。

答案 1 :(得分:0)

我认为你应该考虑为不同的屏幕尺寸创建更多的布局,并测试它们,这样你就可以确保你的小部件在所有屏幕尺寸上看起来都很好。