使用CollapsingToolbarLayout的CoordinatorLayout中的WebView

24

我想在CoordinatorLayout中添加一个WebView,同时在AppBarLayout中使用CollapsingToolbarLayout。问题在于WebView在高度上收缩并且无法填充工具栏下方的空间,因此无法使用。我还尝试将WebView用作NestedScrollView的子项:最初它不起作用(它会使我的WebView高度缩小),但是滚动我的缩小了的WebView会使其填充视口。

这是我所使用的布局:

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

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="256dp"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/collapsing_toolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:fitsSystemWindows="true"
            app:contentScrim="?attr/colorPrimary"
            app:expandedTitleMarginEnd="64dp"
            app:expandedTitleMarginStart="48dp"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <ImageView
                android:id="@+id/backdrop"
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:fitsSystemWindows="true"
                android:scaleType="centerCrop"
                app:layout_collapseMode="parallax" />

            <android.support.v7.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="?attr/actionBarSize"
                app:layout_collapseMode="pin"
                app:popupTheme="@style/ThemeOverlay.AppCompat.Light" />

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

    </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">

        <WebView
            android:id="@+id/article"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </android.support.v4.widget.NestedScrollView>
</android.support.design.widget.CoordinatorLayout>
7个回答

2

您可以在NestedScrollView中使用android:fillViewport="true",并在WebView中使用layout_height="wrap_content"


1
最新的(22.2.1)设计支持库已经修复了该漏洞。

7
自从最新版本(24.2.0)以来,这个错误又出现了。 - Marian

1

我认为设置app:layout_scrollFlags="scroll|enterAlways"会很有帮助。


1
这对我有效。
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.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:fitsSystemWindows="true">

    <com.google.android.material.appbar.AppBarLayout
        android:id="@+id/app_bar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true">

        <com.google.android.material.appbar.CollapsingToolbarLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:background="@color/backgroundColor"
            android:fitsSystemWindows="true"
            app:layout_scrollFlags="scroll|enterAlways|snap">

            <FrameLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="bottom">

                <androidx.appcompat.widget.AppCompatImageButton
                    android:id="@+id/back_bt"
                    android:layout_width="48dp"
                    android:layout_height="48dp"
                    android:background="@color/transparent"
                    android:src="@drawable/ic_arrow_back_black_24dp" />
            </FrameLayout>

        </com.google.android.material.appbar.CollapsingToolbarLayout>

    </com.google.android.material.appbar.AppBarLayout>

    <androidx.core.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fillViewport="false"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:orientation="vertical">

            <WebView
                android:id="@+id/web_view"
                android:layout_width="match_parent"
                android:layout_height="match_parent" />
        </LinearLayout>
    </androidx.core.widget.NestedScrollView>

</androidx.coordinatorlayout.widget.CoordinatorLayout>

0
尝试从所有视图中删除属性android:fitsSystemWindows="true"

1
它不起作用:适配系统窗口不会拉伸视图,并且还需要在AppBarLayout中使用fitsSystemWindows才能获得状态栏覆盖层。 - Alex Facciorusso
好的。我在实现过程中遇到了另一个问题,但我已经用Webview构建了一个测试应用程序。您可以在此帖子中查看XML布局文件:http://stackoverflow.com/questions/30568772/android-design-library-appbar-scrolling-behavior。 我的Apptheme如下所示:<style name="AppTheme" parent="Theme.AppCompat.NoActionBar"> <!-- 在此处自定义您的主题。 --> </style> - Zenco
我刚看到你的问题http://stackoverflow.com/questions/30568772/android-design-library-appbar-scrolling-behavior:你如何在Java代码中实例化你的WebView? - Alex Facciorusso
WebView wvTest = (WebView)findViewById(R.id.wvTest); wvTest.setWebViewClient(new WebViewClient() { @Override public boolean shouldOverrideUrlLoading(WebView view, String url) { return super.shouldOverrideUrlLoading(view, url); } }); wvTest.loadUrl("http://stackoverflow.com/"); - Zenco
我实例化我的方式是一样的...我不知道为什么它不能填满我的布局! - Alex Facciorusso
让我们在聊天中继续这个讨论 - Alex Facciorusso

0

-2
    DisplayMetrics metrics = new DisplayMetrics();
    getActivity().getWindowManager().getDefaultDisplay().getMetrics(metrics);

    int statusBarHeight = getStatusBarHeight(this);

    TypedArray actionbarSizeTypedArray = this.obtainStyledAttributes(new int[]{android.R.attr.actionBarSize});
    int actionBarHeight = (int) actionbarSizeTypedArray.getDimension(0, 0);

    NestedScrollView nestedScrollView = (NestedScrollView) findViewById(R.id.nsv_scroll);
    CoordinatorLayout.LayoutParams params = new CoordinatorLayout.LayoutParams(
            CoordinatorLayout.LayoutParams.MATCH_PARENT,
            metrics.heightPixels - actionBarHeight - statusBarHeight);

    nestedScrollView.setLayoutParams(params);

getStatusBarHeight() 方法:

public int getStatusBarHeight(Context context){
    Class<?> c = null;
    Object obj = null;
    Field field = null;
    int x = 0;
    int statusBarHeight = 0;
    try {
        c = Class.forName("com.android.internal.R$dimen");
        obj = c.newInstance();
        field = c.getField("status_bar_height");
        x = Integer.parseInt(field.get(obj).toString());
        statusBarHeight = context.getResources().getDimensionPixelSize(x);
    } catch (Exception e1) {
        e1.printStackTrace();
    }
    return statusBarHeight;
}

请问您能否稍微解释一下,为什么这会有助于提问者的问题呢? - SuperBiasedMan
哦,@Jiashu 这里没有定义“指标(metrics)”。 - Alex Facciorusso
DisplayMetrics metrics = new DisplayMetrics(); getActivity().getWindowManager().getDefaultDisplay().getMetrics(metrics); - Jiashu

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接