工具栏后退按钮错误Android

时间:2017-12-26 06:13:29

标签: java android android-studio nullreferenceexception android-toolbar

我想在我创建的工具栏中添加一个“后退”按钮,因为我删除了默认的按钮以使用一些选项卡获得材质设计效果,但每次我添加代码以显示该按钮时,Android会给出例外说法这样:

E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.juan.sdfnsdfnskdfnskdfmsfd, PID: 13348
java.lang.NullPointerException: Attempt to invoke virtual method 'int android.support.v4.widget.DrawerLayout.getDrawerLockMode(int)' on a null object reference
at android.support.v7.app.ActionBarDrawerToggle.toggle(ActionBarDrawerToggle.java:284)
at android.support.v7.app.ActionBarDrawerToggle$1.onClick(ActionBarDrawerToggle.java:202)
at android.view.View.performClick(View.java:6308)
at android.view.View$PerformClick.run(View.java:23969)
at android.os.Handler.handleCallback(Handler.java:751)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6823)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1557)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1445)

如果我只在我创建的工具栏中编写相应的代码,我不明白使用null对象引用意味着什么。

这是toolbar.xml:

<android.support.v7.widget.Toolbar xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/toolbar_morado"
android:id="@+id/toolbar_lista_compras"
android:minHeight="?attr/actionBarSize">

<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content">

<TextView
    android:id="@+id/contador_toolbar"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:text="Lista de compras"
    android:textSize="18sp"
    android:textColor="#ffffff"/>

</RelativeLayout>

</android.support.v7.widget.Toolbar>

这是我实现工具栏的地方:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">

    <android.support.design.widget.AppBarLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        android:id="@+id/appBarLayoutCalcular">

        <include layout="@layout/toolbar"></include>

        <android.support.design.widget.TabLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:id="@+id/tablayoutCalcular"
            app:tabGravity="fill"
            app:tabMode="fixed"
            android:background="@color/toolbar_anaranjado"
            app:tabTextAppearance="@style/myTabSize"
            app:tabIndicatorColor="#5c1be1"/>

    </android.support.design.widget.AppBarLayout>

    <android.support.v4.view.ViewPager
        android:id="@+id/viewPagerCalcular"
        android:layout_width="match_parent"
        android:layout_height="match_parent" />

</LinearLayout>

这是我的班级:

public class CalculateMaterials extends AppCompatActivity{

DrawerLayout drawerLayout;
ActionBarDrawerToggle actionBarDrawerToggle;
Toolbar toolbar;
NavigationView navigationView;
TabLayout tabLayout;
ViewPager viewPager;
ViewPagerAdapter viewPagerAdapter;
String tabSeleccionado;

@Override
protected void onCreate(@Nullable Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.calcular_materiales);

    toolbar = (Toolbar)findViewById(R.id.toolbar_shopping_list);
    toolbar.setBackgroundColor(ContextCompat.getColor(getApplicationContext(), R.color.toolbar_anaranjado));
    setSupportActionBar(toolbar);

    // text for the toolbar
    TextView textoToolbar = (TextView)findViewById(R.id.contador_toolbar);
    textoToolbar.setText("Calcular los materiales");

    // status bar color
    if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.LOLLIPOP) {

        getWindow().setStatusBarColor(ContextCompat.getColor(getApplicationContext(), R.color.statusBar_anaranjado));

    }


    // adding toolbar back button
    // this is where I have the error 
    if (toolbar != null) {
        toolbar.setNavigationIcon(R.drawable.backButton);
        toolbar.setNavigationOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                onBackPressed();
            }
        });
    }

    drawerLayout = (DrawerLayout)findViewById(R.id.drawer_layout);

    actionBarDrawerToggle = new ActionBarDrawerToggle(this, drawerLayout, toolbar, R.string.drawer_open, R.string.drawer_close);

    navigationView = (NavigationView)findViewById(R.id.navigationView);

    tabLayout = (TabLayout)findViewById(R.id.tablayoutCalcular);

    viewPager = (ViewPager)findViewById(R.id.viewPagerCalcular);

    // adding the tabs
    viewPagerAdapter = new ViewPagerAdapter(getSupportFragmentManager());
    viewPagerAdapter.addFragments(new FragmentCalcular(), "Con area");
    viewPagerAdapter.addFragments(new FragmentCalcular2(), "Con metros");

    viewPager.setAdapter(viewPagerAdapter);

    tabLayout.setupWithViewPager(viewPager);

