最近的项目中用到了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);这一句注释掉了。不过它修改图标的作用还是很好用的,见图:
图片我只是随便找了一个系统的图片演示效果:
toolbar.setOverflowIcon(getDrawable(android.support.v7.appcompat.R.drawable.abc_vector_test));
好了,效果都实现了,大家如果有问题请私信或在评论区提出,欢迎交流和指正哦~