android中实现内容搜索

在编写android搜索代码的时候,怎样去实现搜索功能,考虑中的有两种:

自己定义搜索方法:

1.自己定义搜索输入框,搜索图标,搜索button

2.自己定义语音输入方法

3.自己定义经常使用热词内容、样式

4.自己定义浏览记录内容和样式

5.自己定义弹出样式使用spinner配合listView

6.自己定义数据源格式和搜索算法

自己定义搜索相比还是比較复杂,须要我们思考比較多。

Android自带的搜索方法:

1.创建一个搜索对话框配置文件

2.创建一个可用于搜索的Acitivity和运行搜索

3.接受搜索查询并调用搜索对话框

省去了自己定义算法的弹出样式,搜索数据源格式和算法两大块。

Android搜索方法长处:

1、当您须要在您的应用程序中提供搜索服务时。您第一个想到的是您的搜索框要放在哪里?通过使用Android的搜索对话框来处理用户的搜索请求。通过一个简单的搜索button或从您的应用程序中调用API,搜索对话框就会显示在屏幕的顶部,并会自己主动显示您的应用程序图标。

本文章实现应用程序提供一个自己定义的搜索对话框,提供一个标准化的搜索体验。并添加如语音搜索和搜索建议等功能。

Android的搜索框架将代您管理搜索对话框,您不须要自己去开发一个搜索框。不须要操心搜索框放在什么位置,也不须要操心搜索框影响您当前界面。全部的这些工作都有SearchManager类来处理。SearchManager管理Android搜索对话框的整个生命周期。在您的应用程序发送搜索请求后。返回对应的搜索keyword。

当用户运行一个搜素,SearchManager将使用一个专门的Intent把搜索查询的keyword传送给您在配置文件里配置的处理搜索结果的Activity。

从本质上讲,全部你须要准备的就是一个Activity来接收Intent。然后运行搜索,并给出结果。详细来说,您须要做的事情包含:

(1)一个搜索配置,用一个XML配置文件来对搜索对话框进行配置。包含一些功能的配置,如文本框。设置语音搜索和搜索建议中显示的提示文字等。

(searchable.xml)

(2)一个用来处理搜索请求的Activity。这个Activity用来接收搜索查询的内容,然后搜索您的数据并显示搜索结果。

(3)一个用户运行的搜索路径,默认情况下。一旦您配置了一个可搜索的Activity,设备搜索键(假设存在)将调用搜索对话框。然后,你应该使用提供还有一种手段,让用户能够调用搜索对话框。如在选项菜单中的搜索button和其它用户界面的button,由于不是全部设备都提供一个专门的搜索键。

一、搜索配置

搜索框配置文件是一个用来配置应用程序的XML文件。这个文件一般命名为searchable.xml。而且必须保存在项目的res/xml/文件夹下。配置文件的根节点必须为searchable,能够有一个或多个属性。

<?xml version="1.0" encoding="utf-8"?>
<searchable xmlns:android="http://schemas.android.com/apk/res/android"
    android:label="@string/app_name"
    android:hint="@string/app_version">
</searchable>

上面的配置文件里,除了android:hint属性外,其它都是一个搜索对话框必须的配置项,android:label是一个必须的属性。它的值为一个string资源引用,不能直接用字符串,通常回事应用程序的名称(虽然它是一个必须属性,但通常情况下是不显示出来的。除非你开启了搜索建议功能)。

android:hint是配置搜索框的输入提示信息,也必须引用string.xml中的配置的字符串资源,不能直接使用字符串。能够配置非常多的属性。但大部分属性都仅仅是使用搜索建议和语音搜索时进行配置,虽然如此尽量配置android:hint,用于提示用户须要输入的信息。

接下来,须要把这个配置文件放到你的应用程序中。

二、创建一个可用于搜索的Activity

当用户从一个搜索框运行搜索时,SearchManager会通过ACTION_SEARCH Intent把要搜索的内容(keyword)发送到一个可运行搜索的Activity。

这个Activity查询数据并显示结果。创建一个用来运行搜索的Activity,声明它能够响应ACTION_SEARCH
Intent。而且添加搜索框配置信息。为此须要加入一个元素和一个元素在你的manifest文件里的节点。例如以下所看到的:

<activity
    android:name="com.spring.mainview.SearchActivity"
    android:theme="@style/Default.NoTitleBar">
    <intent-filter>
        <action android:name="android.intent.action.SEARCH"/>
    </intent-filter>
    <meta-data android:name="android.app.searchable"
        android:resource="@xml/searchable"/>
</activity>