我也尝试:

// add back arrow to toolbar
if (getSupportActionBar() != null){
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);
    getSupportActionBar().setDisplayShowHomeEnabled(true);
}

这也会产生同样的错误。

那么,任何人都可以帮我解决这个问题吗?

修改

感谢所有试图帮助我解决这个问题的人。我终于找到了错误。

前段时间,我尝试在所有活动中添加一个navigationView,但是我忘了在课堂上删除必要的代码,这就是为什么drawerLayout没有出现在xml中。

所以,当我删除drawerLayout变量时,一切正常!

6 个答案:

答案 0 :(得分:3)

试试这个

    toolbar = (Toolbar) findViewById(R.id.toolbar);
    setSupportActionBar(toolbar);

    getSupportActionBar().setDisplayHomeAsUpEnabled(true);
    toolbar.setNavigationOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            onBackPressed();
        }
    });

答案 1 :(得分:0)

试试这个。

   toolbar = (Toolbar) findViewById(R.id.toolbar_editprofile);
    setSupportActionBar(toolbar);
    getSupportActionBar().setDisplayShowTitleEnabled(false):
    toolbar.setNavigationIcon(getResources().getDrawable(R.drawable.back_arrow));
    toolbar.setNavigationOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            finish();
        }
    });

答案 2 :(得分:0)

似乎drawerLayout是null。我无法在XML中找到您的“drawer_layout”。

确保您在findViewById(R.id.drawer_layout)和布局文件中为导航栏使用相同的ID。

答案 3 :(得分:0)

首先,你的DrawerLayout在哪里?我无法从您的问题中找到它,可能是您忘记发布或尚未创建。

确保您必须为ID声明正确的DrawerLayout,因此请检查drawerLayout = (DrawerLayout)findViewById(R.id.drawer_layout);的{​​{1}}

错误行:我在此行中发现错误可能这不是您的答案,但应该纠正您

drawer_layout.xml

试一下

TextView textoToolbar = (TextView)findViewById(R.id.contador_toolbar);

答案 4 :(得分:0)

在onCreate方法中粘贴:

 @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity);

     Toolbar   toolbar = (Toolbar) findViewById(R.id.toolBarGig);
        setSupportActionBar(toolbar);
        getSupportActionBar().setDisplayHomeAsUpEnabled(true);
        getSupportActionBar().setDisplayShowHomeEnabled(true);
        getSupportActionBar().setDisplayShowTitleEnabled(false);

之后你必须覆盖方法: -

@Override
    public boolean onSupportNavigateUp() {
        onBackPressed();
        return true;
    }

试试这个。希望它能帮到你!

答案 5 :(得分:0)

  

首先初始化后退按钮的工具栏栏

 Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
            setSupportActionBar(toolbar);
          getSupportActionBar().setDisplayHomeAsUpEnabled(true);
  

然后回调按钮方法这段代码就足够了以前   其他你可以在onBackPressed方法中使用intent方法   回去

//后退按钮上的方法单击

@Override
public void onBackPressed() {

    super.onBackPressed();

/*OR
  Intent forgot_password = new Intent( AddItemActivity.this,  HomeActivity.class);
                startActivity(forgot_password);
                finish();
        }*/
  

后退按钮点击功能

 @Override
  public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
        case android.R.id.home:
            onBackPressed();

            return true;

        default:
            return super.onOptionsItemSelected(item);
    }
}