我正在doSearchQuery中从此博客http://weblog.plexobject.com/?p=1689实现搜索活动的自定义建议列表,但他无法理解他的所作所为。另一件事是我通过打字搜索例如月份名称以“A”开头比较它并返回那些比赛结果8月,4月等但在建议列表中只显示“a”,所有匹配结果如“j”包含在1月,6月,7月。但在建议清单中获取j,j,j只是这个月的名字。在哪里我错了或遗漏了一些我不理解的东西
这是我的SearchActivity代码
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
//setContentView(R.layout.search_activity);
this.setDefaultKeyMode(Activity.DEFAULT_KEYS_SEARCH_LOCAL);
final Intent queryIntent = getIntent();
final String queryAction = queryIntent.getAction();
if (Intent.ACTION_SEARCH.equals(queryAction)) {
this.doSearchQuery(queryIntent);
} else if (Intent.ACTION_VIEW.equals(queryAction)) {
this.doView(queryIntent);
} else {
Log.d(TAG, "Create intent NOT from search");
}
}
@Override
public void onNewIntent(final Intent queryIntent) {
super.onNewIntent(queryIntent);
final String queryAction = queryIntent.getAction();
if (Intent.ACTION_SEARCH.equals(queryAction)) {
this.doSearchQuery(queryIntent);
} else if (Intent.ACTION_VIEW.equals(queryAction)) {
this.doView(queryIntent);
}
}
// here in this didn't under what he did one is getting intent and bundle but where he define it.
private void doSearchQuery(final Intent queryIntent) {
String queryString = queryIntent.getDataString(); // from suggestions
if (query == null) {
query = intent.getStringExtra(SearchManager.QUERY); // from search-bar
}
// display results here
bundle.putString("user_query", queryString);
intent.setData(Uri.fromParts("", "", queryString));
intent.setAction(Intent.ACTION_SEARCH);
queryIntent.putExtras(bundle);
startActivity(intent);
Log.e("query string", "query string "+queryString);
}
private void doView(final Intent queryIntent) {
Uri uri = queryIntent.getData();
String action = queryIntent.getAction();
Intent intent = new Intent(action);
intent.setData(uri);
startActivity(intent);
this.finish();
}
这是我的提供者,我需要单行建议我在评论第二栏
public class MySuggestionProvider extends SearchRecentSuggestionsProvider {
public final static String AUTHORITY = MySuggestionProvider.class.getName();
public final static int MODE = DATABASE_MODE_QUERIES;
private final static String TAG = MySuggestionProvider.class.getSimpleName();
private static final String[] COLUMNS = {
"_id", // must include this column
SearchManager.SUGGEST_COLUMN_TEXT_1,
// SearchManager.SUGGEST_COLUMN_TEXT_2,
SearchManager.SUGGEST_COLUMN_INTENT_DATA,
SearchManager.SUGGEST_COLUMN_INTENT_ACTION,
SearchManager.SUGGEST_COLUMN_SHORTCUT_ID };
public MySuggestionProvider() {
setupSuggestions(AUTHORITY, MODE);
}
@Override
public Cursor query(Uri uri, String[] projection, String selection,
String[] selectionArgs, String sortOrder) {
String query = selectionArgs[0];
if (query == null || query.length() == 0) {
return null;
}
MatrixCursor cursor = new MatrixCursor(COLUMNS);
try {
List<String> list = callmyservice(query);
int n = 0;
for (String obj : list) {
cursor.addRow(createRow(Integer.valueOf(n), query, obj));
n++;
}
} catch (Exception e) {
Log.e(TAG, "Failed to lookup " + query, e);
}
return cursor;
}
@Override
public Uri insert(Uri uri, ContentValues values) {
throw new UnsupportedOperationException();
}
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
throw new UnsupportedOperationException();
}
@Override
public int update(Uri uri, ContentValues values, String selection,
String[] selectionArgs) {
throw new UnsupportedOperationException();
}
private Object[] createRow(Integer id, String text1,
String name) {
return new Object[] { id, // _id
text1, // text1
//text2, // text2
text1, "android.intent.action.SEARCH", // action
SearchManager.SUGGEST_NEVER_MAKE_SHORTCUT };
}
private static final String[] months = {"January", "February","march","April","may","june","july","August","September","octobor",
"november","december"};
List<String> ls2 = new ArrayList<String>();
private List<String> callmyservice(String query){
List<String> ls = new ArrayList<String>();
for(int i=0;i<months.length;i++){
if(months[i].toLowerCase().contains(query.toLowerCase())){
//if(months[i].equalsIgnoreCase(query.toLowerCase())){
ls.add(months[i]);
}
}
ls2.clear();
ls2.addAll(ls);
return ls;
}
}
答案 0 :(得分:4)
我找到了如何实现自定义建议的方法。稍微改变一下,您可以在建议列表中实现搜索建议单一或双线。
对于Single line表示我先解释。
从问题代码中我改变一些并实现单行建议列表。
从COLUMN对象更改此
private static final String[] COLUMNS = {
"_id", // must include this column
SearchManager.SUGGEST_COLUMN_TEXT_1,
SearchManager.SUGGEST_COLUMN_INTENT_DATA,
SearchManager.SUGGEST_COLUMN_INTENT_EXTRA_DATA,
SearchManager.SUGGEST_COLUMN_SHORTCUT_ID };
现在在createRow()时间只传递一个是ID的对象,另一个是query()方法中的建议列表值。
List<String> list = callmyservice(query);
int n = 0;
for (String obj : list) {
cursor.addRow(createRow(Integer.valueOf(n),obj));
n++;
}
现在实现这样的createRow()。
private Object[] createRow(Integer id, String text1){
return new Object[] { id, // _id
text1, // text1
text1, // data to sent back to activity and select
text1, // data sent as extra data when select from suggestin list
SearchManager.SUGGEST_NEVER_MAKE_SHORTCUT};
}
好的,这是实现它时的快照。
Ok现在,对于两行搜索建议列表,像这样创建COLUMN对象
private static final String[] COLUMNS = {
"_id", // must include this column
SearchManager.SUGGEST_COLUMN_TEXT_1,
SearchManager.SUGGEST_COLUMN_TEXT_2,
SearchManager.SUGGEST_COLUMN_INTENT_DATA,
SearchManager.SUGGEST_COLUMN_INTENT_EXTRA_DATA,
SearchManager.SUGGEST_COLUMN_INTENT_ACTION,
SearchManager.SUGGEST_COLUMN_SHORTCUT_ID };
现在实现createRow()方法并从这样的query()调用 // query()方法 列表list = callmyservice(查询); int n = 0; for(String obj:list){ //此处查询是您当前用于搜索text_1的输入文本 // obj是与此查询一起找到的匹配列表,显示为text_2 cursor.addRow(createRow(Integer.valueOf(n),query,obj)); 的n ++; }
private Object[] createRow(Integer id, String text1, String name) {
return new Object[] { id, // _id
text1, // text1
text2, // text2
text1, // data to be sent when select from list as query
text2, // data to be sent as extra string when select from list as result
"android.intent.action.SEARCH", // action
SearchManager.SUGGEST_NEVER_MAKE_SHORTCUT };
}
这是两行搜索建议列表的视图
好的,希望这对你有所帮助。