6

こんにちは私はアンドロイドアプリケーションを開発しています。私のアプリケーションでは、ActionBarSherlock を使用しています。次の方法で、アクション バーにいくつかのメニュー項目を定義しました。

<menu xmlns:android="http://schemas.android.com/apk/res/android">
 <item android:id="@+id/card_menu"
     android:title="cards" 
     android:showAsAction="always"
     android:actionLayout="@layout/action_button"
  >
         <menu>
             <item android:id="@+id/C1"
              android:title="C1" />
             <item android:id="@+id/C2"
              android:title="c2" />
             <item android:id="@+id/C3"
               android:title="C3" />
         </menu>
 </item>
<item android:id="@+id/notification"
      android:title="Notifications"
      android:showAsAction="always"
      android:actionLayout="@layout/notification_icon"
      android:icon="@drawable/notification"
 />

<item android:id="@+id/filter"
      android:icon="@drawable/filter"
      android:title="Filter" 
      android:showAsAction="always"
 />

これで、すべてが非常にうまく表示されましたが、私の問題は、サブメニューを定義し、アクションレイアウトも定義する card_menu アイテムをクリックしたときです。これらのサブメニューは表示されません。
他のメニュー項目は正常に機能しています。その時点でサブ メニューを含む項目のアクション レイアウトを定義した場合にのみ、サブ メニューを表示できません。
アクションレイアウトを削除すると、正常に機能します...

アイテムのアクション レイアウトを定義する場合、クリック リスナーを手動で処理する必要があることはわかっています。私は次の方法でそれを行いました:

final MenuItem item = menu.findItem(R.id.card_menu);
        item.getActionView().setOnClickListener(new OnClickListener() {
        @Override
        public void onClick(View v) {
            onOptionsItemSelected(item);
            Toast.makeText(getActivity(), "click on menu", Toast.LENGTH_SHORT).show();
        }
        });

その項目のクリック イベントは処理できますが、ドロップダウン サブ メニュー項目を表示できません。

この問題を解決するには?サブメニューを開くにはどうすればよいですか?

助けが必要です....ありがとうございます...

4

1 に答える 1

0

同様の問題があり、アクションバー内のスピナーを使用してトリックで解決しました。したがって、res/menu のアクションバーの私のレイアウトは次のとおりです (action_share が重要です)。

<item android:id="@+id/action_share"
    android:showAsAction="always"
    android:actionLayout="@layout/actionbar_spinner_export" />

res/layout フォルダーに、actionbar_spinner_export を入れました。

<Spinner xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/sp_export"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/actionbar_item_selector" />

次に、onCreateOptionsMenu で、このスピナーを取得し、これにカスタム ArrayAdapter を追加します。Xamarin.Android クロス プラットフォーム開発を使用しているため、コードは c# でしか投稿できません。しかし、Java の場合もほぼ同じです。

IMenuItem spinnerExport = menu.FindItem(Resource.Id.action_share);
        _sp_export = spinnerExport.ActionView.FindViewById<Spinner>(Resource.Id.sp_export);
        _sp_export.Adapter = new ExportAdapter(_parent, Resource.Layout.actionbar_export_row, new List<String>{"Drucken", "Als PDF", "Als Text", "Als Tabelle"});

次に、カスタム ExportAdapter で、表示したい画像 (この場合は共有アイコン) を getView に入れます。getDropDownView で、すべてのアイテムを配置しました。コードは次のとおりです。

class ExportAdapter : ArrayAdapter
{
    private List<String> _objects = null;
    private Context _context = null;

    public ExportAdapter(Context context, int resourceId, List<String> objects) : base(context, resourceId)
    {
        _context = context;
        _objects = objects;
    }

    public override View GetView (int position, View convertView, ViewGroup parent)
    {
        convertView = ((Activity) _context).LayoutInflater.Inflate(Resource.Layout.actionbar_export_row, parent, false);

        TextView tv_text = convertView.FindViewById<TextView>(Resource.Id.tv_text);
        ImageView iv_image = convertView.FindViewById<ImageView>(Resource.Id.iv_image);

        RelativeLayout.LayoutParams lp_iv = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WrapContent, RelativeLayout.LayoutParams.WrapContent);
        lp_iv.AddRule(LayoutRules.CenterInParent);
        iv_image.LayoutParameters = lp_iv;
        iv_image.SetPadding(5,5,5,5);

        tv_text.Visibility = ViewStates.Gone;
        iv_image.SetImageResource(Resource.Drawable.ic_action_share);

        return convertView;
    }

    public override View GetDropDownView (int position, View convertView, ViewGroup parent)
    {
        convertView = ((Activity) _context).LayoutInflater.Inflate(Resource.Layout.actionbar_export_row, parent, false);

        TextView tv_text= convertView.FindViewById<TextView>(Resource.Id.tv_text);
        tv_text.Text = _objects.ElementAt(position);

        return convertView;
    }

    public override int Count {
        get {
            return _objects.Count();
        }
    }

    public String getItemAtIndex(int position)
    {
        return _objects.ElementAt(position);
    }
}

このようにして、実際のアクションバー項目のように見えるアクションバー アイコンができました。クリックすると、スピナーにアイテムが表示されます。

于 2014-06-23T11:11:53.933 に答える