登录页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,效果实现跟产品要求一致,并且不用重新另起一个页面了,一开始的研究方向就出问题了。

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 153,680评论 23 675
  • 愚蠢的 傲慢的 愚蠢和傲慢的 幻想的 愚昧的 幻想的愚昧 若近若离的 撕心裂肺的 孤独的矗立 暧昧的 欲望的 之后...
    張聯凱阅读 28评论 0 0
  • 愿你一直快乐。 大家国庆快乐~~~
    云朵儿z阅读 31评论 0 1