2011-10-24 69 views
0

我有一个linearLayout,它被一个scrollView包围,以便使它可以滚动到较小的屏幕。在线性布局中,我有3个孩子,也是线性布局。不同屏幕尺寸的线性布局

这工作正常。但我也想支持更大的屏幕。目前,我在屏幕底部留下了更大的屏幕空间。我想让按钮(导航栏)始终位于底部。对于较大的屏幕(高度),我想在屏幕顶部添加一个空白视图,填充更大屏幕提供的空间。

我该如何做到这一点?我尝试了很多重量属性,但没有得到它的工作。

这里的布局:

<?xml version="1.0" encoding="utf-8"?> 
<ScrollView 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    android:background="#8db9f6" 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"> 
    <LinearLayout 
     xmlns:android="http://schemas.android.com/apk/res/android" 
     android:orientation="vertical" 
     android:layout_width="fill_parent" 
     android:layout_height="fill_parent" 
     android:background="#8db9f6"> 
     <LinearLayout 
      xmlns:android="http://schemas.android.com/apk/res/android" 
      android:orientation="horizontal" 
      android:layout_marginTop="8dp" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content"> 
      <TextView 
       android:text="test" 
       android:id="@+id/test" 
       android:paddingLeft="10dp" 
       android:textStyle="bold" 
       android:textSize="20dp" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content"> 
      </TextView> 
      <View 
       android:layout_width="wrap_content" 
       android:layout_height="0dip" 
       android:layout_weight="1"/> 
      <ImageButton 
       android:id="@+id/btnName" 
       android:scaleType="center" 
       android:layout_width="60dp" 
       android:layout_height="48dp" 
       android:src="@android:drawable/ic_menu_edit"> 
      </ImageButton> 
     </LinearLayout> 
     <EditText 
      android:id="@+id/edittest" 
      android:editable="false" 
      android:hint="@string/test" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content"> 
     </EditText> 
     <TextView 
      android:text="@string/optionalText" 
      android:id="@+id/test1" 
      android:paddingLeft="10dp" 
      android:textSize="12dp" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content"> 
     </TextView> 
     <TextView 
      android:id="@+id/space" 
      android:layout_width="fill_parent" 
      android:layout_marginTop="4dp" 
      android:layout_height="3sp" 
      android:background="#333142"> 
     </TextView> 
     <LinearLayout 
      xmlns:android="http://schemas.android.com/apk/res/android" 
      android:orientation="horizontal" 
      android:layout_marginTop="5dp" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content"> 
      <TextView 
       android:text="TEST TESt" 
       android:id="@+id/test2" 
       android:paddingLeft="10dp" 
       android:layout_marginTop="5dp" 
       android:textStyle="bold" 
       android:textSize="20dp" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content"> 
      </TextView> 
      <View 
       android:layout_width="wrap_content" 
       android:layout_height="0dip" 
       android:layout_weight="1"/> 
      <ProgressBar 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:visibility="gone" 
       android:id="@+id/progressbar"/> 
      <ImageButton 
       android:id="@+id/btnPicture" 
       android:scaleType="center" 
       android:layout_width="60dp" 
       android:layout_height="48dp" 
       android:src="@android:drawable/ic_menu_edit"> 
      </ImageButton> 
     </LinearLayout> 
     <FrameLayout 
      xmlns:android="http://schemas.android.com/apk/res/android" 
      android:orientation="horizontal" 
      android:background="#ffffff" 
      android:layout_gravity="center" 
      android:layout_width="fill_parent" 
      android:layout_height="150dip"> 
      <ImageView 
       android:id="@+id/test3" 
       android:layout_width="400dip" 
       android:layout_height="150dip" 
       android:layout_gravity="center" 
       android:scaleType="fitCenter" 
       android:src="@drawable/test1"/> 
      <TextView 
       android:id="@+id/text" 
       android:layout_gravity="bottom" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content" 
       android:textSize="8dp" 
       android:text="test test"/> 
     </FrameLayout> 
     <LinearLayout 
      xmlns:android="http://schemas.android.com/apk/res/android" 
      android:orientation="horizontal" 
      android:layout_gravity="bottom" 
      android:layout_marginTop="3dp" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content"> 
      <Button 
       android:id="@+id/scaleMinus" 
       android:textSize="14dp" 
       android:layout_weight="1" 
       android:layout_gravity="bottom" 
       android:layout_width="fill_parent" 
       android:layout_height="40dp" 
       android:text="@string/zoomOut"/> 
      <Button 
       android:id="@+id/scalePlus" 
       android:textSize="14dp" 
       android:layout_weight="1" 
       android:layout_gravity="bottom" 
       android:layout_width="fill_parent" 
       android:layout_height="40dp" 
       android:text="@string/zoomIn"/> 
     </LinearLayout> 
     <TextView 
      android:id="@+id/balken" 
      android:layout_width="fill_parent" 
      android:layout_marginTop="4dp" 
      android:layout_height="3sp" 
      android:background="#333142"> 
     </TextView> 
     <LinearLayout 
      xmlns:android="http://schemas.android.com/apk/res/android" 
      android:orientation="horizontal" 
      android:layout_marginTop="5dp" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content"> 
      <TextView 
       android:text="test test" 
       android:id="@+id/test3" 
       android:paddingLeft="10dp" 
       android:textStyle="bold" 
       android:textSize="20dp" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content"> 
      </TextView> 
      <View 
       android:layout_width="wrap_content" 
       android:layout_height="0dip" 
       android:layout_weight="1"/> 
      <EditText 
       android:id="@+id/test4" 
       android:editable="false" 
       android:layout_width="100dp" 
       android:layout_height="wrap_content"> 
      </EditText> 
      <TextView 
       android:text="test" 
       android:id="@+id/mtest4" 
       android:paddingLeft="10dp" 
       android:textStyle="bold" 
       android:textSize="20dp" 
       android:layout_width="wrap_content" 
       android:layout_height="wrap_content"> 
      </TextView> 
      <View 
       android:layout_width="wrap_content" 
       android:layout_height="0dip" 
       android:layout_weight="1"/> 
      <ImageButton 
       android:id="@+id/test5" 
       android:scaleType="center" 
       android:layout_width="60dp" 
       android:layout_height="48dp" 
       android:src="@android:drawable/ic_menu_edit"> 
      </ImageButton> 
     </LinearLayout> 
     <TextView 
      android:id="@+id/balken" 
      android:layout_width="fill_parent" 
      android:layout_marginTop="4dp" 
      android:layout_height="3sp" 
      android:background="#333142"> 
     </TextView> 
     <LinearLayout 
      xmlns:android="http://schemas.android.com/apk/res/android" 
      android:orientation="horizontal" 
      android:layout_gravity="bottom" 
      android:background="#000000" 
      android:paddingTop="5dp" 
      android:layout_width="fill_parent" 
      android:layout_height="wrap_content"> 
      <Button 
       android:id="@+id/save" 
       android:textSize="18dp" 
       android:layout_weight="1" 
       android:layout_gravity="bottom" 
       android:layout_width="fill_parent" 
       android:layout_height="60dp" 
       android:text="@string/save"/> 
      <Button 
       android:id="@+id/cancel" 
       android:textSize="18dp" 
       android:layout_weight="1" 
       android:layout_gravity="bottom" 
       android:layout_width="fill_parent" 
       android:layout_height="60dp" 
       android:text="@string/abort"/> 
     </LinearLayout> 
    </LinearLayout> 
