在不同的活动中搜索不同表格的建议

时间:2013-10-30 10:21:16

标签: android sqlite android-contentprovider searchview

您好我已关注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);
    }



       }
}

但是,如何通过使用此方法从相关表格中获取数据,为每个活动提供自定义搜索建议?

3 个答案:

答案 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获取被调用的活动名称。 现在你有了被叫活动名称,你可以随心所欲。