小编Adr*_*res的帖子

来自 AppBarLayout 的 OnOffsetChangedListener 的 onOffsetChanged 方法被不断调用

几天来我一直在寻找这个问题的答案。网上没有任何东西我可以使用。

我的问题是,当向 AppBarLayout 添加 OnOffsetChangedListener 时,它的方法 (onOffsetChaned) 会被一遍又一遍地调用,即使我没有触摸屏幕。此外,verticalOffset 的值永远不会改变,工具栏或 AbbBarLayout 返回的 getHeight() 值也不会改变。

我认为重要的是要补充一点,这也是使用来自 Android Studio 的主细节流模板发生的,除了将代码添加到活动之外,无需更改任何其他内容,因此我认为这不是我的代码中的内容。

提前致谢。

这是我正在使用的代码

appbarLayout = (AppBarLayout) findViewById(R.id.app_bar);
    appbarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
        @Override
        public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
            showToast(String.valueOf(appBarLayout.getHeight()));
            if (Math.abs(verticalOffset) == appBarLayout.getTotalScrollRange()) {
                showToast("Collapsed");
            } else if (verticalOffset == 0) {
                showToast("Expanded");
            } else {
               showToast("Scrolling");
            }
        }
    });
Run Code Online (Sandbox Code Playgroud)

这是我的 XML 文件

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true"
    tools:context=".views.ActivityTaskList"
    tools:ignore="MergeRootFrame">

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

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@+id/toolbar_layout"
            android:layout_width="match_parent" …
Run Code Online (Sandbox Code Playgroud)

android android-layout android-appbarlayout

5
推荐指数
1
解决办法
3010
查看次数

动画布局高度会产生奇怪的闪烁

我正在尝试为放置在工具栏下方和 AppbarLayout 内的布局(高度)设置动画。我已经尝试了几种方法:其中之一是使用 ValueAnimator.ofInt 并使用这个 int 来设置布局的高度。然而,这有点波涛汹涌。根据我读过的一些帖子,这是因为在每次迭代中都会调用 requestLayout() 并且这是一项昂贵的操作。我见过的几乎所有其他选项都需要调用 requestLayout() 。在这种情况下,有些旧的设备性能不佳。

另一种显然最有效的方法是在父布局(本例中为 AppbarLayout)中简单地声明 animateLayoutChanges = true 并简单地更改代码中的高度。这确实有效,但它会产生奇怪的跳跃,好像布局立即且非常短暂地到达其最终高度,再次折叠,然后开始正常动画。倒塌时也会发生同样的情况。

在活动中,我只是调用 setVisibility(View.VISIBLE) 展开并调用 newTaskLayout.setVisibility(View.GONE) 折叠。我还尝试将高度设置为 0,然后使视图 GONE 折叠,并设置高度以包裹内容,然后使视图可见展开,但结果是一样的。

有什么理由可以避免这种情况吗?或者有没有更好的方法来做到这一点?

继承人的 XML :(正在动画的视图是工具栏下的 CONstraintLayout)

<?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"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.adrapps.mytasks.Views.TaskListActivity">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:animateLayoutChanges="true"
        android:orientation="vertical"
        android:theme="@style/AppTheme.AppBarOverlay">

        <android.support.v7.widget.Toolbar
            android:id="@+id/toolbar"
            android:layout_width="match_parent"
            android:layout_height="?attr/actionBarSize"
            android:background="?attr/colorPrimary"
            android:title="App"
            app:popupTheme="@style/AppTheme.PopupOverlay">

            <ProgressBar
                android:id="@+id/progressBar"
                android:layout_width="30dp"
                android:layout_height="30dp"
                android:paddingLeft="8dp"
                android:paddingStart="8dp"
                android:visibility="gone" />

        </android.support.v7.widget.Toolbar>

        <android.support.constraint.ConstraintLayout
            android:id="@+id/new_task_layout"
            android:layout_width="match_parent"
            android:layout_height="164dp"
            android:paddingBottom="16dp"
            android:paddingEnd="16dp"
            android:paddingStart="16dp"
            android:visibility="visible">

            <ImageView
                android:id="@+id/title_icon"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginBottom="0dp"
                android:layout_marginEnd="16dp"
                android:layout_marginRight="16dp"
                android:layout_marginTop="0dp"
                android:src="@drawable/ic_label" …
Run Code Online (Sandbox Code Playgroud)

layout animation

5
推荐指数
0
解决办法
427
查看次数