Android布局问题

时间:2011-05-14 20:55:40

标签: android android-layout android-linearlayout relativelayout

我正在尝试创建一个我认为非常简单的Android屏幕布局。我基本上想要一个顶部的标题和一个底部的页脚,以及一个填充剩余屏幕空间的EditText框。标题和EditText框工作正常,但我似乎无法显示我的页脚。这是我的代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent" 
              android:layout_height="match_parent"
              android:orientation="vertical">
    <ImageView android:id="@+id/imageView1" 
               android:src="@drawable/droidiary"
               android:layout_width="wrap_content" 
               android:layout_height="wrap_content"
               android:layout_gravity="center">
    </ImageView>
    <View android:id="@+id/view1" 
          android:layout_height="2dip"
          android:background="#FFAAAAFF" 
          android:layout_width="wrap_content">
    </View>
    <RelativeLayout android:id="@+id/rlLayout1"
                    android:layout_width="fill_parent" 
                    android:layout_height="fill_parent">
        <EditText android:inputType="text|textMultiLine"
                  android:layout_alignParentTop="true" 
                  android:hint="Type about your day..."
                  android:text="" 
                  android:id="@+id/txtEntry" 
                  android:layout_height="match_parent"
                  android:layout_width="match_parent">
        </EditText>
        <LinearLayout android:layout_alignParentBottom="true"
                      android:id="@+id/linearLayout1" 
                      android:layout_width="wrap_content"
                      android:layout_height="wrap_content">
            <View android:id="@+id/view2" 
                  android:layout_height="2dip"
                  android:background="#FFAAAAFF" 
                  android:layout_width="wrap_content">
            </View>
            <TextView android:text="TextView" 
                      android:id="@+id/textView1"
                      android:layout_width="wrap_content" 
                      android:layout_height="wrap_content">
            </TextView>
        </LinearLayout>
    </RelativeLayout>
</LinearLayout>

就像我说的,除了我的页脚,一切都有效。谁能告诉我我做错了什么?

3 个答案:

答案 0 :(得分:2)

似乎有很多额外不需要的布局。这将为您布置三个区域,您可以在其中放置任何内容或只是使它们成为视图控件。每个区域的高度将分别为25%,50%,25%。如果您不想要百分比,请从页眉和页脚中删除权重并设置其宽度值,但保留EditText的权重。

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="match_parent" 
              android:layout_height="match_parent"
              android:orientation="vertical">
   <View android:id="@+id/headerView"
         android:layout_width="match_parent"
         android:layout_height="0dip"
         android:layout_weight="2" />
   <EditText android:id="@+id/editBox"
         android:layout_width="match_parent"
         android:layout_height="0dip"
         android:layout_weight="1" />
   <View android:id="@+id/footerView"
         android:layout_width="match_parent"
         android:layout_height="0dip"
         android:layout_weight="2" />
</LinearLayout>

答案 1 :(得分:2)

您的布局太复杂,无法达到您想要的效果。我建议避免使用RelativeLayout,除非你绝对必须使用它。

以下是如何使用LinearLayout创建标题/内容/页脚布局的简单示例:
(请注意layout_weight元素中的content

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
              android:layout_width="fill_parent" 
              android:layout_height="fill_parent"
              android:orientation="vertical">

        <TextView                   
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:padding="5dp" 
                android:text="Header" />

        <EditText
                android:layout_width="fill_parent"
                android:layout_height="0dp"
                android:layout_weight="1"
                android:singleLine="false" 
                android:hint="Type about your day..."
                android:text="" >
        </EditText>

        <TextView                   
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:padding="5dp" 
                android:text="Footer" />

</LinearLayout>        

enter image description here

答案 2 :(得分:0)

如果我正确理解了您的布局的哪一部分是页眉和页脚,请添加以下行:

android:layout_above="@+id/linearLayout1"

到EditText