作者:yummyLau
链接:https://juejin.im/post/5eddf8456fb9a04804041738

文章是转载的哦 ,感兴趣的可以看看作者其他的文章,我个人觉得挺不错的。

起因

事情是这样的。

4年前毕业那会,呆在公司的短视频项目,做 视频。那会做得比抖音还早,但是由于短视频太烧钱了,项目被公司关掉了。当时需要开发横竖屏直播/异步视频的场景,就研究下了市场上的 app,发现输入弹幕的交互并不友好。最直接的体验就是,微信比绝大部分IM软件在聊天场景下输入法与表情面板频繁切换时表现得更为平滑,不会给用户很突兀的闪烁感。但我们除了适配竖屏,们还需要兼容横屏/满屏/沉浸等场景。

摸索了一段时间之后,做出来的效果挺不错,比市面上的直播/异步视频播放场景下的输入交互体验都要好。于是写了个记录的 Blog Android -SystemUI的那点事 。主要是将如何设计横竖屏直/点播场景下良好的输入交互。但是文章并没有写完… 留了横屏模式下使用 PopupWindow 来实现的悬念… 本打算继续接着写第二篇。结果一拖,就是三年。

而在这三年里,前后参与开发了十多个项目(我们是流水线生产,老工具人),而涉及到输入交互的模块已经有IM聊天,直播间,异步视频播放页面,信息流评论等等。这些页面从最初使用 Activity 实现到演化成可用 Fragment,Dialog,PopupWindow 代替。所以原来那套技术实现已经不能满足。在寻找外部开源项目/技术博文无果的前提下,慢慢积累了一个库。也就是今想推荐的 PanelSwitchHelper,并且还了三年前博文的

PanelSwitchHelper 技术篇

网络上随便搜索 “聊天输入框跳闪” 就有大量讲述同个技术方案的博文,依靠动态更改 LinearLayout - weight 数值,随 Window 更改动态调整内容区域高度来做到不闪跳的效果。但是也是仅仅不闪跳,但是会有生硬的 “忽隐忽现” 的效果。PanelSwitchHelper 早期也是如此实现。微信前几年的体验也是如此,后来体验做得越来越好,过渡变得十分平滑,其方案应该不是这样做的(个人见解)。为了能做到这种平滑的效果,尝试在原来的技术进行优化,但是效果很不如意,因为这些缺陷是由技术选型决定的,所以开始寻找新的技术方案。

为了更好的讲述下面方案,我们把输入法和表情面板等都统称为功能面板。

实践了一段时间后,决定使用手动干预 Layout 逻辑并借助系统过渡动画来实现 “类微信” 的平滑过渡。

新的模式

我们称新的实现为 “内容滑动模式”,旧的实现为 “内容固定模式”。输入交互切换前后大概如下图。

  • 蓝色区域为内容区域,比如聊天IM界面上,蓝色区域大多数为 Recyclerview 实现的聊天列表
  • 绿色区域为面板区域,用于存储功能面板,比如微信的表情界面

在滑动模式下,图2是功能面板显示的结构图。也就是说,无论是输入法显示与否,蓝色区域相对于图一向上滑动了等量输入法高度的距离。当从输入法切换到其他功能面板(比如表情面板)时,如果原表情面板就已经显示在输入法底下,则可无缝的显露出来。

而上述的想法,需要干预到蓝色及绿色区域的 layout 逻辑。从滑动模式下的图一切换称图二时,其整体高度实际上不变,而 layout 的启始坐标是改变的,整体 Bound 也是发生了更改,借助 ChangeBounds 可实现平滑过渡。

实现之后效果大致如下。

使用也是非常简单。

new PanelSwitchHelper.Builder(this).addKeyboardStateListener {}.addEditTextFocusChangeListener {}.addViewClickListener {}.addPanelChangeListener {}.contentCanScrollOutside(true).logTrack(true)                  .build()
复制代码

为了追求更高的实时体验,我们还需要兼容用户可能随时调整输入法高度,随时显示/隐藏导航栏配置。

某一天,奇怪的屏幕来了,挖孔屏/刘海屏/全面屏。

某一天,issue 反馈 Pad 有点适配问题。

某一天,部分使用库的朋友反馈说直播间怎么处理。

维护这个库,基本都是鉴于自己的兴趣爱好,而且一般提议的功能会被审核,合理的需求都会被安排!

