登录页Activity从下向上的弹出效果实现

最近产品有需求,一开始通过启动页进入登录页是正常的页面跳转,而后要进入主页面,在主页面里面的点击判断是否是登录状态,然后登录页从下向上弹出。这个需求一开始感觉应该不是很麻烦,直接用

overridePendingTransition(R.anim.anim_activity_up, 0)

anim_activity_up的文件为:

<?xml version="1.0" encoding="utf-8"?>
<translate
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:duration="200"
    android:fromYDelta="100%p"
    android:toYDelta="0%p"
    >
</translate>

然后这时候运行的时候问题就来了,切换的时候会有黑的阴影闪现,然后谷歌方案一般都是说设置主题,在里面添加如下代码:

<item name="android:windowIsTranslucent">true</item>

这个是改 Activity 的背景为透明,因为一开始设置主题的父主题为:

parent="Theme.AppCompat.Light.NoActionBar"

页面的状态栏也会变成黑色,跟着页面一块来从下往上走,效果也不好。并且设置这个透明色以后,原先的页面跳转也会跟着变化。。。谷歌了一下是确实有这个问题,折腾了好久,最终改变方案。

用 popupwindow 来实现,设置其弹出跟关闭的动画,动画效果可以达到产品效果,但是如果popupWindow弹出,这个时候按下 home 键,然后点击图标进入,popupWindow 页面的动画效果就会再展现一遍,个人感觉有可能是由下面的设置造成:

<item name="android:windowEnterAnimation">@anim/menushow</item>
     <item name="android:windowExitAnimation">@anim/menuhide</item>

设置进入跟退出的动画。效果还是不理想。

这个问题被同组的大神也遇到过,他设置的页面也是点击从下到上弹出,并且说设置overridePendingTransition后面的参数为0的时候没有效果,必须自己去写来实现这个效果,最终代码如下:

overridePendingTransition(R.anim.anim_activity_up,R.anim.anim_activity_stay)

anim_activity_stay的文件为:

<?xml version="1.0" encoding="utf-8"?>
<set  xmlns:android="http://schemas.android.com/apk/res/android">
    <alpha
        android:duration="200"
        android:fromAlpha="1"
        android:toAlpha="1"
        />
</set>

其实就是设置透明度一直为1,效果实现跟产品要求一致,并且不用重新另起一个页面了,一开始的研究方向就出问题了。

记自己的一次踩坑之旅,后者可以少耽误点时间了,共勉

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容