您好我已关注official android guideline启用搜索和搜索建议。我工作得很好,但问题是它只从一个数据库表中搜索。
我有三个表和三个活动,名称分别为“BirthdayWisher_Table”
,“Tasks_Table”
,“Events_Table”
和“BirthdayWisher_Activity”
,“Tasks_Activity”
,“Events_Activity”
。
我希望当用户处于“BirthdayWisher_Activity”并按下搜索菜单项时,我的应用应搜索“BirthdayWisher_Table”中的数据,当用户处于“Tasks_Activity”时,按下搜索菜单项我的应用应该从“Tasks_Table”中搜索数据。
但对我来说似乎不可能这样做。
<?xml version="1.0" encoding="utf-8"?>
<searchable xmlns:android="http://schemas.android.com/apk/res/android"
android:hint="@string/search"
android:label="@string/app_name"
android:searchSettingsDescription="@string/search_the_entire_app_"
android:searchSuggestAuthority="com.beaconimpex.assistant.app.ContentProvider"
android:searchSuggestIntentAction="android.Intent.action.VIEW"
android:searchSuggestIntentData="content://com.beaconimpex.assistant.app.ContentProvider/BirthdayWishTable"
android:searchSuggestPath="BirthdayWishTable"
android:searchSuggestSelection=" suggest_text_1 LIKE ? "
android:searchSuggestThreshold="1" >
</searchable>
<activity
android:name="com.beaconimpex.assistant.SearchAppActivity"
android:label="@string/title_activity_search_app" >
<intent-filter>
<action android:name="android.intent.action.SEARCH" />
</intent-filter>
<meta-data
android:name="android.app.searchable"
android:resource="@xml/searchable" />
</activity>
android:searchSuggestIntentData="content://com.beaconimpex.assistant.app.ContentProvider/BirthdayWishTable"
android:searchSuggestPath="BirthdayWishTable"
public class AssistantContentProvider extends ContentProvider {
public static final String DATABASE_NAME = "gcuf__dB";
public static final int DATABASE_VERSION = 99;
public static final String AUTHORITY = "com.beaconimpex.assistant.app.ContentProvider";
SQLiteDatabase db;
private DBOpenHelper dbHelper;
private static final UriMatcher sURIMatcher = new UriMatcher(
UriMatcher.NO_MATCH);
private static final int SEARCH_SUGGEST = 12345;
static {
sURIMatcher.addURI(AUTHORITY, BirthdayWisher.TABLE_NAME + "/"
+ SearchManager.SUGGEST_URI_PATH_QUERY, SEARCH_SUGGEST);
sURIMatcher.addURI(AUTHORITY, BirthdayWisher.TABLE_NAME + "/"
+ SearchManager.SUGGEST_URI_PATH_QUERY + "/*", SEARCH_SUGGEST);
}
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sortOrder) {
Log.i(MyConstants.LOG_TAG, "-----Query method is called with URI: "
+ uri.toString());
switch (sURIMatcher.match(uri)) {
case SEARCH_SUGGEST:
Log.i(MyConstants.LOG_TAG, "URI Search Suggest");
if (selectionArgs != null && selectionArgs.length > 0
&& selectionArgs[0].length() > 0) {
// the entered text can be found in selectionArgs[0]
// return a cursor with appropriate data
return queryCursor(uri, BirthdayWisher.TABLE_NAME,
BirthdayWisher.allColumns, selection,
new String[] { "%" + selectionArgs[0].toLowerCase()
+ "%" }, null);
} else {
// user hasn't entered anything
// thus return a default cursor
Log.i(MyConstants.LOG_TAG,
"User has not entered anything in the searchBox.");
return null;
}
default:
throw new IllegalArgumentException("Unsupported URI: " + uri);
}
}
}
但是,如何通过使用此方法从相关表格中获取数据,为每个活动提供自定义搜索建议?
答案 0 :(得分:7)
您只需添加另一个可搜索文件即可。您可以随意命名,因为缺少任务,为什么不使用searchable_tasks.xml
?
现在将所有现有searchable.xml
复制到此文件中,将searchSuggestPath
更改为TasksTable
并对searchSuggestIntentData
执行相同操作。
当然,您还必须扩展内容提供程序(将这些额外的可能性添加到URIMatcher并对查询方法中的相应URI做出反应)。
答案 1 :(得分:2)
您应该对所有表“BirthdayWisher_Table”,“Tasks_Table”,“Events_Table”和“BirthdayWisher_Activity”,“Tasks_Activity”,“Events_Activity”分别使用数据库连接来检索所有表信息。希望这个Link可以帮助你理解我在说什么。然后你可以解析搜索建议中的所有表格信息
使用AutoCompleteTextview
的另一种方法查看此source code
SuggestionAdapter类将参数“type”放在构造函数中。
String type;
public SuggestionAdapter(Activity context, String nameFilter,String type) {
super(context, android.R.layout.simple_dropdown_item_1line);
suggestions = new ArrayList<String>();
this.type=type;
}
然后按类型检索信息 在getFilter()方法
List<SuggestGetSet> new_suggestions = db.getInformation(type)
然后使用AutoCompleteTextView,如下面的
AutoCompleteTextView acTextView = (AutoCompleteTextView)findViewById(R.id.autoComplete);
acTextView.setAdapter(new SuggestionAdapter(this,acTextView.getText().toString(),"Tasks_Table"));
答案 2 :(得分:2)
如果我没有错,你可以通过以下方式实现这一目标:
传递活动名称,意图搜索活动。 从intent获取被调用的活动名称。 现在你有了被叫活动名称,你可以随心所欲。