2015-11-20 3 views
0

Это мой первый вопрос. Клянусь, что я много исследовал и много пробовал, но без результата, и я немного разочарован результатами и ошибками. :)Share Navigation Drawer with Other Activity (Advanced)

Я создал проект ящика навигации в Android Studio, и теперь я пытаюсь открыть меню (MainActivity) с другими действиями.

Мой MainActivity:

package br.com.pmarx.ihamster; 

import android.content.Intent; 
import android.os.Bundle; 
import android.support.design.widget.FloatingActionButton; 
import android.support.design.widget.Snackbar; 
import android.view.View; 
import android.support.design.widget.NavigationView; 
import android.support.v4.view.GravityCompat; 
import android.support.v4.widget.DrawerLayout; 
import android.support.v7.app.ActionBarDrawerToggle; 
import android.support.v7.app.AppCompatActivity; 
import android.support.v7.widget.Toolbar; 
import android.view.Menu; 
import android.view.MenuItem; 
import android.support.design.widget.NavigationView.OnNavigationItemSelectedListener; 

public class MainActivity extends AppCompatActivity { 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
    Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); 
    setSupportActionBar(toolbar); 

    FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab); 
    fab.setOnClickListener(new View.OnClickListener() { 
     @Override 
     public void onClick(View view) { 
      Snackbar.make(view, "Replace with your own action", Snackbar.LENGTH_LONG) 
        .setAction("Action", null).show(); 
     } 
    }); 

    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
      this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close); 
    drawer.setDrawerListener(toggle); 
    toggle.syncState(); 

    NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view); 
    navigationView.setNavigationItemSelectedListener(menuItemListener); 
} 

@Override 
public void onBackPressed() { 
    DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
    if (drawer.isDrawerOpen(GravityCompat.START)) { 
     drawer.closeDrawer(GravityCompat.START); 
    } else { 
     super.onBackPressed(); 
    } 
} 

@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; 
} 

@Override 
public boolean onOptionsItemSelected(MenuItem item) { 
    // Handle action bar item clicks here. The action bar will 
    // automatically handle clicks on the Home/Up button, so long 
    // as you specify a parent activity in AndroidManifest.xml. 
    int id = item.getItemId(); 

    //noinspection SimplifiableIfStatement 
    if (id == R.id.action_settings) { 
     return true; 
    } 

    return super.onOptionsItemSelected(item); 
} 

@SuppressWarnings("StatementWithEmptyBody") 
private OnNavigationItemSelectedListener menuItemListener = new OnNavigationItemSelectedListener() { 

    @Override 
    public boolean onNavigationItemSelected(MenuItem item) { 
     // Handle navigation view item clicks here. 
     int id = item.getItemId(); 

     if (id == R.id.my_larder_general_activity) { 
      Intent myLarderViewActivity = new Intent(getApplicationContext(), MyLarderGeneralActivity.class); 
      startActivity(myLarderViewActivity); 
     } else if (id == R.id.my_plan_activity) { 
      Intent myPlanActivity = new Intent(getApplicationContext(), MyPlanActivity.class); 
      startActivity(myPlanActivity); 
     } else if (id == R.id.ins_item_larder) { 
      Intent insItemLarderActivity = new Intent(getApplicationContext(), InsItemLarderActivity.class); 
      startActivity(insItemLarderActivity); 
     } else if (id == R.id.ins_item_plan) { 
      Intent insItemPlanActivity = new Intent(getApplicationContext(), InsItemPlanActivity.class); 
      startActivity(insItemPlanActivity); 
     } else if (id == R.id.my_larder_kept_activity) { 
      Intent myLarderKeptActivity = new Intent(getApplicationContext(), MyLarderKeptActivity.class); 
      startActivity(myLarderKeptActivity); 
     } else if (id == R.id.my_larder_use_activity) { 
      Intent myLarderUseActivity = new Intent(getApplicationContext(), MyLarderUseActivity.class); 
      startActivity(myLarderUseActivity); 
     } else if (id == R.id.my_shopping_list_activity) { 
      Intent myShoppingListActivity = new Intent(getApplicationContext(), MyShoppingListActivity.class); 
      startActivity(myShoppingListActivity); 
     //Populando a Database Daqui 
     } else if (id == R.id.database_populate) { 
      DatabaseDAO crud = new DatabaseDAO(getBaseContext()); 
      crud.popularDatabase(); 
     //Populando a Database Até Aqui 
     } else if (id == R.id.nav_share) { 

     } else if (id == R.id.nav_send) { 

     } 

     DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout); 
     drawer.closeDrawer(GravityCompat.START); 
     return true; 

    } 

}; 
} 