“ 统统支持!”

库的优势

经过多个版本迭代之后,框架表现出来的优势:

  1. 改进传统使用 Weight+LinearLayout 动态更改布局高度适配面板的技术方案,支持多种原生 ViewGroup 容器
  2. 为了追求更平滑的适配效果,当输入法动态调整高度或动态隐藏导航栏时,功能面板能实时适配
  3. 为了追求更流畅的切换效果,支持滑动模式,滑动会更流畅,同时也支持固定模式
  4. 丰富的机型适配,适配 全面屏/刘海屏/挖孔屏/Pad 等非常规 Phone 机型
  5. 丰富的场景支持,支持 Activity/Fragment/Dialog/PopupWindow,应用到聊天/视频/直播/信息流评论等场景
  6. 丰富的 API 支持,可自定义内容容器,业务面板,灵活控制面板隐藏,灵活控制切换面板速度

如果你担心不知道怎么用,Smaple 已经最直白的帮你梳理了你所需要的场景及 API 演示

如果你想看到更多的场景介绍,可前往 场景使用介绍

如果你想了解更多API使用,可前往 API使用指南

部分场景演示

最后下对比 BiliBili/虎牙直播/抖音直播/微信朋友圈的效果。

BiliBili 视频播放场景

对比结果:比 BiliBili 的切换更平滑

抖音直播场景

对比结果:比 抖音直播 的切换更平滑

虎牙直播场景

对比结果:比 虎牙直播 的切换更平滑

朋友圈评论场景

对比结果:比 朋友圈 的切换效果基本一致

小结

如果你还为输入场景的页面变换忧愁,PanelSwitchHelper 可以帮助你解决非常多的问题。重要的是,我还可以协助你解决你可能遇到的困难呀~。

如果你未来还可以需要开发涉及输入场景的功能,PanelSwitchHelper 可以成为你的首选。

欢迎前往体验,任何问题可提 issue ,我会第一时间回复,如有帮助, 下呗。

大家感兴趣兴趣的话,后续会更一篇文章写库的细节实现及适配众多奇葩场景的奇思异想。

短视频知识学习与分享

音视频、直播、“人工智障”,前些年比较火的一些项目最终都是落地于移动平台,而现在 NDK 技术已经成为了Android开发的必备技能了,大多数的公司都要求掌握NDK,还有部分更是把精通NDK的人才作为招聘目标

记得有次一个群里的仔就跟我吐槽,面试没过,回复他“对不起,你很优秀,但是不太适合我们公司的岗位”所以到底做短视频开发,要学哪些知识呢?

[图片上传失败…(image-4b5c35-1591708283474)]

  • NDK模块

C/C++、jni、Linux基础、音视频编解码技术、流媒体协议、ffmpeg,OpenCV、OpenGl等等

以上只是一部分,由于篇幅问题,就不一一展示了,随着抖音,快手等短视频快速崛起,这个技术可以说是今年最火的,而我这份资料可以说是最系统最详细的,每一个点都会扩大来详细讲。所以在学习这方面的朋友,点击【NDK】 了解更多,即可领取!

  • NDK进阶学习全套手册

  • Android高级架构师NDK系统学习核心笔记

