前言

  本章内容是android.widget.SearchView,版本为Android 3.1 r1,为Android 3.0 r1新增API,翻译来自"xiaoQLu",欢迎访问它的博客:"http://www.cnblogs.com/xiaoQLu",再次感谢"xiaoQLu" !期待你一起参与Android API的翻译,联系我[email protected]。

声明

  欢迎转载,但请保留文章原始出处:)

    博客园:http://www.cnblogs.com/

    Android中文翻译组:http://goo.gl/6vJQl

结构

继承关系

public class SearchView extends LinearLayout

java.lang.Object

android.view.View

android.view.ViewGroup

android.widget.LinearLayout

android.widget.SearchView

类概述

一个为用户提供输入搜索查询和提交请求给搜索提供者的用户界面部件。显示查询建议或结果列表,如果有的话,运行用户选择一条查询建议或结果并启动与其相关的操作。

更多信息,参见Search文档。

内部类

  interface SearchView.OnCloseListener

  (译者注:当用户关闭SearchView时触发的回调函数)

interface SearchView.OnQueryTextListener

当查询文本改变时的回调函数。

  interface SearchView.OnSuggestionListener

  在建议上选择事件时的回调接口。

XML属性

属性名称

描述

android:iconifiedByDefault

设置SearchView的默认状态。

如果为true,在没有被使用和点击展开时它将被图形化。

android:maxWidth

SearchView的可选择的最大宽度

android:queryHint

当查询条件为空时显示的一个提示字符串。

公共方法

public CharSequence getQuery ()

  返回当前文本域中的查询字符串

    返回值

      查询字符串

public CursorAdapter getSuggestionsAdapter ()

如果有的话,返回用于搜索建议的适配器。

    返回值

      查询适配器

  public boolean isIconfiedByDefault ()

返回查询区域默认的图标状态。

public boolean isIconified ()

返回SearchView当前的图标状态

    返回值

如果SearchView目前是图标状态,返回true,如果查询区域是完全可见的返回false

public boolean isQueryRefinementEnabled ()

返回查询优化是否是对所有的条目都起作用或者只是对特别的几个起作用

    返回值

      如果是对所有的条目起作用,刚返回true,否则返回false

  public boolean isSubmitButtonEnabled ()

返回当提交按钮在必须的时候是否可用或者从不显示

    返回值

      提交按钮在必须的时候是否自动启用

public boolean onKeyDown (int keyCode, KeyEvent event)

是否处理操作键按下事件

参数

keyCode 键入的键盘值,同时和键盘事件中的参数相同

event 输入键的完整事件记录

    返回值

      如果事件在这里被处理,返回true,不处理返回false

public void setIconified (boolean iconify)

  图标化或者展开SearchView。当图标化时任何查询条件都被清除。这是一个临时的状态,不会重写被setIconifiedByDefault(boolean)设置的默认图标状态。如果默认的是图标化状态,则在用户关闭这个区域前都是false。如果默认的是展开状态,这里就是true,同时清除文本区域,但不关闭它。

参数

iconify true值会把SearchView收缩成一个图标,false值会展开它

    返回值

      查询字符串

public void setIconifiedByDefault (boolean iconified)

  设置搜索栏的默认状态或者静止状态。如果是true,当被按下时,一个单一的搜索图标就会被默认显示,同时显示文本字段和其他按钮。如果默认的状态是图标,在按下关闭按钮时它就会收缩成那个状态。这个属性的改变会立即生效。

    参数

      iconified 搜索栏是否默认被图标化

public void setMaxWidth (int maxpixels)

以最宽的像素相看

    相关的XML属性

android:maxWidth

public void setOnCloseListener (SearchView.OnCloseListener listener)

当用户关闭SearchView时设置一个监听器通知用户

参数

listener 设置用户关闭SearchView时的监听器

public void setOnQueryTextFocusChangeListener (View.OnFocusChangeListener listener)

  设置当查询区域字段改变时通知用户的监听器