Моя новая деятельность по продлению MainActivity (и меню):

package br.com.pmarx.ihamster; 

import android.content.Intent; 
import android.database.Cursor; 
import android.os.Bundle; 
import android.support.v7.app.AppCompatActivity; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ListView; 
import android.widget.SimpleCursorAdapter; 

public class MyShoppingListActivity extends MainActivity { 

private ListView listItem; 
private CreateDatabase database; 

@Override 
protected void onCreate(Bundle savedInstanceState) { 

    super.onCreate(savedInstanceState); 
    setContentView(R.layout.my_plan); 

    listItem = (ListView)findViewById(R.id.listView); 
    listItem.setOnItemClickListener(listItemListener); 

}; 

@Override 
protected void onResume() { 

    super.onResume(); 

    DatabaseDAO crud = new DatabaseDAO(getBaseContext()); 
    Cursor cursor = crud.loadShoppingList(); 

    String[] fieldNames = new String[] {database.PROD_NOME, "volume3"}; 
    int[] idViews = new int[] {R.id.tvProd, R.id.tvVolum}; 

    SimpleCursorAdapter adapter = new SimpleCursorAdapter(getBaseContext(), R.layout.sel_item_plan, cursor, fieldNames, idViews, 0); 

    listItem = (ListView)findViewById(R.id.listView); 
    listItem.setAdapter(adapter); 

}; 

private OnItemClickListener listItemListener = new OnItemClickListener(){ 

    @Override 
    public void onItemClick(AdapterView<?> parent, View view, int position, long id){ 

     //Passando parametro para a outra tela 
     Intent insertItemActivity = new Intent(getBaseContext(), InsItemLarderActivity.class); 
     insertItemActivity.putExtra("PROD_ID", String.valueOf(id)); 
     startActivity(insertItemActivity); 


    } 

}; 

} 

Первый, я получаю ошибку «Эта активность уже имеет панель действий, поставляемых оконный декор ". Таким образом, я изменил стиль так:

<!-- Base application theme. --> 
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar"> 
    <!-- Customize your theme here. --> 
    <item name="colorPrimary">@color/colorPrimary</item> 
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item> 
    <item name="colorAccent">@color/colorAccent</item> 
    <item name="windowActionBar">false</item> 
    <item name="windowNoTitle">true</item> 
</style> 
<style name="AppTheme.NoActionBar"> 
    <item name="windowActionBar">false</item> 
    <item name="windowNoTitle">true</item> 
</style> 
<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" /> 
<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" /> 

Мой activity_main.xml

<?xml version="1.0" encoding="utf-8"?> 
<android.support.v4.widget.DrawerLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:app="http://schemas.android.com/apk/res-auto" 
xmlns:tools="http://schemas.android.com/tools" 
android:id="@+id/drawer_layout" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:fitsSystemWindows="true" 
tools:openDrawer="start"> 

<include layout="@layout/app_bar_main" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" /> 
<android.support.design.widget.NavigationView 
    android:id="@+id/nav_view" 
    android:layout_width="wrap_content" 
    android:layout_height="match_parent" 
    android:layout_gravity="start" 
    android:fitsSystemWindows="true" 
    app:headerLayout="@layout/nav_header_main" 
    app:menu="@menu/activity_main_drawer" /> 
</android.support.v4.widget.DrawerLayout> 

Мой app_bar_main.xml

<android.support.design.widget.CoordinatorLayout 
    xmlns:android="http://schemas.android.com/apk/res/android" 
    xmlns:app="http://schemas.android.com/apk/res-auto" 
    xmlns:tools="http://schemas.android.com/tools" 
    android:layout_width="match_parent" 
    android:layout_height="match_parent" 
    android:fitsSystemWindows="true" 
    tools:context=".MainActivity"> 
    <android.support.design.widget.AppBarLayout 
     android:layout_height="wrap_content" 
     android:layout_width="match_parent" 
     android:theme="@style/AppTheme.AppBarOverlay"> 
     <android.support.v7.widget.Toolbar 
      android:id="@+id/toolbar" 
      android:layout_width="match_parent" 
      android:layout_height="?attr/actionBarSize" 
      android:background="?attr/colorPrimary" 
      app:popupTheme="@style/AppTheme.PopupOverlay" /> 

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

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

