• Android修行手册 - Toolbar搜索联动以及各种监听和小技巧


    往期文章分享

    👉关于作者

    众所周知,人生是一个漫长的流程,不断克服困难,不断反思前进的过程。在这个过程中会产生很多对于人生的质疑和思考,于是我决定将自己的思考,经验和故事全部分享出来,以此寻找共鸣 !!!
    专注于Android/Unity和各种游戏开发技巧,以及各种资源分享(网站、工具、素材、源码、游戏等)
    有什么需要欢迎私我,交流群让学习不再孤单

    在这里插入图片描述

    本文约6千字,新手阅读需要7分钟,复习需要3分钟收藏随时查阅不再迷路

    👉实践过程

    😜监听

    //返回事件的监听,也就是app:navigationIcon属性设置的图片的监听
    idToolBar.setNavigationOnClickListener {
        Toast.makeText(this, "点击了返回", Toast.LENGTH_SHORT).show()
    }
    //右侧点击的监听
    idToolBar.setOnMenuItemClickListener {
        Toast.makeText(this, it.title, Toast.LENGTH_SHORT).show()
        true
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    😜实现搜索

    
    <menu xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:app="http://schemas.android.com/apk/res-auto">
        <item
            android:id="@+id/idTooBarMenuOne"
            android:icon="@mipmap/icon_xin_no"
            android:orderInCategory="1"
            android:title="搜索"
            app:showAsAction="ifRoom|collapseActionView"
            app:actionViewClass="androidx.appcompat.widget.SearchView " />
    menu>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    重点为app:showAsAction和app:actionViewClass属性,actionViewClass表示展开哪个view,上面的android.widget.SearchView是系统的搜索view。

    <androidx.appcompat.widget.Toolbar
        android:id="@+id/idToolBar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="#0000ff"
        app:collapseIcon="@mipmap/icon_xin_yes"
        app:menu="@menu/menu"
        app:titleTextColor="#ff0000" />
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    在这里插入图片描述

    关于搜索的几个监听事件

    //注意import引入的SearchView 要和 menu的item中app:actionViewClass属性一致
    val searchView: SearchView = idToolBar.menu.findItem(R.id.idTooBarMenuOne).actionView as SearchView
    //设置搜索提示语
    searchView.queryHint = "搜索"
    searchView.setOnSearchClickListener {
        //当点击搜索编辑框的时候回调,刚进入的时候默认是点击搜索编辑框的
        Toast.makeText(this@ActivityToolBar, "点击了搜索框", Toast.LENGTH_SHORT).show()
    }
     
    searchView.setOnQueryTextListener(object : SearchView.OnQueryTextListener {
        override fun onQueryTextSubmit(s: String?): Boolean {
            //点击手机软键盘搜索按钮的时候回调
            Toast.makeText(this@ActivityToolBar, "点击了搜索", Toast.LENGTH_SHORT).show()
            return false
        }
     
        override fun onQueryTextChange(s: String?): Boolean {
            //当搜索框中文本发生改变的时候执行
            return false
        }
    })
    
    searchView.setOnQueryTextFocusChangeListener { v, hasFocus ->
        //当得到焦点和失去焦点的时候执行
        if (hasFocus) {
            Toast.makeText(this@ActivityToolBar, "获取了焦点", Toast.LENGTH_SHORT).show()
        } else {
            Toast.makeText(this@ActivityToolBar, "失去了焦点", Toast.LENGTH_SHORT).show()
        }
    }
    
    idToolBar.menu.findItem(R.id.idTooBarMenuOne).setOnActionExpandListener(object : MenuItem.OnActionExpandListener {
        override fun onMenuItemActionExpand(item: MenuItem?): Boolean {
            //展开时执行
            Toast.makeText(this@ActivityToolBar, "进行了展开", Toast.LENGTH_SHORT).show()
            return true
        }
        override fun onMenuItemActionCollapse(item: MenuItem?): Boolean {
            //收起时回调
            Toast.makeText(this@ActivityToolBar, "进行了收缩", Toast.LENGTH_SHORT).show()
            return true
        }
    })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43

    😜改变Overflow

    OverFlow就是溢出的那三个点点。可以自己设置其他的图标,比如一个加号。而且推荐这种方式,其他在theme文件中设置style的属性不太好,官方对这块支持还差点。

    idToolBar.overflowIcon=ContextCompat.getDrawable(this,R.mipmap.dragon_eight)
    
    • 1

    😜修改Menu弹出位置

    只需要在你的主题中设置overlapAnchor属性节课,默认是true会从右上角展示,false为在toolbar下方展示。
    在这里插入图片描述

    当然吗,处了上面属性,还可以在其他文章中看到关于在这修改Menu的样式啥的,但其实不建议在这搞,因为这是主题,不仅仅会应用到这,还会应用到你的其他地方,都是统一的还好,可如果不是,你的处理就麻烦了。

    👉其他

    📢作者:小空和小芝中的小空
    📢转载说明-务必注明来源:https://zhima.blog.csdn.net/
    📢这位道友请留步☁️,我观你气度不凡,谈吐间隐隐有王者霸气💚,日后定有一番大作为📝!!!旁边有点赞👍收藏🌟今日传你,点了吧,未来你成功☀️,我分文不取,若不成功⚡️,也好回来找我。

    温馨提示点击下方卡片获取更多意想不到的资源。
    空名先生

  • 相关阅读:
    Java实现HTTP的上传与下载
    ThinkPHP V6.0.12在php8.1下验证码出现问题
    腾讯被曝要求员工还清90万房贷再离职;苹果因不附带充电器被判赔偿消费者7000元;Git 2.6发布|极客头条
    【Docker】——常用命令
    如何提高课堂教学效率?西安所高校出招了
    c++深拷贝和浅拷贝的区别
    阿里业务平台技术质量部——测试开发面试
    Vue-Router实现带参数跳转,并且保存原页面数据记录
    html做一个分组散点图图的软件
    代码随想录算法训练营Day45 | 动态规划(7/17) LeetCode 70. 爬楼梯 (进阶) 322. 零钱兑换 279.完全平方数
  • 原文地址:https://blog.csdn.net/qq_27489007/article/details/126938403