参数

listener 设置焦点更改时的监听器

  public void setOnQueryTextListener (SearchView.OnQueryTextListener listener)

  为用户在SearchView内的操作设置监听器

参数

listener 当用户在SearchView操作时比如说点击按钮或者输入查询内容时,设置接收回调的监听器对象

  public void setOnSearchClickListener (View.OnClickListener listener)

  设置按钮被按下时的监听器。在默认情况下当文本字段不可见时才起作用,调用setIconified(false)也可以通知这个监听器。

参数

listener 当搜索按钮被点击或者文本字段编辑取消图形化时通知监听器

  public void setOnSuggestionListener (SearchView.OnSuggestionListener listener)

  设置当一条搜索建议被选中或者点击的时候的监听器

参数

listener 选择搜索建议事件的监听器

  public void setQuery (CharSequence query, boolean submit)

  设置文本区域的一个查询字符串并选择提交和查询。

参数

query 查询字符串。代替在文本区域已经存在的查询文本

submit 是否立即提交查询或者只更新文本区域的内容

  public void setQueryHint (CharSequence hint)

  设置在查询文本区域的提示文本。将覆盖SearchableInfo中的任何提示。

    相关XML属性

android:queryHint

参数

  hint 要显示的提示文本

  public void setQueryRefinementEnabled (boolean enable)

  指定如果精确查询按钮是否在每条建议的旁边显示或者是否根据运营商建议中的设置在个别项目的标志决定。点击精确查询的按钮会用建议中的文本替换查询文本区域中的字段。这个标志只是在一个SearchableInfo中指定setSearchableInfo(SearchableInfo)且不使用定制的适配器时起作用。

参数

      enable 如果所有的条目都有一个精确查询按钮刚为true,如果只有带精确查询标志的条目需要按钮,则为false

    参见

SUGGEST_COLUMN_FLAGS

FLAG_QUERY_REFINEMENT

  public void setSearchableInfo (SearchableInfo searchable)

  SearchView设置SearchableInfoSearchableInfo中的属性用来显示标签,提示(hints),搜索建议,创建打开查询结果和控制其他功能比如一个声音按钮的intents

参数

  searchable 对于一个特殊的activiey或者,能从SearchManager中检索的SearchableInfo,全局的搜索提供者。

  public void setSubmitButtonEnabled (boolean enabled)

  当查询不为空时,显示一个提交按钮。如果SearchView被用来填充当前activity的内容,并且不会启动一个单独的activity,这里提交按钮会消失。

参数

  enabled 设置为True时显示一个提交请求的按钮,当不需要请求按钮时设置为false

  public void setSuggestionsAdapter (CursorAdapter adapter)

  如果你愿意,你可以设置一个定制的适配器。否则使用默认的适配器来显示和SearchableInfo相关的建议提供者的建议。

    参见

setSearchableInfo(SearchableInfo)


更多相关文章

  1. android之PackageManager简介
  2. Android(安卓)基础-1.0 按钮4种点击事件
  3. Android之对话框Dialog
  4. android 按钮按下效果3
  5. Android(安卓)Cursor之MergeCursor
  6. android 数据库操作 插入彩信,数据库子查询
  7. appium---操作手机按键(adb shell input keyevent )
  8. Android中实现图文并茂的按钮实例代码
  9. Android(安卓)程式开发:(一)详解Activity —— 1.4显示“普通”对话

随机推荐

  1. android videoview视频铺满屏幕
  2. android 手势屏幕平移图片转换效果(也可以
  3. Android笔记二十.Android绘图深度解析
  4. Android Firebase接入(四)-- AdMob广告
  5. Android(安卓)关于获取摄像头帧数据
  6. Android(安卓)拍照 以及从本地选择图片
  7. 管理图片缓存
  8. 使用calabash测试开源中国Android客户端
  9. 【Android 开发教程】ListView的基本使用
  10. Android底层驱动开发 -驱动配置篇