Androidプロジェクトに取り組んでおり、 http://developer.Android.com/training/implementing-navigationの例を使用して、新しいNavigation Drawerを統合しようとしています。 /nav-drawer.html 。
アクションバーのアップボタンにはメニューが表示されませんが、Edgeからメインアクティビティ画面上で指をスワイプするとメニューが表示されるため、実際のメニューに問題はないことがわかります。 、そのアクションバーボタンだけです。
以下はコードです
public class MainActivity extends Activity {
private DrawerLayout mDrawerLayout;
private ListView mDrawerList;
private ActionBarDrawerToggle mDrawerToggle;
private CharSequence mTitle;
private CharSequence mDrawerTitle;
private String[] mPlanetTitles;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mTitle = mDrawerTitle = getTitle();
mPlanetTitles = getResources().getStringArray(R.array.planets_array);
mDrawerLayout = (DrawerLayout)findViewById(R.id.drawer_layout);
mDrawerList = (ListView)findViewById(R.id.left_drawer);
MenuItemAdapter menuAdapter = new MenuItemAdapter(this);
menuAdapter.add(new MenuItem("Hello"));
menuAdapter.add(new MenuItem("World"));
menuAdapter.add(new MenuItem("Parsnips"));
menuAdapter.add(new MenuItem("Turnips"));
mDrawerList.setAdapter(menuAdapter);
mDrawerList.setOnItemClickListener(new DrawerItemClickListener());
getActionBar().setDisplayHomeAsUpEnabled(true);
getActionBar().setHomeButtonEnabled(true);
mDrawerToggle = new ActionBarDrawerToggle(
this,
mDrawerLayout,
R.drawable.ic_drawer,
R.string.drawer_open,
R.string.drawer_closed)
{
public void onDrawerClosed(View view)
{
getActionBar().setTitle(mTitle);
invalidateOptionsMenu();
}
public void onDrawerOpened(View drawerView)
{
getActionBar().setTitle(mDrawerTitle);
invalidateOptionsMenu();
}
};
mDrawerLayout.setDrawerListener(mDrawerToggle);
if (savedInstanceState == null)
{
selectItem(0);
}
}
@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;
}
private class DrawerItemClickListener implements ListView.OnItemClickListener {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
selectItem(position);
}
}
private void selectItem(int position) {
// update the main content by replacing fragments
Android.app.Fragment fragment = new PlanetFragment();
Bundle args = new Bundle();
args.putInt(PlanetFragment.ARGS_PLANET_NUMBER, position);
fragment.setArguments(args);
Android.app.FragmentManager fragmentManager = getFragmentManager();
fragmentManager.beginTransaction().replace(R.id.content_frame, fragment).commit();
mDrawerList.setItemChecked(position, true);
setTitle(mPlanetTitles[position]);
mDrawerLayout.closeDrawer(mDrawerList);
}
@Override
public void setTitle(CharSequence title)
{
mTitle = title;
getActionBar().setTitle(mTitle);
}
@Override
protected void onPostCreate(Bundle savedInstanceState)
{
super.onPostCreate(savedInstanceState);
mDrawerToggle.syncState();
}
@Override
public void onConfigurationChanged(Configuration newConfig)
{
super.onConfigurationChanged(newConfig);
mDrawerToggle.onConfigurationChanged(newConfig);
}
public static class PlanetFragment extends Android.app.Fragment
{
public static final String ARGS_PLANET_NUMBER = "planet_number";
public PlanetFragment()
{
}
@Override
public View onCreateView(LayoutInflater inflator, ViewGroup container, Bundle savedInstanceState)
{
View rootView = inflator.inflate(R.layout.fragment_planet, container, false);
int i = getArguments().getInt(ARGS_PLANET_NUMBER);
String planet = getResources().getStringArray(R.array.planets_array)[i];
//((TextView)rootView.findViewById(R.id.fragment_text_view)).setText(planet);
getActivity().setTitle("Planet: " + planet);
return rootView;
}
}
private class MenuItem
{
public String menuName;
public MenuItem(String menuName)
{
this.menuName = menuName;
}
}
public class MenuItemAdapter extends ArrayAdapter<MenuItem>
{
public MenuItemAdapter (Context context)
{
super(context,0);
}
public View getView (int position, View convertView, ViewGroup parent)
{
convertView = null;
if (convertView == null)
{
convertView = LayoutInflater.from(getContext()).inflate(R.layout.row_menu_item, null);
}
/*TextView title = (TextView)convertView.findViewById(R.id.row_title);
title.setText(getItem(position).menuName);
title.setVisibility(View.VISIBLE);*/
EditText title = (EditText)convertView.findViewById(R.id.row_edittext);
title.setHint(getItem(position).menuName);
title.setVisibility(View.VISIBLE);
return convertView;
}
}
}
あなたが提供できる助けをありがとう。
OnOptionsItemSelectedの実装を忘れました
これは魔法が起こる場所です:
@Override
public boolean onOptionsItemSelected(MenuItem item) {
// Pass the event to ActionBarDrawerToggle, if it returns
// true, then it has handled the app icon touch event
if (mDrawerToggle.onOptionsItemSelected(item)) {
return true;
}
// Handle your other action bar items...
return super.onOptionsItemSelected(item);
}
まだ問題がある場合は、このメソッドが欠落している可能性があります(OPにはありますが、削除しました)。
@Override
protected void onPostCreate(Bundle savedInstanceState) {
super.onPostCreate(savedInstanceState);
mDrawerToggle.syncState();
}
私の仕事。
drawerToggle.setToolbarNavigationClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mDrawer.openDrawer(GravityCompat.START);
}
});
ここで、Androidスタジオを使用せずにAndroidでドロワーナビゲーションを作成する簡単で簡単な方法を説明します。ADTを使用してナビゲーションドロワーを作成しました。コードを見てみましょう
activity_main.xml
<Android.support.v4.widget.DrawerLayout
xmlns:Android="http://schemas.Android.com/apk/res/Android"
Android:id="@+id/dr_layout"
Android:layout_width="match_parent"
Android:layout_height="match_parent">
<RelativeLayout
Android:id="@+id/mainContent"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content">
<TextView
Android:id="@+id/txt1"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:text="swipe content"/>
<Button
Android:id="@+id/bt1"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:text = "Click to open d"/>
</RelativeLayout>
<RelativeLayout
Android:id="@+id/drawer"
Android:layout_width="200dp"
Android:layout_height="match_parent"
Android:layout_gravity = "start"
Android:background="#FFFFFF">
<TextView
Android:id="@+id/txt2"
Android:layout_width="200dp"
Android:layout_height="wrap_content"
Android:text="drawer content are here arr"/>
<Button
Android:id="@+id/bt2"
Android:layout_width="wrap_content"
Android:layout_height="wrap_content"
Android:text = "Click to open d"/>
</RelativeLayout>
</Android.support.v4.widget.DrawerLayout>
MainActivity.Java
package com.example.drawer1;
import Android.os.Bundle;
import Android.annotation.SuppressLint;
import Android.app.Activity;
import Android.content.res.Configuration;
import Android.support.v4.app.ActionBarDrawerToggle;
import Android.support.v4.widget.DrawerLayout;
import Android.support.v4.widget.DrawerLayout.DrawerListener;
import Android.util.Log;
import Android.view.Menu;
import Android.view.MenuItem;
import Android.view.MotionEvent;
import Android.view.View;
import Android.view.View.OnClickListener;
import Android.view.View.OnTouchListener;
import Android.widget.Button;
import Android.widget.Toast;
public class MainActivity extends Activity {
private DrawerLayout drawerLayout;
private View drawerView;
Button bt1,bt2;
private DrawerListener myDrawerListner;
private ActionBarDrawerToggle mDrawerTogle;
@SuppressLint("NewApi")
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
drawerLayout = (DrawerLayout) findViewById(R.id.dr_layout);
drawerView = (View) findViewById(R.id.drawer);
drawerLayout.setDrawerListener(myDrawerListner);
bt1 = (Button) findViewById(R.id.bt1);
bt2 = (Button) findViewById(R.id.bt2);
mDrawerTogle =new ActionBarDrawerToggle(this, drawerLayout,
R.drawable.ic_drawer,R.string.open_drawer,R.string.close_drawer){
public void onDrawerOpened(View drawerView) {
// TODO Auto-generated method stub
super.onDrawerOpened(drawerView);
getActionBar().setTitle("SpeakEng");
}
public void onDrawerClosed(View view) {
// TODO Auto-generated method stub
super.onDrawerClosed(view);
getActionBar().setTitle("SpeakEng");
}
};
drawerLayout.setDrawerListener(mDrawerTogle);
getActionBar().setDisplayHomeAsUpEnabled(true);
getActionBar().setHomeButtonEnabled(true);
bt2.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
drawerLayout.closeDrawer(drawerView);
}
});
bt1.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View arg0) {
// TODO Auto-generated method stub
drawerLayout.openDrawer(drawerView);
}
});
}
@Override
public void onConfigurationChanged(Configuration newConfig){
super.onConfigurationChanged(newConfig);
mDrawerTogle.onConfigurationChanged(newConfig);
}
public boolean onOptionsItemSelected(MenuItem item){
if (mDrawerTogle.onOptionsItemSelected(item)){
return true;
}
return super.onOptionsItemSelected(item);
}
@Override
protected void onPostCreate(Bundle savedInstanceState){
super.onPostCreate(savedInstanceState);
//Sync the toogle state after onRestoreInstanceState has occured.
mDrawerTogle.syncState();
}
}
引き出しを開くには、1)ボタンをクリックする、2)左から引っ張る、3)アクションバーの引き出しアイコンをクリックします。必要に応じて開くことができます。3つのオプションがあります。
注:drawerLayoutは、コードに示すようにルート要素である必要があります。 onConfigurationChanged()、onOptionsItemSelected()、onPostCreate()を保持します。この3つの方法は、ナビゲーションドロワーを作成するために非常に重要です。
幸運を!.