ObjectAnimator實現菜單的彈出(扇形)

用ObjectAnimator 實現菜單的彈出java

 

首先是菜單的圖片資源和佈局android

 

佈局中使用FrameLaout 將菜單喚出對應的imageView放在佈局的最後面來隱藏菜單詳細內容。app

<?xml version="1.0" encoding="utf-8"?>
<FrameLayout 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=".MainActivity">

<ImageView
android:id="@+id/imageView_b"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/b"/>
<ImageView
android:id="@+id/imageView_c"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/c"/>
<ImageView
android:id="@+id/imageView_d"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/d"/>
<ImageView
android:id="@+id/imageView_e"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/e"/>
<ImageView
android:id="@+id/imageView_f"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/f"/>

<ImageView
android:id="@+id/imageView_g"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/g" />
<ImageView
android:id="@+id/imageView_a"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dp"
android:paddingTop="5dp"
android:layout_gravity="bottom|right"
android:src="@drawable/a"/>

</FrameLayout>

 

 

 
 
package com.a18470.mooc_animtest;import android.animation.AnimatorSet;import android.animation.ObjectAnimator;import android.support.v7.app.AppCompatActivity;import android.os.Bundle;import android.util.Log;import android.view.View;import android.view.animation.BounceInterpolator;import android.widget.ImageView;import android.widget.Toast;import java.util.ArrayList;import java.util.List;public class MainActivity extends AppCompatActivity implements View.OnClickListener{    private int[] res = {R.id.imageView_a, R.id.imageView_b, R.id.imageView_c,            R.id.imageView_d, R.id.imageView_e, R.id.imageView_f, R.id.imageView_g};    private List<ImageView> imageViewList = new ArrayList<ImageView>();    private boolean flag = false;    protected void onCreate(Bundle savedInstanceState) {        super.onCreate(savedInstanceState);        setContentView(R.layout.activity_main);        for(int i=0;i<res.length;i++){            ImageView imageView = findViewById(res[i]);            imageView.setOnClickListener(this);            imageViewList.add(imageView);        }    }    @Override    public void onClick(View v) {        switch (v.getId()){            case R.id.imageView_a:                for (int i = 1; i < res.length; i++) {                    ImageView menu = imageViewList.get(i);                    double angle = Math.toRadians(i * (90 * 1.0 / (res.length - 1))); // 角度                    double radius = 450; // 半徑                    float distanceX = (float) (Math.cos(angle) * radius); // X座標偏移量                    float distanceY = (float) (Math.sin(angle) * radius); // Y座標偏移量                    ObjectAnimator animatorX;                    ObjectAnimator animatorY;                    if (flag) { // 若是菜單是打開的則關閉菜單                        animatorX = ObjectAnimator.ofFloat(menu, "translationX", -distanceX, 0f);                        animatorY = ObjectAnimator.ofFloat(menu, "translationY", -distanceY, 0f);                    } else { // 若是菜單是關閉的則打開菜單                        animatorX = ObjectAnimator.ofFloat(menu, "translationX", 0f, -distanceX);                        animatorY = ObjectAnimator.ofFloat(menu, "translationY", 0f, -distanceY);                    }                    AnimatorSet set = new AnimatorSet(); // X、Y軸同時移動                    set.playTogether(animatorX, animatorY);                    set.setDuration(500);                    set.setInterpolator(new BounceInterpolator());                    set.start();                }                flag = !flag;                break;            default:                Toast.makeText(MainActivity.this,"click"+v.getId(),Toast.LENGTH_SHORT).show();                break;        }    }}
相關文章
相關標籤/搜索