聆听Android的ActionView扩展事件

时间:2015-02-27 11:16:18

标签: android listener searchview

当用户点击SearchView的查找图标时,我想做点什么。阅读API之后,我在本文末尾写了类似的内容。但我的应用程序在启动时崩溃,这是堆栈跟踪:

java.lang.UnsupportedOperationException: This is not supported, use MenuItemCompat.setOnActionExpandListener()
            at android.support.v7.internal.view.menu.MenuItemImpl.setOnActionExpandListener(MenuItemImpl.java:740)
            at com.kradragon.minadictionary.MainActivity.onCreateOptionsMenu(MainActivity.java:187)
            at android.app.Activity.onCreatePanelMenu(Activity.java:2508)
            at android.support.v4.app.FragmentActivity.onCreatePanelMenu(FragmentActivity.java:275)
            at android.support.v7.app.ActionBarActivity.superOnCreatePanelMenu(ActionBarActivity.java:276)
            at android.support.v7.app.ActionBarActivityDelegate$1.onCreatePanelMenu(ActionBarActivityDelegate.java:79)
            at android.support.v7.app.ActionBarActivityDelegateBase.preparePanel(ActionBarActivityDelegateBase.java:979)
            at android.support.v7.app.ActionBarActivityDelegateBase.doInvalidatePanelMenu(ActionBarActivityDelegateBase.java:1182)
            at android.support.v7.app.ActionBarActivityDelegateBase.access$100(ActionBarActivityDelegateBase.java:79)
            at android.support.v7.app.ActionBarActivityDelegateBase$1.run(ActionBarActivityDelegateBase.java:118)
            at android.os.Handler.handleCallback(Handler.java:800)
            at android.os.Handler.dispatchMessage(Handler.java:100)
            at android.os.Looper.loop(Looper.java:194)
            at android.app.ActivityThread.main(ActivityThread.java:5371)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:525)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:833)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:600)
            at dalvik.system.NativeStart.main(Native Method)

我搜索并发现了一些建议使用MenuItemCompat的帖子。我也实现了它(我将该代码放在评论中),我的应用程序已启动,但事件未触发。

如果有人可以解释为什么使用MenuItemCompat,虽然SDK中存在一些类似的API,但这会有所帮助。请更正我的代码。

提前感谢:)

public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);

    // Associate searchable configuration with the SearchView
    SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
    MenuItem searchItem = menu.findItem(R.id.search);
    SearchView searchView = (SearchView) searchItem.getActionView();
    searchView.setSearchableInfo(searchManager.getSearchableInfo(getComponentName()));

    searchItem.setOnActionExpandListener(new MenuItem.OnActionExpandListener() {
        @Override
        public boolean onMenuItemActionExpand(MenuItem item) {
            return false;
        }

        @Override
        public boolean onMenuItemActionCollapse(MenuItem item) {
            return false;
        }
    });

//        MenuItemCompat.setOnActionExpandListener(searchItem, new MenuItemCompat.OnActionExpandListener() {
//            @Override
//            public boolean onMenuItemActionExpand(MenuItem item) {
//                showResultsFragment();
//                return false;
//            }
//
//            @Override
//            public boolean onMenuItemActionCollapse(MenuItem item) {
//                return false;
//            }
//        });
//        MenuItemCompat.setActionView(searchItem, searchView);

    return true;
}

main_menu.xml文件:

<menu 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" tools:context=".MainActivity">
    <item android:id="@+id/search"
        android:title="@string/search_title"
        android:icon="@drawable/search"
        app:showAsAction="collapseActionView|always"
        app:actionViewClass="android.widget.SearchView"/>
</menu>

1 个答案:

答案 0 :(得分:2)

API 14中添加了

MenuItem.setOnActionExpandListener(),这意味着它无法在API&lt; 14上运行。通常,要使这些内容适用于较低的API,您可以使用'support' libraries,这些内容旨在向新内容提供与较低API的向后兼容性。

  

Android支持库包是一组代码库,提供Android框架API的向后兼容版本以及仅通过库API提供的功能。每个支持库都向后兼容特定的Android API级别。这种设计意味着您的应用程序可以使用库和#39;功能,仍然与运行Android 1.6(API级别4)及更高版本的设备兼容。

在您的情况下,MenuItemCompat'support-v4' library的一部分。