如何确定ImageView在CollapsingToolbar中是否可见?

时间:2016-05-01 21:10:59

标签: android android-imageview android-collapsingtoolbarlayout

我有一个折叠的工具栏布局,如下所示:

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

       <include layout="@layout/circle_image_view"/>

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

其中circle_image_view

<com.example.ui.CircularParseImageView 
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:id="@+id/iv_circular_backdrop"
    android:layout_width="120dp"
    android:layout_height="120dp"
    android:layout_gravity="center"
    android:fitsSystemWindows="true"
    android:scaleType="centerCrop"
    android:transitionName="@string/transition_pic"
    app:layout_collapseMode="parallax" />

这只是带有圆形遮罩的标准图像视图。展开折叠工具栏时,圆形图像视图可见,并显示如下:

Expanded view

折叠时,图像视图不再可见,如下所示:

Collapsed view

然而,即使在折叠状态下,图像视图的可见性似乎仍设置为“可见”。当用户按下后退按钮时,我需要确定图像是否可见以执行共享元素过渡动画。 如何在折叠工具栏中确定图像当前是否可见?

我尝试过:

getVisibility()保持不变

isOpaque()保持不变

getImageAlpha()保持不变

3 个答案:

答案 0 :(得分:4)

我能够根据文档使用CollapsingToolbarLayout#getContentScrim()来解决问题:

  

返回用于前景稀松布的drawable。

似乎图像视图始终可见,但前景稀松布隐藏了它,因此使用public/img/属性alpha可以确定图像是否可见。

答案 1 :(得分:2)

这可以使用您自己的OnOffsetChangedListener实现来实现。

AppBarLayout appBarLayout = (AppBarLayout) view.findViewById(R.id.app_bar_layout);
appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
        @Override
        public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
            if (Math.abs(verticalOffset) == appBarLayout.getTotalScrollRange()) {
                // Collapsed
            } else if (verticalOffset == 0) {
                // Expanded
            } else {
                // Somewhere in between
            }
        }
    }););

答案 2 :(得分:1)

mAppBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
            @Override
            public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
                boolean isContentHide = mCollapsingToolbarLayout.getScrimVisibleHeightTrigger() + Math.abs(verticalOffset) > mCollapsingToolbarLayout.getHeight();
            }
        });