@Android程序员今年必看!!拖更了三年带回了一个抖音,虎牙,哔哩哔哩都在用的库|墙裂推荐相关推荐

  1. 程序员今年必看!!拖更了三年带回了一个抖音,虎牙,哔哩哔哩都在用的库|墙裂推荐

    前言 金三银四到来了,找工作的好时候到了,小伙伴们是不是都在忙着找工作呢,小弟前一阵也是忙着在找工作,面试了好多公司,所幸的是进到了自己心仪的公司,也是很幸运的.下面我将自己亲身实战的面试题及收到的面 ...

  2. 想转行当程序员的必看!揭秘ARouter路由机制,Android校招面试指南

    Android没凉,只是比以前难混了 多年前Android异军突起,成了新的万亿级市场,无数掘金人涌入,期待可以一展拳脚. 那时候大环境下的手游圈,只要你能有个可以运行的连连看就能找到工作,走上赛道被 ...

  3. 优秀的程序员职业生涯必看五本书

    我认为通过书籍去学编程基础知识,是个不错的选择,但是,对于日常工作中需要用到的高级技术,我并不是很喜欢通过书籍学习,因为编程的基本概念通常不会有太大的变化,但过了这个阶段,你的学习应该更加自主,而不是 ...

  4. 年薪40W的程序员需要掌握怎样的技术(Java程序员高薪必看)

    很多人在问我,程序员如何拿高薪,如何做到年薪40W+,其实总结出来还是一句话,你的技术决定你的能力已经薪资. 那么什么样的技术人才才能拿到一份Java行业里面的高薪呢? 下面是我的一个总结技术: 最后 ...

  5. Java程序员2022必看面试题(含答案)

    每个技术人都有个大厂梦,我觉得这很正常,并不是饭后的谈资而是每个技术人的追求.像阿里.腾讯.美团.字节跳动.京东等等的技术氛围与技术规范度还是要明显优于一些创业型公司/小公司,如果说能够在这样的公司锻 ...

  6. 资深程序员教你,用python入门的知识抓取抖音短视频,太厉害了

    抖音短视频可以说是当下最流行的自媒体平台,而python编程同样也是目前最流行的编程语言. 今天,就让一位大厂的资深程序员,用最简单的方式,使用python抓取抖音短视频. 到时候我会把所有的源代码都 ...

  7. 想转行当程序员的必看!2021年Android春招面试经历,威力加强版

    前言 今天我给大家再次分享一下,我最近的一些读书的感想,思考起来,确实能够给自己带来一些真实的帮助和启发,希望大家在平时的工作学习中,也能够认清楚学习的一些本质. 如果我们的学习是在不断掌握应对具体工 ...

  8. html列表按时间排序代码_程序员小白必看:腾讯视频版排序列表的实现

    每当我们对国产剧失望的时候 总会有一部令人惊喜的剧目横空出世 这几天你一定被一个国产剧刷屏了 它就是<隐秘的角落> 图片源于网络,仅作配文展示 也许你并不是"第一个吃螃蟹的人&q ...

  9. 程序员面试必看30道智力题

    二进制问题 金条问题 有个商人雇用了一位手艺高超的工匠了为他做一个精致产品,工作一星期七天的代价是一条金条.商人手头上有一条金条,刚好有可以付工匠一星期的工钱.但工匠要求工钱要按每天来付.虽然他并不急 ...

最新文章

  1. linux ls没有反应_Linux入门②“命令格式”
  2. CISCO 组播RPF 逆向路径转发 实验原理
  3. 怎么改善现有网站为xhtml+CSS
  4. git 如何取消add操作
  5. 05.Bootstrap导入基础笔记
  6. tensorflow英语怎么读_英语不行?你可以试试TensorFlow官方中文版教程
  7. VS修改生成应用图标
  8. opencv 编译静态库
  9. 我与CSDN的2020年
  10. 交互式电子杂志_快速的创建交互式演示和翻转电子书工具-XFlip Enterprise(电子杂志相册制作器) V2.0.5.0 中文版 - 未来软件园...
  11. vb导出mysql字段名_VB获取数据库字段名
  12. 【第四课】UAV倾斜摄影测量三维建模技术软件——Smart 3d
  13. Linux中rz命令与sz命令
  14. 2019六月广东省计算机二级报名,广东2019年3月全国计算机二级考试报名时间通知...
  15. 战意显示与服务器断开连接,战意服务器地址
  16. Ruby+Selenium demo
  17. UiAutomator Android 的自动测试框架(基础)
  18. CocosCreator之微信小游戏的聊天/提示气泡制作
  19. 高效能人士的七个习惯及亚马逊十四条领导力准则
  20. System32和SysWoW64的区别(转载)

热门文章

  1. 小程序各个文件夹的作用分类
  2. Eval Reset忘记重置怎么办
  3. 【BUG记录】Idea spring boot项目中target中没有同步更新最新目录文件及资源
  4. 30行python代码实现微信自动陪女盆友聊天(itchat-uos + 无限制调用)
  5. java计算机毕业设计基于springboo+vue的共享单车自行车管理系统
  6. 【算法Algorithm】计数(Count)排序
  7. 211院校实习生三跨Java面经(头条、拼多多、华为、vivo)
  8. 2021.06.29【R语言】丨png转pdf批量生成
  9. perf: interrupt took too long
  10. matlab示波器横轴变纵轴,excel表格横轴数据变纵轴-在EXCEL中做图表,横坐标和纵坐标如何调换?...