Android开发之搜索框SearchView用法示例

本文实例讲述了Android开发之搜索框SearchView用法。分享给大家供大家参考,具体如下:

介绍:

SearchView时搜索组件,可以让用户输入文字,见他输入匹配结果

效果:

基本的用法 我就不详细描述了

这里主要说一些我遇到的问题:

如下:

一、点击listView后 让文字自动补全到searchView上:

首先需要设置adapter 然后这只listView的点击事件:

private final String[] mStrings = {"我爱Java","安卓无敌","好好学习"};
final ArrayAdapter adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,mStrings);
listView.setAdapter(adapter);

然后对listView添加 item的监听事件:

listView.setOnItemClickListener(new ListView.OnItemClickListener() {
  @Override
  public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
    Object string = adapter.getItem(position);
    searchView.setQuery(string.toString(),true);
  }
});

二、删除listView自带过滤器的黑框:

在 onQueryTextChange

对adapter设置:adapter.getFilter().filter(newText.toString());

@Override
public boolean onQueryTextChange(String newText) {
  //如果newText长度不为0
  if (TextUtils.isEmpty(newText)){
    listView.clearTextFilter();
  }else{
    listView.setFilterText(newText);
    //adapter.getFilter().filter(newText.toString());//替换成本句后消失黑框!!!
  }
  return true;
}

下面给出效果图的的完整实现方法:

public class MainActivity extends Activity {
  private SearchView searchView;
  private ListView listView;
  //定义自动完成的列表
  private final String[] mStrings = {"我爱Java","安卓无敌","好好学习"};
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    listView = (ListView) findViewById(R.id.lv);
    final ArrayAdapter adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,mStrings);
    listView.setAdapter(adapter);
    //为ListView启动过滤
    listView.setTextFilterEnabled(true);
    searchView = (SearchView) findViewById(R.id.sv);
    //设置SearchView自动缩小为图标
    searchView.setIconifiedByDefault(false);//设为true则搜索栏 缩小成俄日一个图标点击展开
    //设置该SearchView显示搜索按钮
    searchView.setSubmitButtonEnabled(true);
    //设置默认提示文字
    searchView.setQueryHint("输入您想查找的内容");
    //配置监听器
    searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
      //点击搜索按钮时触发
      @Override
      public boolean onQueryTextSubmit(String query) {
        //此处添加查询开始后的具体时间和方法
        Toast.makeText(MainActivity.this,"you choose:" + query,Toast.LENGTH_SHORT).show();
        return false;
      }
      @Override
      public boolean onQueryTextChange(String newText) {
        //如果newText长度不为0
        if (TextUtils.isEmpty(newText)){
          listView.clearTextFilter();
        }else{
          listView.setFilterText(newText);
//          adapter.getFilter().filter(newText.toString());//替换成本句后消失黑框!!!
        }
        return true;
      }
    });
    listView.setOnItemClickListener(new ListView.OnItemClickListener() {
      @Override
      public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        Object string = adapter.getItem(position);
        searchView.setQuery(string.toString(),true);
      }
    });
  }
}

最后给出布局如下:

<?xml version="1.0" encoding="utf-8" ?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical">
  <!--定义一个SearchView-->
  <SearchView
    android:id="@+id/sv"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>
  <!--定义自动完成的ListView-->
  <ListView
    android:id="@+id/lv"
    android:layout_width="match_parent"
    android:layout_height="0dp"
    android:layout_weight="1"/>
