监听 AppBarLayout 的偏移量变化(collapsing/expanding)以改变 Kotlin 中工具栏的背景
Listen to offset changes (collapsing/expanding) of AppBarLayout to change toolbar's background in Kotlin
我正在定制 Collapsing Toolbar Layout
。折叠部分完成,工具栏也相应调整。唯一缺少的是我想改变我的 Toolbar
s 背景 因为 Collapsing Toolbar Layout
正在崩溃,即逐渐增加我的 [=14] 的不透明度=]的背景。
我在 Java 中看到了很多看似符合我要求的答案。不幸的是,我在 Java 中没有(完全)基础知识,最有意义的是这里:。我尝试将上述代码粘贴到我的 Android Studio IDE,但它不起作用(它并没有真正覆盖任何东西)。作为参考,post 的代码在这里:
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
//measuring for alpha
int toolBarHeight = toolbar.getMeasuredHeight();
int appBarHeight = appBarLayout.getMeasuredHeight();
Float f = ((((float) appBarHeight - toolBarHeight) + verticalOffset) / ( (float) appBarHeight - toolBarHeight)) * 255;
fading_backdrop.getBackground().setAlpha(255 - Math.round(f));
}
我同样想这样做,即我希望能够听到我的 AppBarLayout
的 Y 偏移以逐渐改变我的 Toolbar
的背景。
我有以下 activity_xml 文件(以防万一):
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout ...>
<com.google.android.material.appbar.AppBarLayout
... >
<com.google.android.material.appbar.CollapsingToolbarLayout
android:id="@+id/collapsingToolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg_collapsing_toolbar"
app:collapsedTitleTextAppearance="@style/CollapsedCollapsingToolbarText"
app:expandedTitleTextAppearance="@style/ExpandedCollapsingToolbarText"
app:layout_scrollFlags="exitUntilCollapsed|scroll">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg_collapsing_toolbar"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="0.75" />
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/Theme.AppCompat.Light">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
... />
<ImageView
... />
<ImageView
... />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.appcompat.widget.Toolbar>
</com.google.android.material.appbar.CollapsingToolbarLayout>
</com.google.android.material.appbar.AppBarLayout>
</androidx.coordinatorlayout.widget.CoordinatorLayout>
我如何听一些 AppBarLayout
偏移量变化,以便我可以随着 Collapsing Toolbar Layout
在 Kotlin[=] 中崩溃 逐渐改变我的 Toolbar
s 背景35=]?
试试这个。
appBarLayout.addOnOffsetChangedListener(AppBarLayout.OnOffsetChangedListener { appBarLayout, verticalOffset ->
//measuring for alpha
int toolBarHeight = toolbar.getMeasuredHeight();
int appBarHeight = appBarLayout.getMeasuredHeight();
Float f = ((((float) appBarHeight - toolBarHeight) + verticalOffset) / ( (float) appBarHeight - toolBarHeight)) * 255;
fading_backdrop.getBackground().setAlpha(255 - Math.round(f));
})
我正在定制 Collapsing Toolbar Layout
。折叠部分完成,工具栏也相应调整。唯一缺少的是我想改变我的 Toolbar
s 背景 因为 Collapsing Toolbar Layout
正在崩溃,即逐渐增加我的 [=14] 的不透明度=]的背景。
我在 Java 中看到了很多看似符合我要求的答案。不幸的是,我在 Java 中没有(完全)基础知识,最有意义的是这里:
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int verticalOffset) {
//measuring for alpha
int toolBarHeight = toolbar.getMeasuredHeight();
int appBarHeight = appBarLayout.getMeasuredHeight();
Float f = ((((float) appBarHeight - toolBarHeight) + verticalOffset) / ( (float) appBarHeight - toolBarHeight)) * 255;
fading_backdrop.getBackground().setAlpha(255 - Math.round(f));
}
我同样想这样做,即我希望能够听到我的 AppBarLayout
的 Y 偏移以逐渐改变我的 Toolbar
的背景。
我有以下 activity_xml 文件(以防万一):
<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.widget.CoordinatorLayout ...>
<com.google.android.material.appbar.AppBarLayout
... >
<com.google.android.material.appbar.CollapsingToolbarLayout
android:id="@+id/collapsingToolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg_collapsing_toolbar"
app:collapsedTitleTextAppearance="@style/CollapsedCollapsingToolbarText"
app:expandedTitleTextAppearance="@style/ExpandedCollapsingToolbarText"
app:layout_scrollFlags="exitUntilCollapsed|scroll">
<ImageView
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/bg_collapsing_toolbar"
app:layout_collapseMode="parallax"
app:layout_collapseParallaxMultiplier="0.75" />
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/Theme.AppCompat.Light">
<androidx.constraintlayout.widget.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
... />
<ImageView
... />
<ImageView
... />
</androidx.constraintlayout.widget.ConstraintLayout>
</androidx.appcompat.widget.Toolbar>
</com.google.android.material.appbar.CollapsingToolbarLayout>
</com.google.android.material.appbar.AppBarLayout>
</androidx.coordinatorlayout.widget.CoordinatorLayout>
我如何听一些 AppBarLayout
偏移量变化,以便我可以随着 Collapsing Toolbar Layout
在 Kotlin[=] 中崩溃 逐渐改变我的 Toolbar
s 背景35=]?
试试这个。
appBarLayout.addOnOffsetChangedListener(AppBarLayout.OnOffsetChangedListener { appBarLayout, verticalOffset ->
//measuring for alpha
int toolBarHeight = toolbar.getMeasuredHeight();
int appBarHeight = appBarLayout.getMeasuredHeight();
Float f = ((((float) appBarHeight - toolBarHeight) + verticalOffset) / ( (float) appBarHeight - toolBarHeight)) * 255;
fading_backdrop.getBackground().setAlpha(255 - Math.round(f));
})