如何确定 ImageView 在 CollapsingToolbar 中是否可见?
How to determine if an ImageView is visible in CollapsingToolbar?
我有一个折叠式工具栏布局,如下所示:
<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" />
这只是一个带有圆形遮罩的标准图像视图。当展开折叠工具栏时,圆形图像视图可见并显示如下:
折叠后,图像视图不再可见,如下所示:
然而,即使在折叠状态下,图像视图的可见性似乎仍设置为可见。当用户按下后退按钮时,我需要确定图像是否可见以执行共享元素过渡动画。 如何确定图像当前在折叠工具栏中是否可见?
我尝试过的:
getVisibility()
保持不变
isOpaque()
保持不变
getImageAlpha()
保持不变
我能够使用 CollapsingToolbarLayout#getContentScrim() 解决问题,根据文档:
Returns the drawable which is used for the foreground scrim.
似乎图像视图始终可见,但前景稀松布将其隐藏,因此使用 alpha
属性 getContentScrim().getAlpha()
您可以确定图像是否可见。
这可以使用您自己的 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
}
}
}););
mAppBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
boolean isContentHide = mCollapsingToolbarLayout.getScrimVisibleHeightTrigger() + Math.abs(verticalOffset) > mCollapsingToolbarLayout.getHeight();
}
});
我有一个折叠式工具栏布局,如下所示:
<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" />
这只是一个带有圆形遮罩的标准图像视图。当展开折叠工具栏时,圆形图像视图可见并显示如下:
折叠后,图像视图不再可见,如下所示:
然而,即使在折叠状态下,图像视图的可见性似乎仍设置为可见。当用户按下后退按钮时,我需要确定图像是否可见以执行共享元素过渡动画。 如何确定图像当前在折叠工具栏中是否可见?
我尝试过的:
getVisibility()
保持不变
isOpaque()
保持不变
getImageAlpha()
保持不变
我能够使用 CollapsingToolbarLayout#getContentScrim() 解决问题,根据文档:
Returns the drawable which is used for the foreground scrim.
似乎图像视图始终可见,但前景稀松布将其隐藏,因此使用 alpha
属性 getContentScrim().getAlpha()
您可以确定图像是否可见。
这可以使用您自己的 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
}
}
}););
mAppBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
boolean isContentHide = mCollapsingToolbarLayout.getScrimVisibleHeightTrigger() + Math.abs(verticalOffset) > mCollapsingToolbarLayout.getHeight();
}
});