在Android中的自定义ActionBar按钮中添加向上导航属性

ray*_*dis 5 android

我想创建自己的ActionBar布局.

像这样(例如在Paint中创建)

在此输入图像描述

是否可以为第二个按钮提供上行导航属性?因此,如果我按下它,它会完成此操作Activity并启动它的父级.

我想要汉堡图标,Navigation Drawer向上导航的向上图标和活动标题.

可能吗?或者是否已有解决方案?

Kon*_*nov 1

实际上,这很容易做到(尽管有点麻烦)。首先,为后退按钮创建一个可绘制对象(最好 - 作为选择器,以区分按下/正常状态:

<?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 指南并仔细检查导航抽屉在次要活动中是否必不可少。