</ScrollView> 
+0

您是否尝试过在布局中使用fill_parent ?.你可以发布layout.xml来看看它的样子,这样我们可以帮助你更好吗? –

+0

是的,我已经设置了fill_parent。我将发布布局。 – tobias

回答

2

将整个布局包裹在相对布局中。使用相对布局作为根元素,并将包含按钮的线性布局设置为layout_alignParentBottom =“true”,并将ScrollView设置为layout_alignParentTop =“true”。

包含按钮和ScrollView的LinearLayout应该是RelativeLayout的直接子节点。

<RelativeLayout 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent"> 
     <LinearLayout <-- containing the layout minus the buttons 
       android:id="@+id/SV" 
       android:layout_width="fill_parent" 
       android:layout_height="wrap_content" 
       android:layout_alignParentTop="true"> 
      <The Rest Of The Layout> 
     </LinearLayout> 
     <LinearLayout 
       android:id="@+id/LLButtons" 
       android:layout_width="fill_parent" 
       android:layout_height="wrap_content" 
       android:layout_alignParentBottom="true"> 
      <Buttons> 
      </LinearLayout> 
</ScrollView> 

如果你想要按钮始终在屏幕的底部alignParentBottom。如果你想让按钮始终处于滚动视图的底部alignBelow =“@ id/SV”

+0

Thx。但那里有ScrollView的开始? – tobias

+0

ok thx,这很好。但现在空间在按钮之上。我想要它在屏幕的顶部。 – tobias

+0

你希望布局锚定在屏幕的底部和顶部的任何空白空间?没问题。 Buttons = alignParentBottom = true&LL与其余布局将alignAbove =“@ id/LLButtons” – Phobos

0

android:layout_height="wrap_content"在你内心的LinearLayout是你的麻烦在这里,将其改为 'FILL_PARENT' 应该帮助。通常,您可能想使用hierarchyviewer来帮助解决这样的布局问题。

+0

我有3个内部线性布局。我应该使用它们的所有fill_parent作为身高吗? – tobias