android顶部(toolbar)搜索框实现

原创 2016年02月17日 21:08:10

本文介绍两种SearchView的使用情况,一种是输入框和搜索结果不在一个activity中,另一种是在一个activity中。
首先编写toolbar的布局文件
toolbar中图标在menu文件下定义一个布局文件实现

<menu xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    tools:context=".MainActivity" >

    <item
        android:id="@+id/ab_search"
        android:orderInCategory="60"
        android:title="action_search"
        app:actionViewClass="android.support.v7.widget.SearchView"
        app:showAsAction="ifRoom"/>
</menu>

menu下只有item和group两种子节点,这里不具体介绍,actionViewClass的作用是让这个item的显示形式,我们这里使用自带的搜索框。
然后在你xml文件下编写searchable.xml文件

<?xml version="1.0" encoding="utf-8"?>

<searchable xmlns:android="http://schemas.android.com/apk/res/android"
    android:label="@string/app_name"
    android:imeOptions="actionSearch"
    android:hint="姓名" />

imeOptions作用是键盘的回车键变成了搜索,这里还有其他选项,不做介绍。actionSearch是将回车键显示为搜索键。
然后在activity中实现,这里一定要先实现toolbar,不在贴出代码,
然后重写这个方法,得到SearchView

 @Override
    public boolean onCreateOptionsMenu(Menu menu) {
        getMenuInflater().inflate(R.menu.toolbar_menu_friend, menu);
        SearchManager searchManager =
                (SearchManager) getSystemService(Context.SEARCH_SERVICE);
        SearchView searchView =
                (SearchView) menu.findItem(R.id.ab_search).getActionView();
        searchView.setSearchableInfo(
                searchManager.getSearchableInfo(getComponentName()));
        return true;
    }

然后在新建一个activity,为处理搜索结果的界面,命名为SearchResultActivity。
String SearchContent = getIntent().getStringExtra(SearchManager.QUERY);
这样SearchContent里面就是你在搜索框中输入的内容。
接下来在配置文件中对activity进行配置

<activity android:name=".activity.MainActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
            <meta-data android:name="android.app.default_searchable"
                android:value=".activity.SearchResultActivity"/>
        </activity>

-----------------------分割线---------------------------

<activity android:name=".activity.SearchResultActivity"
            android:parentActivityName=".activity.MainActivity">
            <meta-data
                android:name="android.support.PARENT_ACTIVITY"
                android:value=".activity.MainActivity" />
            <!-- meta tag and intent filter go into results activity -->
            <meta-data android:name="android.app.searchable"
                android:resource="@xml/searchable" />
            <intent-filter>
                <action android:name="android.intent.action.SEARCH" />
            </intent-filter>
        </activity>

以上是搜索框和搜索结果不在一个activity中。
如果在一个activity中,方法都不变,只是在配置文件中具有搜索框的acitivity中配置这两个就行了
<meta-data android:name="android.app.searchable"
android:resource="@xml/searchable" />
<intent-filter>
<action android:name="android.intent.action.SEARCH" />
</intent-filter>

这里写图片描述
这里写图片描述

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

实现toolbar上的搜索栏

先看一下效果图:点击搜索图标之前和点击之后                                                 步骤:1.利用最新版的Android Studio生成一个...

ToolBar和 ActionBar点击搜索出来输入框

ToolBarstyle文件里修改 @color/colorPrimary @color/c

ToolBar和SearchView的使用总结

众所周知,在使用ActionBar的时候,一堆的问题:这个文字能不能定制,位置能不能改变,图标的间距怎么控制神马的,由此暴露出了ActionBar设计的不灵活。为此官方提供了ToolBar,并且提供了...

android ToolBar + SearchView

一直觉得标题栏是个小玩意,没花时间去了解过,最近项目中用到就了解了一下,分享出来,有需要的朋友可以凑合看看...

toolbar 搜索功能

1.首先在menu文件中设置searchItem的属性 item android:id="@+id/action_search" android:icon="@android:drawa...

Android自定义View——自定义搜索框(SearchView)

概述 在Android开发中,当系统数据项比较多时,常常会在app添加搜索功能,方便用户能快速获得需要的数据。搜索栏对于我们并不陌生,在许多app都能见到它,比如豌豆荚 在某些情况下,我们希望...
  • jdsjlzx
  • jdsjlzx
  • 2015年06月16日 10:06
  • 102116

android 搜索框实现方法,还在手写搜索框?out了!附加Toast及时改变内容

效果图:教程::如图,之前用到搜索框都是自己写,里面的EditText还得设置内容改变监听来实现实时搜索,偶然间发现V7包中存在有搜索控件...

android顶部(toolbar)搜索框实现

本文介绍两种SearchView的使用情况,一种是输入框和搜索结果不在一个activity中,另一种是在一个activity中。  首先编写toolbar的布局文件  toolbar中图标在menu文...

Toolbar结合SearchView的使用

在实际的业务开发中,我们通常会在顶部的导航栏加入搜索的功能,如微信顶部的导航栏,这时我们可以Toolbar结合SearchView来使用 Toolbar的具体使用见:http://blog.csdn....

SearchView结合Toolbar 筛选RecyclerView中的内容,类似知乎、google play实现的效果

效果代码已上传至github项目里要做一个对列表内容的筛选,想到了知乎以及google play的效果,确定了是用Toolbar、SearchView、RecyclerView实现Toolbar不用多...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:android顶部(toolbar)搜索框实现
举报原因:
原因补充:

(最多只允许输入30个字)