为了更好的讲述下面方案,我们把输入法和表情面板等都统称为功能面板。
实践了一段时间后,决定使用手动干预 Layout 逻辑并借助系统过渡动画来实现 “类微信” 的平滑过渡。
我们称新的实现为 “内容滑动模式”,旧的实现为 “内容固定模式”。输入交互切换前后大概如下图。
在滑动模式下,图2是功能面板显示的结构图。也就是说,无论是输入法显示与否,蓝色区域相对于图一向上滑动了等量输入法高度的距离。当从输入法切换到其他功能面板(比如表情面板)时,如果原表情面板就已经显示在输入法底下,则可无缝的显露出来。
而上述的想法,需要干预到蓝色及绿色区域的 layout 逻辑。从滑动模式下的图一切换称图二时,其整体高度实际上不变,而 layout 的启始坐标是改变的,整体 Bound 也是发生了更改,借助 ChangeBounds 可实现平滑过渡。
实现之后效果大致如下。
使用也是非常简单。
new PanelSwitchHelper.Builder(this)
.addKeyboardStateListener {}
.addEditTextFocusChangeListener {}
.addViewClickListener {}
.addPanelChangeListener {}
.contentCanScrollOutside(true)
.logTrack(true)
.build()
复制代码
为了追求更高的实时体验,我们还需要兼容用户可能随时调整输入法高度,随时显示/隐藏导航栏配置。
某一天,奇怪的屏幕来了,挖孔屏/刘海屏/全面屏。
某一天,issue 反馈 Pad 有点适配问题。
某一天,部分使用库的朋友反馈说直播间怎么处理。
维护这个库,基本都是鉴于自己的兴趣爱好,而且一般提议的功能会被审核,合理的需求都会被安排!
“ 统统支持!”
经过多个版本迭代之后,框架表现出来的优势:
如果你担心不知道怎么用,Smaple 已经最直白的帮你梳理了你所需要的场景及 API 演示
如果你想看到更多的场景介绍,可前往 场景使用介绍
如果你想了解更多API使用,可前往 API使用指南
最后下对比 BiliBili/虎牙直播/抖音直播/微信朋友圈的效果。
对比结果:比 BiliBili 的切换更平滑
对比结果:比 抖音直播 的切换更平滑
改变人生,没有什么捷径可言,这条路需要自己亲自去走一走,只有深入思考,不断反思总结,保持学习的热情,一步一步构建自己完整的知识体系,才是最终的制胜之道,也是程序员应该承担的使命。
如果有需要进阶Android高级工程师系统学习资料的,我可以免费分享给大家,需要完整版的朋友,【点这里可以看到全部内容】。
《系列学习视频》
《系列学习文档》
《我的大厂面试之旅》
标签: