【问题标题】:Android: Center a scrollview between header and footerAndroid:在页眉和页脚之间居中滚动视图
【发布时间】:2016-07-01 01:45:27
【问题描述】:

我正在尝试将 ScrollView 置于页眉和页脚之间。具体来说,我有一个必须位于顶部的 ImageView、一个位于底部的 RelativeView 和一个位于两者之间的 ScrollView。当 ScrollView 的内容不大于页脚和页眉之间的空间时,我希望它垂直居中,如下图所示。我当前的尝试将滚动视图放在正确的位置,但当内容小于可用空间时,它不会正确垂直居中。

Layout Pic

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:acg="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent">

<ImageView
    android:id="@+id/preloginLogo"
    android:layout_width="350dp"
    android:layout_height="130dp"
    android:src="@drawable/logo"
    android:layout_centerHorizontal="true"
    android:layout_alignParentTop="true"/>

<ScrollView
    android:layout_width="@dimen/prelogin_main_content_width"
    android:layout_height="wrap_content"
    android:layout_centerHorizontal="true"
    android:layout_below="@+id/preloginLogo"
    android:layout_above="@+id/preloginTertiaryLinks">

    <RelativeLayout
        android:id="@+id/mainContent"
        android:layout_width="match_parent"
        android:layout_height="wrap_content">           

    </RelativeLayout>
</ScrollView>

<RelativeLayout
    android:id="@+id/preloginTertiaryLinks"
    android:layout_width="match_parent"
    android:layout_height="96dp"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true"
    android:paddingTop="5dp">

    <View
        android:layout_width="match_parent"
        android:layout_height="1dip"
        android:background="@color/lt_gray"
        android:layout_centerVertical="true"
        android:layout_alignParentTop="true"/>

    <LinearLayout
        android:orientation="horizontal"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true">

        <Button
            android:id="@+id/prelogin_guestButton"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="Footer"/>
    </LinearLayout>
</RelativeLayout>

【问题讨论】:

    标签: android layout scrollview android-relativelayout


    【解决方案1】:

    您可以在顶部和底部为 ScrollView 提供填充。

    <ScrollView
        android:layout_width="@dimen/prelogin_main_content_width"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_below="@+id/preloginLogo"
        android:layout_paddingTop="12dp"
        android:layout_paddingBottom="12dp"
        android:layout_above="@+id/preloginTertiaryLinks">
    
        <RelativeLayout
            android:id="@+id/mainContent"
            android:layout_width="match_parent"
            android:layout_height="wrap_content">           
        </RelativeLayout>
    </ScrollView>
    

    【讨论】:

    • 太棒了,谢谢,这正是我要找的!
    【解决方案2】:

    这个怎么样:

    1:输上面和下面

    2:设置页边距,以免覆盖页眉和页脚。

     <ScrollView
            android:layout_width="match_parent"
            android:layout_marginTop="130dp"
            android:layout_marginBottom="96dp"
            android:background="@color/red_danger"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true" 
            >
    
        <RelativeLayout
                android:id="@+id/mainContent"
                android:layout_width="match_parent"
                android:layout_height="100dp">
    
        </RelativeLayout>
    </ScrollView>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2011-10-18
      • 1970-01-01
      • 1970-01-01
      • 2011-01-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多