关于toolbar标题居中及隐藏右侧overflowButton

最近的项目中用到了Android中的标题栏toolbar,但现在的需求中暂时不需要标题栏右侧的overflowButton,而且要求标题居中。

先贴一张最终效果图:
最终效果图

再来对比一下原图:
原图

其实我还是觉得有overflow的小点会好看一些,无奈~ 。好了,废话少说,在实现这个效果之前,我去看了看toolbar的代码,没找到让标题居中的比较好的实现方试(当然,如果有人知道的话,还恳请告知一声,谢啦~),就去网上搜了一下。大家给的解决办法大多都是自己在toolbar的布局中又写了一个TextView并设置居中,然后再在引用toolbar的地方设置toolbar.setTitle(“”),最终实现标题居中的效果。

代码如下:

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

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_gravity="center"
                android:text="@string/app_name"
                android:textColor="#fff"
                android:textSize="@dimen/main_title_size"/>
        </android.support.v7.widget.Toolbar>

我试了一下,效果还比较不错,先这么用,有更好的方案再换,嘿嘿。

接下来是去掉overflowButton,这个比较简单,在activity中将生成菜单的那句代码注掉就好了,上代码

    @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        // Inflate the menu; this adds items to the action bar if it is present.
//        getMenuInflater().inflate(R.menu.main, menu);
        return true;
    }
在网上还看到有些同学想要将右边的这个overflowButton的图片换成自己的,好多人给出的方案是修改样式,但是我在看toolbar的代码的时候,分明看到一个方法
/**
     * Set the icon to use for the overflow button.
     *
     * @param icon Drawable to set, may be null to clear the icon
     */
    public void setOverflowIcon(@Nullable Drawable icon) {
        ensureMenu();
        mMenuView.setOverflowIcon(icon);
    }

这个方法说的比较清楚,用来设置overflow button的图标,同时也可以设为null来清除图标。我试过把它设为null,图标是没了,但点击事件依然在,所以我在上面说把getMenuInflater().inflate(R.menu.main, menu);这一句注释掉了。不过它修改图标的作用还是很好用的,见图:
替换overflow button图标

图片我只是随便找了一个系统的图片演示效果:

toolbar.setOverflowIcon(getDrawable(android.support.v7.appcompat.R.drawable.abc_vector_test));

好了,效果都实现了,大家如果有问题请私信或在评论区提出,欢迎交流和指正哦~

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值