代码中android:name属性值必须为“android.app.searchable"。android:resource属性值必须引用上面提到的res/xml/文件夹下的搜索配置文件(本文中为res/xml/searchable.xml)。

请注意,仅仅有配置了上面的meta-data节点的Activity的节点才干运行搜索,假设想在整个应用程序中都能够调用搜索框,可进行例如以下配置:

<activity
    android:name="com.spring.mainview.SearchActivity"
    android:theme="@style/Default.NoTitleBar">
    <intent-filter>
        <action android:name="android.intent.action.SEARCH"/>
    </intent-filter>
    <meta-data android:name="android.app.searchable"
        android:resource="@xml/searchable"/>
</activity>
<meta-data android:name="android.app.default_searchable"
    android:value="com.spring.mainview.SearchActivity"/>

上面代码中andorid:name="android.app.default_searchable"定义一个响应搜索框搜索请求的名称,android:value制定是由哪个Activity响应并运行搜索。

当我们在应用程序中的OtherActivity中运行搜索请求时,SearchActivity将会被载入用于运行搜索并显示搜索结果。

当一个Activity声明为可搜索时。运行实际的搜索包含三个步骤:接受查询,检索你的数据,并提交结果。

通常情况下,你的搜索结果须要在一个listView中展现。所以拟用于运行的Activity要继承ListActivity,这样能够方面的訪问ListView的API。

当从搜索对话框运行搜索时,刚才配置的可用于搜索的Activity将会被Intent激活。同一时候带着一些搜索相关的參数,你须要检查Intent并做出搜索响应。例如以下所看到的:

Intent intent= getIntent();
//推断是否是搜索请求
if (Intent.ACTION_SEARCH.equals(intent.getAction())){
	//获取搜索的查询内容(keyword)
	String query = intent.getStringExtra(SearchManager.QUERY);
	//运行对应的查询动作
	doMySearch(query);
}

doMySearch()方法将依据keyword查询数据库或从网络上查询数据信息,假设是耗时的搜索,你还须要使用搜索进度条,来告诉用户搜索正在进行,最后返回结果后,能够调用ListView的setAdapter()方法将结果显示在ListView中。

你能够从应用程序中的不论什么一个地方调用onSearchRequested()方法激活搜索框,比方从菜单中或者一个button等。

你也能够在OnCreate()方法中调用。setDefaultKeyMode(DEFAULT_KEYS_SEARCH_LOCAL),这样,当用户按下键盘上的按键时,将会自己主动激活搜索框。

搜索框和普通对话框一样,浮动在屏幕的最上方。他不会改变Acitivity堆栈状态。没有不论什么Activity生命周期中的方法会被调用,仅仅有当搜索框出现的时候,正在执行的Activity会失去输入焦点。

假设你要运行搜索时,进行别的操作。能够重写OnSearchRequested()方法。例如以下所看到的

@Override
    public boolean onSearchRequested(){
    	//这种方法中干你想干的事,比方做一些被始化工作
        pauseSomeStuff();
        return super.onSearchRequested();
    }

假设当前的Activity就是对应搜索请求的Activity时,会有下面两种情况:

默认情况下。ACTION_SEARCH Intent将会创建一个新的Activity,并调用OnCreate()方法。这个新的Activity会显示在最前面。你将同一时候有两个Activity实例。

当你按下”返回“键时,会回到没有运行搜索前的Activity。

还有一种情况是配置了android:launchMode="singleTop"的Activity,这时。我们须要在onNewIntent(Intent)方法中处理搜索请求,例如以下所看到的:

代码

@Override
public void onCreate(Bundle savedInstanceState){
    super.onCreate(savedInstanceState);
    setContentView(R.layout.search);
    handleIntent(getIntent());
}

@Override
protected void onNewIntent(Intent intent){
    setIntent(intent);
    handleIntent(intent);
}
private void handleIntent(Intent intent){
    if (Intent.ACTION_SEARCH.equals(intent.getAction())){
      String query = intent.getStringExtra(SearchManager.QUERY);
      doMySearch(query);
    }
}

对应的Activity配置例如以下

<activity android:name=".MySearchableActivity"
	android:launchMode="singleTop">
<intent-filter>
  <action android:name="android.intent.action.SEARCH"/>
</intent-filter>
	<meta-data android:name="android.app.searchable"
	android:resource="@xml/searchable"/>
</activity>

要给搜索框传递參数,我们须要重写onSearchRequested()方法。例如以下所看到的:

@Override
public boolean onSearchRequested(){
     Bundle appData= new Bundle();
     appData.putBoolean(MySearchableActivity.JARGON,true);
     startSearch(null,false, appData,false);
     return true;
}

