2016-06-12 2 views
1

Это мой первый Android-проект. Мне нужно создать скользящее меню для запуска разных страниц. Затем я обнаружил, что в Android Studio 1.4 по умолчанию используется «Ящик навигации» для использования. Here is the default imageКак использовать Android NavigationDrawer для создания других фрагментов?

Так что я хочу нажимать на разные предметы, чтобы начинать разные фрагменты (я думаю, что это фрагменты, а не действия). Как добавить код для запуска?

`Я думаю, что я должен добавить код здесь

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

    if (id == R.id.nav_camara) { 
     // Handle the camera action 
    } else if (id == R.id.nav_gallery) { 

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

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

    } 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 com.ad_imagine.navigationdrawer2; 

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; 

public class Main2Activity extends AppCompatActivity 
    implements NavigationView.OnNavigationItemSelectedListener { 

@Override 
protected void onCreate(Bundle savedInstanceState) { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main2); 
    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(this); 
} 

@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.main2, 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") 
@Override 
public boolean onNavigationItemSelected(MenuItem item) { 
    // Handle navigation view item clicks here. 
    int id = item.getItemId(); 

    if (id == R.id.nav_camara) { 
     // Handle the camera action 
    } else if (id == R.id.nav_gallery) { 

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

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

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

Вот основной макет:

<include layout="@layout/app_bar_main2" 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_main2"  app:menu="@menu/activity_main2_drawer" /> 

ответ

0

Вы на правильном пути, вот как я это делаю (пример только одного фрагмента, другие - то же самое).

case R.id.nav_feedback: handleFeedback(); 
        break; 

Мне нравятся методы, которые четко показывают по их названию, что они делают; также я пытаюсь делегировать некоторые вещи в частные методы, чтобы очистить мой код. На этот пункт щелкнул, нам нужно обрабатывать обратную связь, и этот метод выглядит следующим образом:

private void handleFeedback() { 
    changeToFragment(FeedbackFragment.newInstance()); 
    try { 
     getSupportActionBar().setTitle(R.string.feedback); 
    } catch (NullPointerException e) { 
     e.printStackTrace(); 
    } 
} 

Теперь есть метод, называемый changeToFragment, должно быть очевидно, что она делает:

private void changeToFragment(Fragment fragment){ 
    FragmentManager fragmentManager = getSupportFragmentManager(); 
    fragmentManager.beginTransaction() 
      .replace(R.id.content_navigation_drawer, fragment) 
      .commit(); 
} 

Конечно, есть класс Фрагмент называется FeedbackFragment, и быть уверенным, что вы либо использование android.app.FragmentиgetFragmentManager или android.support.v4.app.FragmentиgetSupportFragmentManager. НЕ СМЕШАТЬ эти, иначе у вас будет плохое время. Обратитесь к this question, чтобы узнать их различия и какой из них вы хотите использовать. Я лично выбрал тот из библиотеки поддержки.

Я оставлю это для вас, чтобы реализовать классы фрагментов, я надеюсь, что этот код был понятен для вас.

+0

спасибо, вы талантливы, и это очень полезно для меня! Но у меня есть проблема, когда я использую 'replace (R.id.content_navigation_drawer, фрагмент)', в 'фрагменте', он также отображает макет' content_navigation_drawer' –

+0

Что вы имеете в виду? Он показывает как фрагмент, так и 'content_navigation_drawer'? – Vucko

+0

в 'content_navigation_drawer', есть« TextView », а текст« content1 », в« фрагменте », есть« TextView », а текст« content2 ». При первом запуске приложения он показывает« content1 », но когда я нажимаю элемент, он показывает «content1» и «content2» на той же странице. –