最近实现了一个从点击处弹出的对话框,最终效果如下:

1. 接招
实现对话框功能可选择的技术有 Dialog、PopupWindow、Activity。它们都支持自定义弹出和消失动画。它们都能实现自定义动画。
| WindowAnimation | Transition | ShareElement Transition | |
|---|---|---|---|
| Dialog | 支持 | 不支持 | 不支持 |
| PopupWindow | 支持 | 支持 | 不支持 |
| Activity | 支持 | 支持 | 支持 |

WindowAnimation动画必须要在styles.xml中定义,不能通过代码动态设置windowEnterAnimation、windowExitAnimation。意味着windowAnimation一旦设置好了
动画是固定不变的,显然无法满足从点击处做弹出动画的功能。排除Dialog。Activity同时支持过渡动画和共享元素过渡动画。经过一番尝试,发现虽然Activity支持丰富
的过渡动画,但是并不适合完成该场景的功能,最终决定采用PopupWindow实现该功能。
2. 拆招
该动画的特征是:从手指点击处做放大动画同时将对话框的中心点平移到屏幕中心。核心代码如下

3. 解招
最终代码

4. 获取完整源码
关注微信公众号"字节小站",回复"对话框",获取完整源码
本文介绍了使用PopupWindow实现从点击位置弹出对话框的方法。对比了Dialog、PopupWindow及Activity的特点,最终选择了PopupWindow来实现自定义动画,并详细描述了实现过程。
733

被折叠的 条评论
为什么被折叠?



