我在我的Activity中使用了CollapsingToolbarLayout,但是我需要在扩展时改变后箭头的颜色,有什么方法可以做到这一点吗? 我有什么:
我想做什么:
这是我的布局,我把“......”布局包含了NestedScrollView。
<?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="com.primebitstudio.swiper.AboutCouponActivity"
android:layout_marginTop="-1px">
<android.support.design.widget.AppBarLayout android:id="@+id/app_bar"
android:fitsSystemWindows="true"
android:layout_height="wrap_content"
android:layout_width="match_parent"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.design.widget.CollapsingToolbarLayout android:id="@+id/toolbar_layout"
android:fitsSystemWindows="true"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_scrollFlags="scroll|exitUntilCollapsed"
app:contentScrim="?attr/colorPrimary"
app:expandedTitleTextAppearance="@style/CollapsingToolbarLayoutExpandedTextStyle"
app:theme="@style/ThemeOverlay.AppCompat.Light"
app:popupTheme="@style/ToolBarStyle">
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_marginTop="-24dp">
<ImageView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:adjustViewBounds="true"
android:scaleType="fitCenter"
android:src="@drawable/test_image"
android:id="@+id/image"/>
</RelativeLayout>
<android.support.v7.widget.Toolbar android:id="@+id/toolbar"
android:layout_height="?attr/actionBarSize"
android:layout_width="match_parent"
app:layout_collapseMode="pin"
app:popupTheme="@style/ToolBarStyle" />
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
...
...
</android.support.design.widget.CoordinatorLayout>
答案 0 :(得分:2)
以下是展开和折叠布局时如何更改抽屉和选项图标颜色的示例:
protected void onCreate(Bundle savedInstanceState) {
AppBarLayout appBarLayout = (AppBarLayout) findViewById(R.id.app_bar_layout);
appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
@Override
public void onOffsetChanged(AppBarLayout appBarLayout, int offset)
{
Drawable upArrow = ResourcesCompat.getDrawable(getResources(), R.drawable.drawer_icon, null);
if (offset < -200)
{
upArrow.setColorFilter(Color.parseColor("#000000"), PorterDuff.Mode.SRC_ATOP);
getSupportActionBar().setHomeAsUpIndicator(upArrow);
Drawable drawable = ContextCompat.getDrawable(getApplicationContext(),R.drawable.option_menu_icon);
drawable.setColorFilter(Color.parseColor("#000000"), PorterDuff.Mode.SRC_ATOP);
toolbar.setOverflowIcon(drawable);
}
else
{
upArrow.setColorFilter(Color.parseColor("#ffffff"), PorterDuff.Mode.SRC_ATOP);
getSupportActionBar().setHomeAsUpIndicator(upArrow);
getSupportActionBar().setDisplayHomeAsUpEnabled(true);
Drawable drawable = ContextCompat.getDrawable(getApplicationContext(),R.drawable.option_menu_icon);
drawable.setColorFilter(Color.parseColor("#ffffff"), PorterDuff.Mode.SRC_ATOP);
toolbar.setOverflowIcon(drawable);
}
}
});
答案 1 :(得分:1)
来自documentation on ActionBarDrawerToggle
:
您可以通过在ActionBar主题中定义
drawerArrowStyle
来自定义动画切换。
drawerArrowStyle
属性列出了可以配置的以下属性:
android.support.v7.appcompat:arrowHeadLength
android.support.v7.appcompat:arrowShaftLength
android.support.v7.appcompat:barLength
android.support.v7.appcompat:color
android.support.v7.appcompat:drawableSize
android.support.v7.appcompat:gapBetweenBars
android.support.v7.appcompat:spinBars
android.support.v7.appcompat:thickness
我认为android.support.v7.appcompat:color
是您追求的目标。
为了在运行时更改颜色,您有多个选项。
选项1
从Toolbar
获取导航图标并对其应用颜色过滤器。例如,要将图标着色为红色,可以执行以下操作:
Drawable navIcon = mToolbar.getNavigationIcon();
navIcon.setColorFilter(Color.RED, PorterDuff.Mode.SRC_IN);
这种方法的优点是你可以使用各种PorterDuff.Mode
常量来实现不同的效果。如果您决定提供自己的导航图标(而不是默认的汉堡包 - 转动 - 箭头 - 反之亦然),这种方法也可以工作(并继续工作)。
选项2
如果您只对着色默认导航图标感兴趣,则可以利用导航图标drawable是DrawerArrowDrawable
这一事实,该方法具有setColor()
方法:
DrawerArrowDrawable navIcon = (DrawerArrowDrawable) mToolbar.getNavigationIcon();
navIcon.setColor(Color.RED);
如果您计划在ie ObjectAnimator.ofArgb(...)
或ValueAnimator.ofArgb(...)
的帮助下逐渐设置颜色动画(而不仅仅是设置它),则第二种方法可能更容易使用。
答案 2 :(得分:0)
appBarLayout.addOnOffsetChangedListener(new AppBarLayout.OnOffsetChangedListener() {
int scrollRange = -1;
@Override
public void onOffsetChanged(final AppBarLayout appBarLayout, int verticalOffset) {
//Initialize the size of the scroll
if (scrollRange == -1) {
scrollRange = appBarLayout.getTotalScrollRange();
}
//Check if the view is collapsed
if (scrollRange + verticalOffset == 0) {
@SuppressLint("UseCompatLoadingForDrawables") final Drawable upArrow = getResources().getDrawable(R.drawable.abc_ic_ab_back_material);
upArrow.setColorFilter(getResources().getColor(R.color.black), PorterDuff.Mode.SRC_ATOP);
Objects.requireNonNull(getSupportActionBar()).setHomeAsUpIndicator(upArrow);
} else {
@SuppressLint("UseCompatLoadingForDrawables") final Drawable upArrow = getResources().getDrawable(R.drawable.abc_ic_ab_back_material);
upArrow.setColorFilter(getResources().getColor(R.color.white), PorterDuff.Mode.SRC_ATOP);
Objects.requireNonNull(getSupportActionBar()).setHomeAsUpIndicator(upArrow);
}
}
});
如果你想在android中使用collapsingtoolbarlayout时改变工具栏后退按钮的颜色。 这是当你想要在 appbarlayout 折叠或展开时显示不同颜色的后退按钮时的条件。