2016-09-27 6 views
3

私はアイテムのアイコンを入れようとしているときにナビゲーション用の引き出しを使用しているアプリを開発しています。このようなイメージのパスが表示されます: " res/drawale/bg.jpg "と入力します。私はそれをどうやって行うのか分からない。以下はナビゲーションドロワーのアイテムにアイコンを付ける方法

が主な活動のために私のコードです:次に

app:menu="@menu/drawer_menu_icons" 

:ここ

private void init_navigator() { 
    // Navigation Drawer 
    mTitle = mDrawerTitle = getTitle(); 

    mDrawerLayout = (DrawerLayout) findViewById(R.id.main_activity_DrawerLayout); 
    mDrawerLayout.setStatusBarBackgroundColor(getResources().getColor(R.color.primaryDark)); 
    mScrimInsetsFrameLayout = (ScrimInsetsFrameLayout) findViewById(R.id.main_activity_navigation_drawer_rootLayout); 
    mDrawerList = (ListView) findViewById(R.id.left_drawer); 
    mDrawerItmes = getResources().getStringArray(R.array.drawer_titles); 
    mDrawerItmes = getResources().getStringArray(R.array.nav_drawer_icons); 

は、XMLでstring.xmlを

ごnavigationviewで
<string-array name="drawer_titles"> 
    <item>About Us</item> 
    <item>FeedBack</item> 
    <item>Setting</item> 
    <item>Share App</item> 
    <item>Rate Us</item> 
    <item>Logout</item> 
</string-array> 

<array name="nav_drawer_icons"> 
    <item>@drawable/bg</item> 
    <item>@drawable/bg</item> 
    <item>@drawable/bg</item> 
    <item>@drawable/bg</item> 
    <item>@drawable/b</item> 
    <item>@drawable/bg</item> 

</array> 
+1

を探しているまさにあり、この方法に従うことをしてみてくださいナビゲーションビューを使用している場合、[タイトルとアイコン付き]メニューを簡単に作成して、メニューを膨らませることができます彼はXML属性としてナビゲーションビューを表示しています もっと明確にするためにhttp://www.technotalkative.com/part-4-playing-with-navigationview/を参照してください。 –

+0

ここにどのようにすればいいですか..あなたにはどんなアイデアもあります – user6798766

+0

DrawerLayoutメニューを保持するホルダーを意味する。明示的にナビゲーションビュー(メニュー)をxmlに追加し、そこからメニューを膨張させる必要があります –

答えて

3

のための私のコードは、これを追加することですメニューフォルダにdrawer_menu_iconsという新しいxmlを作成し、これを実行します:

<?xml version="1.0" encoding="utf-8"?> 
<menu xmlns:android="http://schemas.android.com/apk/res/android"> 

    <group 
     android:id="@+id/homegroup" 
     android:checkableBehavior="single"> 
     <item 
      android:id="@+id/nav_home" 
      android:icon="@drawable/homeicon" 
      android:title="Main screen" /> 
     <item 
      android:id="@+id/nav_branches" 
      android:icon="@drawable/backspace" 
      android:title="Branch selection" /> 

    </group> 
</menu> 

そして、あなたが好きなアイコンを追加:)

0

をただ、これがあなたならば、あなたが

http://www.journaldev.com/9958/android-navigation-drawer-example-tutorial

http://www.androidhive.info/2013/11/android-sliding-menu-using-navigation-drawer/

public class DrawerItemCustomAdapter extends ArrayAdapter<DataModel> { 

    Context mContext; 
    int layoutResourceId; 
    DataModel data[] = null; 

    public DrawerItemCustomAdapter(Context mContext, int layoutResourceId, DataModel[] data) { 

     super(mContext, layoutResourceId, data); 
     this.layoutResourceId = layoutResourceId; 
     this.mContext = mContext; 
     this.data = data; 
    } 

    @Override 
    public View getView(int position, View convertView, ViewGroup parent) { 

     View listItem = convertView; 

     LayoutInflater inflater = ((Activity) mContext).getLayoutInflater(); 
     listItem = inflater.inflate(layoutResourceId, parent, false); 

     ImageView imageViewIcon = (ImageView) listItem.findViewById(R.id.imageViewIcon); 
     TextView textViewName = (TextView) listItem.findViewById(R.id.textViewName); 

     DataModel folder = data[position]; 


     imageViewIcon.setImageResource(folder.icon); 
     textViewName.setText(folder.name); 

     return listItem; 
    } 
}