透明且可具有滑入滑出动画效果的Activity 样式

1.设置主题


    <activity 
    android:name="XXX.Activity"
    android:screenOrientation="portrait"
    android:theme="@style/MyDialogStyleBottom"/>


2.设置样式 theme (继承Dialog主题)


  <style name="MyDialogStyleBottom" parent="android:Theme.Dialog">
        <!--动画效果-->
        <item name="android:windowAnimationStyle">@style/AnimBottom</item>
        <!-- 边框 -->
        <item name="android:windowFrame">@null</item>
        <!-- 是否浮现在activity之上 -->
        <item name="android:windowIsFloating">false</item>
        <!-- 半透明 -->
        <item name="android:windowIsTranslucent">true</item>
        <!-- 无标题 -->
        <item name="android:windowNoTitle">true</item>
        <!-- 背景透明 -->
        <item name="android:windowBackground">@android:color/transparent</item>
        <!-- 模糊 -->
        <item name="android:backgroundDimEnabled">true</item>
    </style>


    2.1 程序更新时候的样式
     <style name="CMYDialog" parent="@android:style/Theme.Dialog">
        <item name="android:windowFrame">@null</item>
        <item name="android:windowIsFloating">true</item>
        <!--是否有遮盖 -->
        <item name="android:windowContentOverlay">@null</item>
        <item name="android:windowNoTitle">true</item>
        <item name="android:background">@color/transparent</item>
        <item name="android:windowBackground">@color/transparent</item>
        <item name="android:backgroundDimEnabled">true</item>
    </style>


3.设置动画 AnimBottom  (继承动画类Animation, 样式为:上下滑入)
    <style name="AnimBottom" parent="@android:style/Animation">
        <item name="android:windowEnterAnimation">@anim/push_bottom_in</item>
        <item name="android:windowExitAnimation">@anim/push_bottom_out</item>
    </style>


    3.1 进入的样式 <push_bottom_in>


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


    3.2 滑出的样式 <push_bottom_out>


    <?xml version="1.0" encoding="utf-8"?><!-- 上下滑出式 -->
    <set xmlns:android="http://schemas.android.com/apk/res/android">
        <translate
            android:duration="200"
            android:fromYDelta="0"
            android:toYDelta="50%p" />
    </set>
  
 4.资料:
    1. translate 位置转移动画效果  
            整型值:  
                fromXDelta 属性为动画起始时 X坐标上的位置  
                toXDelta   属性为动画结束时 X坐标上的位置  
                fromYDelta 属性为动画起始时 Y坐标上的位置  
                toYDelta   属性为动画结束时 Y坐标上的位置  
                注意:  
                         没有指定,  
                         默认是以自己为相对参照物  
            长整型值:  
                duration  属性为动画持续时间  


                说明:   时间以毫秒为单位  


    在这些属性里面还可以加上%和p,例如:


    android:toXDelta="100%",表示自身的100%,也就是从View自己的位置开始。


    android:toXDelta="80%p",表示父层View的80%,是以它父层View为参照的。


2.windowIsFloating的讲解:
windowIsFloating属性设置为false,默认将Window设置成全屏大小,设置为true,则window大小为wrap_content。


如果dialog布局大小不变,而window大小为全屏,且gravity没有设置为center,那么可能导致dailog在左上角而不是中间,而且window大小全屏时会导致touchoutside失效。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值