滚动到CoordinatorLayout中查看仅显示部分视图

时间:2016-01-11 15:39:59

标签: android android-coordinatorlayout android-appbarlayout nestedscrollview

我制作了一个包含带有AppBar和NestedScrollView的CoordinatorLayout的Android应用。在我的NestedScrollView中,我有一个项目列表,以及一个滚动到我的NestedScrollView中的项目的按钮。

点按该按钮后,Android应用会向下滚动到该项目,但不会仅部分显示整个项目:http://i.stack.imgur.com/8kuq0.png

我期待以下内容:http://i.stack.imgur.com/k0A5N.png

似乎应用程序需要滚动的数量与AppBar大小相同,以显示整个视图。如果我在下面的布局文件中删除滚动标记,我会得到预期的行为。

我做错了什么?

更新(2016年1月12日):我已经更新了图片,因此它们更大了。此外,正如我在Herry的回复中所写的那样,我怀疑View.requestRectangleOnScreen()是否是正确的调用方法,或者我是否应该使用不同的布局,然后是NestedScrollView。

我的活动编码如下:

package com.example.sij.coordinatorlayoutbug;

import android.graphics.Rect;
import android.os.Bundle;
import android.os.Handler;
import android.os.Looper;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

public class MainActivity extends AppCompatActivity {
    TextView itemToNavigateTo;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        setSupportActionBar(toolbar);

        itemToNavigateTo = (TextView)findViewById(R.id.itemToNavigateTo);
        Button navigatorButton = (Button)findViewById(R.id.navigator_button);
        navigatorButton.setOnClickListener(navigateToItemListener());
    }

    View.OnClickListener navigateToItemListener() {
        return new View.OnClickListener() {
            @Override
            public void onClick(final View v) {
                new Handler(Looper.getMainLooper()).post(new Runnable() {
                    @Override
                    public void run() {
                        itemToNavigateTo.requestRectangleOnScreen(
                            new Rect(
                                0, 
                                0, 
                                itemToNavigateTo.getWidth(),
                                itemToNavigateTo.getHeight()));
                    }
                });
            }
        };
    }
}

布局文件:

<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            app:layout_scrollFlags="scroll|enterAlways" />

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">
        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">
            <Button
                android:id="@+id/navigator_button"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/scroll_to_item" />
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/item1"/>
            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/lorem_ipsum"
                android:paddingBottom="20dp"/>

            <!-- Items 2 to 5 omitted for brevity -->

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/item6"/>
            <TextView
                android:id="@+id/itemToNavigateTo"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="@string/lorem_ipsum"
                android:paddingBottom="20dp"/>              
        </LinearLayout>
    </android.support.v4.widget.NestedScrollView>

</android.support.design.widget.CoordinatorLayout>

1 个答案:

答案 0 :(得分:0)

您需要在

中添加android:fillviewport="true"
 <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        android:fillViewport="true">