android 关于SpringAnimation弹性弹框小demo

近期有同事想在app有新版本的时候弹出一个弹性的弹出框,给了一点意见,让多看看SpringAnimation,随后自己就整理了一下,把这个demo写出来记录一下,有需要的朋友可以做个参考,有不对的地方请多多指教。

首先导入:

compile 'com.android.support:support-dynamic-animation:25.3.0'

注意:导入可能会冲突报错,

可以修改这里

minSdkVersion 16
targetSdkVersion 25

话不多说,直接上代码:

MainActivity.java

import android.app.Dialog;
import android.support.animation.SpringAnimation;
import android.support.animation.SpringForce;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        Button mButton = (Button)findViewById(R.id.mButton);
        mButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                showDialog();
            }
        });

    }

    /**
     * 弹性弹框
     */
    private void showDialog() {
        Dialog dialog = new Dialog(
                MainActivity.this,
                R.style.test_dialog);

        //整个弹框布局
        View contentView = getLayoutInflater().inflate(R.layout.mytest_dialog, null);
        //弹性动画的布局
        View test_view = contentView.findViewById(R.id.test_view);

        dialog.setContentView(contentView);

        dialog.setCanceledOnTouchOutside(true);

        //Stiffness越小,弹性效果越好,弹的时间越长。DampingRatio的值越大,弹性效果越差。
        //StartVelocity开始速度,单位是px/second.正数是弹簧收缩的方向,负数则相反。
        SpringAnimation signUpBtnAnimY = new SpringAnimation(test_view,SpringAnimation.TRANSLATION_Y,0);
        signUpBtnAnimY.getSpring().setStiffness(SpringForce.STIFFNESS_VERY_LOW);
        signUpBtnAnimY.getSpring().setDampingRatio(SpringForce.DAMPING_RATIO_LOW_BOUNCY);
        signUpBtnAnimY.setStartVelocity(10000);
        signUpBtnAnimY.start();
        dialog.show();
    }
}

 

 

布局文件activity_main.xml

 

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.coin.bit.myapplication3.MainActivity">

    <TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Hello World!"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintLeft_toLeftOf="parent"
        app:layout_constraintRight_toRightOf="parent"
        app:layout_constraintTop_toTopOf="parent" />



    <Button
        android:id="@+id/mButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="show"/>

</android.support.constraint.ConstraintLayout>

 

弹框布局文件:mytest_dialog.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent"
    android:layout_height="match_parent">


    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        android:layout_centerInParent="true">
        <View
            android:layout_width="200dp"
            android:layout_height="50dp"
            android:background="#e60000"/>


        <View
            android:id="@+id/test_view"
            android:layout_width="200dp"
            android:layout_height="200dp"
            android:background="#00FF00"/>
    </LinearLayout>
</RelativeLayout>

样式:test_dialog.xml

<style name="test_dialog" parent="@android:style/Theme.Dialog">
    <item name="android:windowFrame">@null</item>
    <item name="android:windowIsFloating">true</item>
    <item name="android:windowIsTranslucent">true</item>
    <item name="android:windowNoTitle">true</item>
    <item name="android:background">#00000000</item>
    <item name="android:windowBackground">@color/transparent</item>
    <item name="android:backgroundDimEnabled">true</item>
</style>
<color name="transparent">#00000000</color>

参考:https://www.jianshu.com/p/c2962a8135f5

希望对您有帮助,祝您生活愉快!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值