一个 activity 中的 SearchView,结果是另一个
SearchView in one activity, results in another one
我的用例如下:在 activity A 中,我有一个带有可折叠 SearchView 的操作栏。当用户给出她的查询并按下 'search' 按钮时,我想显示 activity B 的结果。我没有这样做,这是我的代码:
searchable.xml:
<?xml version="1.0" encoding="utf-8"?>
<searchable xmlns:android="http://schemas.android.com/apk/res/android"
android:hint="@string/action_search_hint"
android:label="@string/app_name"/>
Activity答:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu, menu);
SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
SearchView searchView = (SearchView) menu.findItem(R.id.action_search).getActionView();
searchView.setSearchableInfo(searchManager.getSearchableInfo(getComponentName()));
return true;
}
Activity A 和 B 的 AndroidManifest:
<activity
android:name=".ActivityA">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".ActivityB">
<intent-filter>
<action android:name="android.intent.action.SEARCH"/>
</intent-filter>
<meta-data
android:name="android.app.searchable"
android:resource="@xml/searchable"/>
</activity>
但是,无论我尝试什么,A 中的 getSearchableInfo 总是 returns null。
我觉得我有什么地方不明白。使 getSearchableInfo() return 不为空的唯一方法是将 SEARCH 意图过滤器和可搜索元数据放入清单中的 activity A 中。但是,当我按下 'search' 按钮时, activity A 的另一个实例在当前实例之上再次启动,这绝对不是我想要的。我想我可以将 singleTop 添加到 A 并在 onNewIntent 中处理 SEARCH 操作并启动 B,但我通常不希望 A 是 singleTop,我想要默认值。还是我?
我尝试将此添加到清单中的 A(如其他一些线程中所建议):
<meta-data
android:name="android.app.default_searchable"
android:value=".ActivityB" >
</meta-data>
我做错了什么?
编辑: 我用以下内容替换了 A 中的 'getComponentName()' 行:
searchView.setSearchableInfo(searchManager.getSearchableInfo(new ComponentName(this, ActivityB.class)));
它似乎按照我想要的方式工作!我在这里做错了什么,或者这是正确的方法吗?我有点不确定,因为在任何地方都没有提到它!
<intent-filter>
<action android:name="android.intent.action.SEARCH"/>
</intent-filter>
将此意图过滤器添加到 activity A。
2.SearchView 菜单
SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
searchView = (SearchView) menu.findItem(R.id.search).getActionView();
searchView.setSearchableInfo(searchManager
.getSearchableInfo(getComponentName()));
xml:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/search"
android:actionViewClass="android.widget.SearchView"
android:icon="@drawable/ic_action_search"
android:showAsAction="collapseActionView|always"
android:title="@string/search_hint"/>
</menu>
3.Call这个方法来自oncreate。
private void handleIntent(Intent intent) {
if (Intent.ACTION_SEARCH.equals(intent.getAction())) {
String query = intent.getStringExtra(SearchManager.QUERY);
Debug.e("Suggestion handle click", "call " + query);
startNextActivity(query);
}
}
4。如果您使用的是自动建议列表视图,请实施 searchView.setOnQueryTextListener、setOnSuggestionListener 和 setSuggestionsAdapter。
根据Android documentations,SearchManager.getSearchableInfo(componentName)
接受一个参数,即:
componentName: The activity to get searchable information for
在您的情况下,您需要 ActivityB
,因此构建指向 ActivityB
的 ComponentName 是正确的方法
new ComponentName(this, ActivityB.class)
我的用例如下:在 activity A 中,我有一个带有可折叠 SearchView 的操作栏。当用户给出她的查询并按下 'search' 按钮时,我想显示 activity B 的结果。我没有这样做,这是我的代码:
searchable.xml:
<?xml version="1.0" encoding="utf-8"?>
<searchable xmlns:android="http://schemas.android.com/apk/res/android"
android:hint="@string/action_search_hint"
android:label="@string/app_name"/>
Activity答:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu, menu);
SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
SearchView searchView = (SearchView) menu.findItem(R.id.action_search).getActionView();
searchView.setSearchableInfo(searchManager.getSearchableInfo(getComponentName()));
return true;
}
Activity A 和 B 的 AndroidManifest:
<activity
android:name=".ActivityA">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
<activity android:name=".ActivityB">
<intent-filter>
<action android:name="android.intent.action.SEARCH"/>
</intent-filter>
<meta-data
android:name="android.app.searchable"
android:resource="@xml/searchable"/>
</activity>
但是,无论我尝试什么,A 中的 getSearchableInfo 总是 returns null。
我觉得我有什么地方不明白。使 getSearchableInfo() return 不为空的唯一方法是将 SEARCH 意图过滤器和可搜索元数据放入清单中的 activity A 中。但是,当我按下 'search' 按钮时, activity A 的另一个实例在当前实例之上再次启动,这绝对不是我想要的。我想我可以将 singleTop 添加到 A 并在 onNewIntent 中处理 SEARCH 操作并启动 B,但我通常不希望 A 是 singleTop,我想要默认值。还是我?
我尝试将此添加到清单中的 A(如其他一些线程中所建议):
<meta-data
android:name="android.app.default_searchable"
android:value=".ActivityB" >
</meta-data>
我做错了什么?
编辑: 我用以下内容替换了 A 中的 'getComponentName()' 行:
searchView.setSearchableInfo(searchManager.getSearchableInfo(new ComponentName(this, ActivityB.class)));
它似乎按照我想要的方式工作!我在这里做错了什么,或者这是正确的方法吗?我有点不确定,因为在任何地方都没有提到它!
<intent-filter>
<action android:name="android.intent.action.SEARCH"/>
</intent-filter>
将此意图过滤器添加到 activity A。
2.SearchView 菜单
SearchManager searchManager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
searchView = (SearchView) menu.findItem(R.id.search).getActionView();
searchView.setSearchableInfo(searchManager
.getSearchableInfo(getComponentName()));
xml:
<?xml version="1.0" encoding="utf-8"?>
<menu xmlns:android="http://schemas.android.com/apk/res/android" >
<item
android:id="@+id/search"
android:actionViewClass="android.widget.SearchView"
android:icon="@drawable/ic_action_search"
android:showAsAction="collapseActionView|always"
android:title="@string/search_hint"/>
</menu>
3.Call这个方法来自oncreate。
private void handleIntent(Intent intent) {
if (Intent.ACTION_SEARCH.equals(intent.getAction())) {
String query = intent.getStringExtra(SearchManager.QUERY);
Debug.e("Suggestion handle click", "call " + query);
startNextActivity(query);
}
}
4。如果您使用的是自动建议列表视图,请实施 searchView.setOnQueryTextListener、setOnSuggestionListener 和 setSuggestionsAdapter。
根据Android documentations,SearchManager.getSearchableInfo(componentName)
接受一个参数,即:
componentName: The activity to get searchable information for
在您的情况下,您需要 ActivityB
,因此构建指向 ActivityB
的 ComponentName 是正确的方法
new ComponentName(this, ActivityB.class)