【发布时间】:2013-10-30 10:21:15
【问题描述】:
您好,我已关注official android guideline 以启用搜索和搜索建议。我工作得很好,但问题是它只能从一个数据库表中搜索。
我有三个表和三个活动,名称分别为 “BirthdayWisher_Table”、“Tasks_Table”、“Events_Table” 和 “BirthdayWisher_Activity”、“Tasks_Activity”、“Events_Activity”。
我希望当用户在“BirthdayWisher_Activity”并按下“搜索”菜单项时,我的应用应该从“BirthdayWisher_Table”中搜索数据,而当用户在“Tasks_Activity”中并按下“搜索”菜单项时,我的应用应该从“Tasks_Table”中搜索数据。
但对我来说似乎不可能这样做。
SearchAble 配置文件
<?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>
这是我如何关联我的 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>
BirthdayWisherTable 效果很好(因为我已经指定了)
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);
}
}
}
但是如何通过使用此方法从相关表中获取数据来为每个 Activity 提供自定义搜索建议?
【问题讨论】:
标签: android sqlite android-contentprovider searchview