【问题标题】:Android: fixed header in topAndroid:顶部的固定标题
【发布时间】:2014-12-19 14:31:51
【问题描述】:

想在页面上有一个固定的标题,但我做不到。

我正在这样做: 代码 XML [fragment_products.xml]

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

    <LinearLayout
        android:id="@+id/header"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:gravity="center" >

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:text="Headerrrr"
            android:textColor="#000000"
            android:textSize="20sp" />
    </LinearLayout>

    <ScrollView
        android:id="@+id/sw_layout"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_below="@+id/header"
        android:orientation="vertical" >

        <LinearLayout
            android:id="@+id/sw_linear_layout"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:background="@color/list_background"
            android:gravity="center_horizontal"
            android:orientation="vertical"
            android:padding="10dp"
            android:paddingLeft="10dp"
            android:paddingRight="10dp" >

            <TextView
                android:id="@+id/name"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:paddingBottom="2dip"
                android:paddingTop="6dip"
                android:textColor="#43bd00"
                android:textSize="16sp"
                android:textStyle="bold" />

            <TextView
                android:id="@+id/qtde"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:paddingBottom="2dip"
                android:textColor="#acacac" />
        </LinearLayout>
    </ScrollView>

</RelativeLayout>

JAVA代码(FindProductsFragment):

@Override
        protected void onPostExecute(Void result) {
            super.onPostExecute(result);
            /**
             * Updating parsed JSON data
             * */
            String[] sr = { TAG_NAME, TAG_QTDE };
            int[] in = { R.id.name, R.id.qtde };

            ListAdapter adapter = new SimpleAdapter(getActivity(), productsList, R.layout.fragment_products, sr, in);
            setListAdapter(adapter);
}

结果不是我想要的。

image result

想要有固定的标题。 知道该怎么做吗?

【问题讨论】:

    标签: java android xml eclipse


    【解决方案1】:

    对于一个固定的页眉放置一个特定的布局,请遵循以下模式(我也在添加一个固定的页脚视图):

    <!-- Header aligned to top -->
    
    <RelativeLayout
        android:id="@+id/header"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentTop="true"
        android:background="@drawable/layered_bg"
        android:gravity="center" >
    
        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp"
            android:text="@string/title_app"
            android:textAppearance="?android:attr/textAppearanceLarge"
            android:textColor="@color/dark_gray" />
    </RelativeLayout>
    
    <!-- Footer aligned to bottom -->
    
    <RelativeLayout
        android:id="@+id/footer"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:background="@drawable/layered_bg"
        android:gravity="center" >
    
        <TextView
            android:id="@+id/id_txt"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_margin="5dp"
            android:text="@string/footer_text"
            android:textColor="@color/dark_gray" />
    </RelativeLayout>
    

    您只需要在这 2 个视图之间添加您的视图,就可以开始了。

    问候,

    【讨论】:

    • 你应该把你的其他布局元素放在这两个视图之间。你应该在这两个之间对齐它们。就是这样。我在我的应用程序中使用这种方式,我没有遇到任何问题。
    【解决方案2】:

    我这样做了:

    <?xml version="1.0" encoding="utf-8"?>
    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        android:layout_width="match_parent"
        android:layout_height="fill_parent"
        android:orientation="vertical" >
    
        <RelativeLayout
            android:id="@+id/header"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentTop="true"
            android:background="@color/list_background_pressed"
            android:gravity="center">
    
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_margin="5dp"
                android:text="@string/title_app"
                android:textAppearance="?android:attr/textAppearanceLarge"
                android:textColor="#FFFFFF" />
        </RelativeLayout>
    
        <ScrollView
            android:id="@+id/sw_layout"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_above="@+id/footer"
            android:layout_below="@+id/header"
            android:orientation="vertical">
    
            <LinearLayout
                android:id="@+id/sw_linear_layout"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:background="@color/list_background"
                android:gravity="center_horizontal"
                android:orientation="vertical"
                android:padding="10dp"
                android:paddingLeft="10dp"
                android:paddingRight="10dp" >
    
                <TextView
                    android:id="@+id/name"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:paddingBottom="2dip"
                    android:paddingTop="6dip"
                    android:textColor="#43bd00"
                    android:textSize="16sp"
                    android:textStyle="bold" />
    
                <TextView
                    android:id="@+id/qtde"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:paddingBottom="2dip"
                    android:textColor="#acacac" />
            </LinearLayout>
        </ScrollView>
    </RelativeLayout>
    

    我没有得到我们想要的结果,看起来像这样: looked like this

    我想要这样的东西: something like this

    【讨论】:

      猜你喜欢
      • 2016-05-17
      • 1970-01-01
      • 2016-02-29
      • 2012-01-30
      • 2015-02-04
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多