<android.support.design.widget.FloatingActionButton 
    android:id="@+id/fab" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_gravity="bottom|end" 
    android:layout_margin="@dimen/fab_margin" 
    android:src="@android:drawable/ic_dialog_email" /> 
</android.support.design.widget.CoordinatorLayout> 

Мой my_plan

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:layout_width="match_parent" 
android:layout_height="match_parent" 
android:orientation="vertical" 
android:background="#fdb46d" 
android:weightSum="1"> 

<GridLayout 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:rowCount="1" 
    android:columnCount="4" 
    android:layout_gravity="center_horizontal"> 

</GridLayout> 

<include 
    android:id="@+id/toolbar" 
    layout="@layout/activity_main" /> 

<ListView 
    android:layout_width="match_parent" 
    android:layout_height="wrap_content" 
    android:id="@+id/listView" 
    android:layout_alignParentLeft="true" 
    android:layout_alignParentStart="true" 
    android:choiceMode="singleChoice" 
    android:clickable="false" 
    android:contextClickable="false" /> 

</LinearLayout> 

Но, я начал получать ошибку «java.lang.NullPointerException: попытка вызвать виртуальный метод 'булево android.support.v4.widget.DrawerLayout.isDrawerOpen (INT)' под null ссылка на объект ".

После некоторых изменений, теперь я получаю сообщение об ошибке «java.lang.NullPointerException: попытка вызвать виртуальный метод» java.lang.CharSequence android.support.v7.widget.Toolbar.getTitle() »в ссылке на нулевой объект "

Давайте сделаем это вместе, шаг за шагом. Я действительно застрял в этом.

Спасибо, продвинутый!

+0

Я удалил «public void onBackPressed()» mehod из MainActivity, и NullPointer остановился, но меню не отображается в новом действии. Извините за мой плохой английский. –

+0

ОК 1) Я нахожу это намного проще в использовании для создания навигационного ящика: https://github.com/mikepenz/MaterialDrawer 2) вы получаете ошибку, скорее всего, потому что MyShoppingListActivity переопределяет 'setContentView()', что означает, что нет DrawerLayout , следовательно, оно действительно является нулевым. Похоже, вы должны попробовать и погрузиться в использование фрагментов, поскольку это более естественная подгонка для навигационного ящика (1 Активность с выдвижным ящиком, упорядочивающим набор фрагментов) – cYrixmorten

+0

Я добавляю более подробную информацию, чтобы помочь вам помочь. Благодаря! –

ответ

0

Когда MyShoppingListActivity запускается

Во-первых, OnCreate метод вызывается и эта строка будет выполнена.

super.onCreate(savedInstanceState); 

Что вызывает метод OnCreate родительского класса, который является OnCreate метод MainActivity.

So setContentView(R.layout.activity_main); выполнен в супервызове.

Затем setContentView(R.layout.my_plan) выполняются, который установлен макет будет R.layout.my_plan

Так Toolbar линия находки возвратит нуль, если вы не имеете панели инструментов с идентификатором R.id.toolbar, определенным в файле R.layout.my_plan XML.

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

Решение будет создавать BaseActivity без макета, не вызывая метод setContentView (...). Поместите все настройки кода Views в if(findViewById(id)!= null){...} блоков.

И затем определите Виджеты в вашем файле layout.xml ActionScript для вашего подкласса с тем же идентификатором.

+0

Теперь я получаю сообщение об ошибке java.lang.RuntimeException: Невозможно запустить Activity ComponentInfo {br.com.pmarx.ihamster/br.com.pmarx.ihamster.MyShoppingListActivity}: java.lang.NullPointerException: попытка вызвать виртуальный метод 'java .lang.CharSequence android.support.v7.widget.Toolbar.getTitle() 'на ссылке нулевого объекта –

+0

Я добавляю больше деталей, чтобы помочь вам помочь. Благодаря! –