最后我们来看看怎样使用android的语音搜索:

仅仅须要对我们的搜索配置文件做例如以下修改。你的搜索就支持语音搜索了。配置文件

<?

xml version="1.0" encoding="utf-8"?>
<searchable xmlns:android="http://schemas.android.com/apk/res/android"
    android:label="@string/app_name"
    android:hint="@string/app_version"
    android:voiceSearchMode="showVoiceSearchButton|launchRecognizer">
</searchable>
时间: 2024-10-26 15:03:19

android中实现内容搜索的相关文章

Android中TextView内容过长加省略号

      textview中有个内容过长加省略号的属性,即ellipsize,用法如下: 在xml中 Android:ellipsize = "end"   省略号在结尾 android:ellipsize = "start" 省略号在开头 android:ellipsize = "middle"     省略号在中间 android:ellipsize = "marquee"  跑马灯 最好加一个约束android:sin

android中TextView内容竖向显示

项目中遇到需要textview内容竖着排的需求,如图所示: 网上那些"教程"并不能达到需要的效果,发现有一个属性可以支持这种效果,android:ems="*",这是属性表示一行只显示*个字符. 具体代码如下: 1 <TextView 2 android:layout_centerInParent="true" 3 android:id="@+id/leaderName" 4 android:layout_width=&

Android 中的内容观察者ContentObserver

ContentObserver——内容观察者,目的是观察(捕捉)特定Uri引起的数据库的变化,继而做一些相应的处理,它类似于 数据库技术中的触发器(Trigger),当ContentObserver所观察的Uri发生变化时,便会触发它. 使用ContentObserver 的时候2个重要方法. (1)注册:    public final void  registerContentObserver(Uri uri, boolean notifyForDescendents, ContentObs

Android中谷歌语音识别应用探究

引言 由于为期半年的项目结束了,进入了一段“疗养”的真空期,因此有时间可以去归纳整理项目的经验,学习新的姿势与技巧,对自己技术水平也是一种提升.另外,个人懒癌症严重,为强迫自己努力学习,立了一些福来阁(比如没有写出博客女装什么的咳咳,我一定会拔旗成功的,哼),总体来说督促效果还是挺不错的. 项目中使用的Android和linux进行客户端的开发,结合项目的实战经验,七月份写的博客内容主要围绕Android开发进行,研究的内容预定为:Android中谷歌语音搜索功能探究(开篇),app应用意外关闭

android edittext + listview 实现搜索listview中的内容

以前一直以为edittext中输入一些东西.然后可以检测listview中的内容很高大上.一直没有去尝试.现在项目中遇到了.特此过来尝试一番.结果发现挺简单的,效果还不错,主要就是用到了edittext的 textchange监听 以及listview的过滤.下面直接上截图: xml: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://

Android中设置ListView内容刷新问题

最近在学习Android的listView控件时遇到了一个问题,如何添加一个Item到ListView中并及时的刷新出来.在网上查了很多帖子,很多人在问,也很多人在解答,但是总的来说都没找到详细的解决方案.对于ListView与数据库的同步,高手们建议使用ContentProvider对象.但是如果我不使用数据库呢?也有人回答用notifyDataSetChanged()方法.这倒是一个正确的解决方案,但是对于新手来说,还是比较困惑怎么去用,这里我贴一下我的用法: 代码 OnClickListe

Android 中内容提供者的使用

在Android中内容提供者主要是用于不同程序之间的数据共享.内容提供器的用法一般有两种,一种是使用现有的内容提供器来读取和操作相应程序的数据,另一种是创建自己的内容提供器,供其他的程序访问. 使用现有的内容提供器来读取和操作相应程序的数据 ContentResolve中提供了一系列的方法用于对数据进行增删改查的操作,其中,insert()用于添加数据,update()用于数据更新,delete()方法用于删除数据,query()用于数据的查询. 在ContentResolve中,使用内容URI

Android中内容提供者ContentProvider实现数据库增删改查

1.我们首先new一个我们自己的类集成ContentProvider,并实现方法如下 package com.wzw.sqllitedemo.providers; import com.wzw.sqllitedemo.db.PersonSQLiteOpenHelper; import android.content.ContentProvider; import android.content.ContentUris; import android.content.ContentValues;

备忘: Android中把EditText的输入内容转为大写

editText_SerialCode = (EditText) findViewById(R.id.editText_SerialCode); editText_SerialCode.addTextChangedListener(textWatcher); private TextWatcher textWatcher = new TextWatcher() { @Override public void onTextChanged(CharSequence s, int start, int