我想创建自己的ActionBar
布局。
像这样(例如在Paint中创建)
是否可以为第二个按钮提供向上导航属性?因此,如果我按下它,它将完成此Activity
并启动它的父级。
我想要Navigation Drawer
的汉堡图标,向上导航的向上图标和活动标题。
有可能吗?或者是否已有解决方案?
答案 0 :(得分:1)
实际上,要做到这一点相当容易(虽然这很小)。 首先,为后退按钮创建一个drawable(最好 - 作为选择器,以区分按下/正常状态:
<?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>
接下来,将此drawable设置为工具栏toolbar.setLogo(R.drawable.back_button_selector);
然后唯一剩下的就是设置click-listener。
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;
}
(感谢Nicola的帖子here)。或者,如果你不害怕反思,可以这样轻松地完成:
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
}
另一种可能的解决方案是将自定义布局设置为ActionBar。 虽然,我主张遵循UI / UX准则并仔细检查,如果导航抽屉在次要活动中是必不可少的。