8

问题:当 ScrollView 超过一定高度时,它会隐藏其子视图的顶部。

我在 XML 中定义了以下布局

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

    <LinearLayout
        android:id="@+id/commandPanel"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:paddingLeft="5dip"
        android:paddingRight="5dip" >

        <Button
            android:id="@+id/button1"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="OK" />

        <Button
            android:id="@+id/button2"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_weight="1"
            android:text="Back" />
    </LinearLayout>

    <RelativeLayout
        android:id="@+id/mainContentPanel"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_above="@id/commandPanel"
        android:background="@android:color/white" >

        <ScrollView
            android:id="@+id/formScrollView"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_gravity="center"
            android:layout_marginTop="5dip"
            android:layout_weight="1"
            android:background="@android:color/darker_gray"
            android:fillViewport="false"
            android:paddingBottom="5dip"
            android:scrollbarStyle="insideOverlay" >

            <LinearLayout
                android:id="@+id/formContentLayout"
                android:layout_width="fill_parent"
                android:layout_height="fill_parent"
                android:layout_gravity="center"
                android:layout_marginTop="20dip"
                android:background="@android:color/black"
                android:gravity="center_horizontal|top"
                android:orientation="vertical"
                android:paddingLeft="5dip"
                android:paddingRight="5dip"
                android:paddingTop="20dip" >

                <LinearLayout
                    android:id="@+id/tr"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_marginTop="10dip"
                    android:orientation="horizontal" >

                    <TextView
                        android:id="@+id/title"
                        android:layout_width="fill_parent"
                        android:layout_height="wrap_content"
                        android:layout_weight="1"
                        android:text="sample title" />

                    <TextView
                        android:id="@+id/value"
                        android:layout_width="fill_parent"
                        android:layout_height="wrap_content"
                        android:layout_weight="1"
                        android:text="sample value ......." />
                </LinearLayout>
            </LinearLayout>
        </ScrollView>
    </RelativeLayout>

</RelativeLayout>

- - - - - 代码 - - -

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setContentView(R.layout.scrollview);
    updateUi();
}

//add few more rows here
void updateUi() {
    LinearLayout sampletr = (LinearLayout) findViewById(R.id.tr);
    LinearLayout contentPane = (LinearLayout) findViewById(R.id.formContentLayout);
    TextView title = (TextView) findViewById(R.id.title);
    TextView value = (TextView) findViewById(R.id.value);
    for (int i = 0; i < 25; i++) {
        LinearLayout tr = new LinearLayout(this);
        TextView t = new TextView(this);
        t.setText("Sample title : " + i);
        TextView v = new TextView(this);
        v.setText("Sample value : " + i);

        tr.addView(t, title.getLayoutParams());
        tr.addView(v, value.getLayoutParams());
        contentPane.addView(tr, sampletr.getLayoutParams());
    }
}

如果没有,LinearLayout(ScrollView 的直接子级)中的顶部行开始从顶部消失。行数超过 15!此外,我什至无法手动向上滚动查看它们,请任何指针,这个布局有什么问题?

4

5 回答 5

30

好的,我已经通过从 LinearLayout(ScrollView 的直接子级)中删除以下行来解决它

android:layout_gravity="center"

ScrollView 现在可以完美运行。谢谢大家的建议。

于 2012-05-29T13:08:42.257 回答
0

只需用 lil change 编写 xml

<LinearLayout
    android:id="@+id/commandPanel"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:paddingLeft="5dip"
    android:paddingRight="5dip" >

    <Button
        android:id="@+id/button1"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="OK" />

    <Button
        android:id="@+id/button2"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="1"
        android:text="Back" />
</LinearLayout>

<RelativeLayout
    android:id="@+id/mainContentPanel"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:layout_above="@id/commandPanel"
    android:background="@android:color/white" >

    <ScrollView
        android:id="@+id/formScrollView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_gravity="center"

        android:layout_marginTop="0dp"    <--- --- change n remove this margin

        android:layout_weight="1"
        android:background="@android:color/darker_gray"
        android:fillViewport="false"
        android:paddingBottom="5dip"
        android:scrollbarStyle="insideOverlay" >

        <LinearLayout
            android:id="@+id/formContentLayout"
            android:layout_width="fill_parent"
            android:layout_height="fill_parent"
            android:layout_gravity="center"
            android:layout_marginTop="20dip"
            android:background="@android:color/black"
            android:gravity="center_horizontal|top"
            android:orientation="vertical"
            android:paddingLeft="5dip"
            android:paddingRight="5dip"
            android:paddingTop="20dip" >

            <LinearLayout
                android:id="@+id/tr"
                android:layout_width="fill_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="10dip"
                android:orientation="horizontal" >

                <TextView
                    android:id="@+id/title"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_weight="1"
                    android:text="sample title" />

                <TextView
                    android:id="@+id/value"
                    android:layout_width="fill_parent"
                    android:layout_height="wrap_content"
                    android:layout_weight="1"
                    android:text="sample value ......." />
            </LinearLayout>
        </LinearLayout>
    </ScrollView>
</RelativeLayout>

于 2012-05-29T11:56:50.667 回答
0

我会删除第二个RelativeLayout节点,但保留ScrollView. 然后对于ScrollView我会添加layout_alignParentTop=trueand layout_above="@+id/commandPanel"。第二个RelativeLayout似乎是多余的,通常当您将子项添加到 a 时,RelativeLayout他们应该使用容器的布局选项,即 layout_above、below、align 等。

于 2012-05-29T11:47:46.547 回答
0

看起来您的 padding-top 似乎有问题,请先尝试将其删除。

于 2012-05-29T11:48:18.447 回答
0

只需android:gravity="center"在父线性布局内添加行就scrollView解决了我的问题。

于 2020-12-24T14:36:58.623 回答