我想创建自己的ActionBar布局.
像这样(例如在Paint中创建)
是否可以为第二个按钮提供上行导航属性?因此,如果我按下它,它会完成此操作Activity并启动它的父级.
我想要汉堡图标,Navigation Drawer向上导航的向上图标和活动标题.
可能吗?或者是否已有解决方案?
实际上,这很容易做到(尽管有点麻烦)。首先,为后退按钮创建一个可绘制对象(最好 - 作为选择器,以区分按下/正常状态:
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@drawable/back_button_pressed"/>
<item android:drawable="@drawable/back_button"/>
</selector>
Run Code Online (Sandbox Code Playgroud)
接下来,将这个drawable设置为工具栏的标志toolbar.setLogo(R.drawable.back_button_selector);
那么剩下的唯一的事情就是设置点击监听器。
View logoView = getToolbarLogoIcon(toolbar);
logoView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
onBackPressed();
}
});
...
private View getToolbarLogoIcon(Toolbar toolbar){
//check if contentDescription previously was set
boolean hadContentDescription = android.text.TextUtils.isEmpty(toolbar.getLogoDescription());
String contentDescription = String.valueOf(!hadContentDescription ? toolbar.getLogoDescription() : "logoContentDescription");
toolbar.setLogoDescription(contentDescription);
ArrayList<View> potentialViews = new ArrayList<>();
//find the view based on it's content description, set programatically or with android:contentDescription
toolbar.findViewsWithText(potentialViews,contentDescription, View.FIND_VIEWS_WITH_CONTENT_DESCRIPTION);
//Nav icon is always instantiated at this point because calling setLogoDescription ensures its existence
View logoIcon = null;
if (potentialViews.size() > 0) {
logoIcon = potentialViews.get(0);
}
//Clear content description if not previously present
if (hadContentDescription) {
toolbar.setLogoDescription(null);
}
return logoIcon;
}
Run Code Online (Sandbox Code Playgroud)
(感谢尼古拉在这里的帖子)。或者,如果您不害怕反射,则可以轻松完成,如下所示:
try {
Field declaredField = toolbar.getClass().getDeclaredField("mLogoView");
declaredField.setAccessible(true);
View logoView = (View) declaredField.get(toolbar);
logoView.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
onBackPressed();
}
});
} catch (Exception ex) {
//error
}
Run Code Online (Sandbox Code Playgroud)
另一种可能的解决方案是为 ActionBar 设置自定义布局。不过,我建议遵循 UI/UX 指南并仔细检查导航抽屉在次要活动中是否必不可少。
| 归档时间: |
|
| 查看次数: |
341 次 |
| 最近记录: |