keyboard dialog 仿微博键盘

Posted liuzhen

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了keyboard dialog 仿微博键盘相关的知识,希望对你有一定的参考价值。

 

技术分享图片

功能描述:弹出键盘,右边有最大化按钮,没有最大化的时候最大行数为3,默认1行,随着文字输入增加自动增加高度,到达3行时不会在增加,点击最大化输入框,行数无限制,输入框下方图片点击删除

 技术分享图片

此处为了简便,键盘监听用了一个库,如果自己写也简单,直接 addOnGlobalLayoutListener 便可

首先是点击 edittext ,然后键盘自动弹起

这里的键盘弹起是在dialog里面提供了一个开关

技术分享图片

然后是xml,xml有点讲究,不然达不到自动的效果,这也是实验了多种方式布局选择的一种

图中看出edittext输入框包含了图片浏览一起,其实只是背景效果,两者是分开的,上部分是输入框,下部分是一个列表,两者容器设置一个shape背景,这也看起来就跟一个整体一样,图片嵌入在了输入框里面,然后最下面是一个viewpager的表情列表

技术分享图片

这种方式的布局可以达到一个效果,输入文字增加输入框会自动夸张行数高度,到了maxline后会停止,一开始想直接用约束的,不过试了几种方法达不到最终的效果,因为最大化后约束也会影响着布局,这样要控制的话逻辑代码就多了,所以为了简化这一步逻辑,里面用的常用布局方式,但是外层依然可以约束起来,这样一来最大化就只需要一小段代码就能完美的切换了,我只需要控制输入框的大小,其它布局都会自动调整约束,这样避免了很多逻辑控制操作

技术分享图片

但是这里需要一个高度,不然约束布局起不到作用,除非全部使用常用布局,但是嵌套太多,自从用了 ConstraintLayout 就有强迫症,多一层嵌套心里就不舒服,但是这里也好处理,因为我们需要监听键盘的状态,居然都要监听,那么也就不算多出的逻辑

技术分享图片

上图为切换表情输入框状态时的布局显示隐藏操作

然后我们外层一般使用 setCanceledOnTouchOutside 让dialog点击自动消失,但是这里还有一个要点,就是你操作想要手动让dialog关闭的时候需要使用另外的dialog关闭方法去关闭,否则有的时候dialog中的键盘关闭不了,比如点击发送,我们需要

关闭键盘和dialog

技术分享图片

技术分享图片

到这里一个输入框的雏形就有了

 GitHub:https://github.com/1024477951/FragmentApp

以上是关于keyboard dialog 仿微博键盘的主要内容,如果未能解决你的问题,请参考以下文章

PHP 中的 Telegram Bot 自定义键盘

h5聊天室web端(仿微博微信)|h5仿微信网页端|仿微信界面弹窗

Android仿微博实现添加话题的输入框

仿微博视频边下边播之封装播放器

仿微博视频边下边播之滑动TableView自动播放-b

react网页版聊天|仿微信微博web版|react+pc端仿微信实例