</LinearLayout>

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android开发入门与进阶教程》、《Android调试技巧与常见问题解决方法汇总》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结》

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • Android仿简书动态searchview搜索栏效果

    简书的动态搜索栏效果是这样的,挺高大上的感觉. ezgif.com-resize.gif 仔细想一下,其实实现起来非常简单,这是我做的效果,基本完美还原. ezgif.com-resize (2).gif 实现这个效果, 只要关注几个点 1.搜索栏伸展和收缩动画效果实现 2.搜索栏伸展和收缩的时机 3.顶部透明度的渐变 搜索栏伸展和收缩动画效果实现: 我们只要明确,使用系统为我们提供的Transition框架,就可以轻而易举的实现了. 首先要引入依赖compile 'com.android.su

  • Android顶部(toolbar)搜索框实现的实例详解

    Android顶部(toolbar)搜索框实现的实例详解 本文介绍两种SearchView的使用情况,一种是输入框和搜索结果不在一个activity中,另一种是在一个activity中. 首先编写toolbar的布局文件 toolbar中图标在menu文件下定义一个布局文件实现 示例代码: <menu xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.

  • Android搜索框(SearchView)的功能和用法详解

    SearchView是搜索框组件,它可以让用户在文本框里输入文字,通过监听器取得用户的输入,当用户点击搜索时,监听器执行实际的搜索. 1.SearchView组件的常用方法如下: ①setIconifiedByDefault(boolean iconified) ===> 设置搜索框默认是否自动缩小为图标. ②setOnQueryTextListener(SearchView,OnQueryTextListener listener) ===> 为搜索框设置监听器 ③setSubmitButt

  • Android搜索框组件SearchView的基本使用方法

    SearchView是android系统中内置的一个搜索框组件,可以很方便在添加在用户界面之上,但是也带来了一些问题,那就是searchview的UI是固定的,定制起来会很麻烦,如果对SearchView的要求比较高,完全可以采用button和EditText自己实现.这里先简单的说说SearchView的使用: main.xml: <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" x

  • Android自定义View实现搜索框(SearchView)功能

    概述 在Android开发中,当系统数据项比较多时,常常会在app添加搜索功能,方便用户能快速获得需要的数据.搜索栏对于我们并不陌生,在许多app都能见到它,比如豌豆荚 在某些情况下,我们希望我们的自动补全信息可以不只是纯文本,还可以像豌豆荚这样,能显示相应的图片和其他数据信息,因此Android给我们提供的AutoCompleteTextView往往就不够用,在大多情况下我们都需要自己去实现搜索框. 分析 根据上面这张图,简单分析一下自定义搜索框的结构与功能,有 1. 搜索界面大致由三部门组成

  • Android SearchView搜索框组件的使用方法

    SearchView是搜索框组件,它可以让用户在文本框里输入文字,通过监听器取得用户的输入,当用户点击搜索时,监听器执行实际的搜索. 本文就为大家分享了SearchView搜索框组件的使用方法,供大家参考,具体内容如下 效果: 代码SearchActivity.java package com.jialianjia.bzw.activity; import android.os.Bundle; import android.widget.ArrayAdapter; import android.

  • Android 根据EditText搜索框ListView动态显示数据

    根据EditText搜索框ListView动态显示数据是根据需求来的,觉得这之中涉及的东西可能比较的有意思,所以动手来写一写,希望对大家有点帮助. 首先,我们来分析下整个过程: 1.建立一个layout,包含一个EditText搜索框和一个ListView 2.创建一个数据集mData,用于ListView的Adapter的创建 3.添加EditText的文本改变的监听器 4.利用notifyDataSetChanged()动态更新ListView 第一步:创建一个搜索框 这个还是比较容易的,这

  • Android 解决使用SearchView时软键盘不支持actionSearch的问题

    前言 变态问题常有,今年特别多,,, - - # 今天遇到的这个非处理不可,不然没法在HTC One S使用SearchView,其软键盘不支持action设置.  正文 问题设备: HTC One S searchable.xml <searchable xmlns:android="http://schemas.android.com/apk/res/android" android:label="@string/search_label" android

  • Android搜索框SearchView属性和用法详解

    SearchView简介 SearchView是Android原生的搜索框控件,它提供了一个用户界面,用于用户搜索查询. SearchView默认是展示一个search的icon,点击icon展开搜索框,如果你想让搜索框默认就展开,可以通过setIconifiedByDefault(false);实现. SearchView属性 SearchView使用 xml中定义SearchView: <?xml version="1.0" encoding="utf-8"

  • Android EditText搜索框实现图标居中

    类似这样EditText 搜索框,hiht 提示有一个icon并且text内容. 重写EditText : package mobi.truekey.weapp2.widget; import android.content.Context; import android.content.res.TypedArray; import android.graphics.Canvas; import android.graphics.Paint; import android.graphics.dr

随机推荐