Android 帶有彈出收縮動畫的扇形菜單實例
更新時間:2017年06月27日 10:57:25 作者:大西瓜的小桃子
本篇文章主要介紹了Android 帶有彈出收縮動畫的扇形菜單實例,具有一定的參考價值,有興趣的可以了解一下
最近試著做了個Android 帶有彈出收縮動畫的扇形菜單,留個筆記記錄一下。
效果如下

public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private ImageView imgPublish;
private TextView textView1;
private TextView textView2;
private boolean isMenuOpen = false;
private List<TextView> textViews = new ArrayList<>();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imgPublish = (ImageView) findViewById(R.id.img_publish);
textView1 = (TextView) findViewById(R.id.tv_1);
textView2 = (TextView) findViewById(R.id.tv_2);
textViews.add(textView1);
textViews.add(textView2);
imgPublish.setOnClickListener(this);
}
@Override
public void onClick(View v) {
switch (v.getId()) {
case R.id.img_publish:
if (!isMenuOpen) {
showOpenAnim(80);
imgPublish.setImageResource(R.mipmap.publish_select);
}else {
showCloseAnim(80);
imgPublish.setImageResource(R.mipmap.fabu);
}
break;
}
}
//打開扇形菜單的屬性動畫, dp為半徑長度
private void showOpenAnim(int dp) {
textView1.setVisibility(View.VISIBLE);
textView2.setVisibility(View.VISIBLE);
//for循環(huán)來開始小圖標(biāo)的出現(xiàn)動畫
for (int i = 0; i < textViews.size(); i++) {
AnimatorSet set = new AnimatorSet();
//標(biāo)題1與x軸負(fù)方向角度為20°,標(biāo)題2為100°,轉(zhuǎn)換為弧度
double a = -Math.cos(20 * Math.PI / 180 * (i * 2 + 1));
double b = -Math.sin(20 * Math.PI / 180 * (i * 2 + 1));
double x = a * dip2px(dp);
double y = b * dip2px(dp);
set.playTogether(
ObjectAnimator.ofFloat(textViews.get(i), "translationX", (float) (x * 0.25), (float) x),
ObjectAnimator.ofFloat(textViews.get(i), "translationY", (float) (y * 0.25), (float) y)
, ObjectAnimator.ofFloat(textViews.get(i), "alpha", 0, 1).setDuration(2000)
);
set.setInterpolator(new BounceInterpolator());
set.setDuration(500).setStartDelay(100);
set.start();
set.addListener(new Animator.AnimatorListener() {
@Override
public void onAnimationStart(Animator animation) {
}
@Override
public void onAnimationEnd(Animator animation) {
//菜單狀態(tài)置打開
isMenuOpen = true;
}
@Override
public void onAnimationCancel(Animator animation) {
}
@Override
public void onAnimationRepeat(Animator animation) {
}
});
}
//轉(zhuǎn)動加號大圖標(biāo)本身45°
ObjectAnimator rotate = ObjectAnimator.ofFloat(imgPublish, "rotation", 0, 90).setDuration(300);
rotate.setInterpolator(new BounceInterpolator());
rotate.start();
}
//關(guān)閉扇形菜單的屬性動畫,參數(shù)與打開時相反
private void showCloseAnim(int dp) {
//for循環(huán)來開始小圖標(biāo)的出現(xiàn)動畫
for (int i = 0; i < textViews.size(); i++) {
AnimatorSet set = new AnimatorSet();
double a = -Math.cos(20 * Math.PI / 180 * (i * 2 + 1));
double b = -Math.sin(20 * Math.PI / 180 * (i * 2 + 1));
double x = a * dip2px(dp);
double y = b * dip2px(dp);
set.playTogether(
ObjectAnimator.ofFloat(textViews.get(i), "translationX", (float) x, (float) (x * 0.25)),
ObjectAnimator.ofFloat(textViews.get(i), "translationY", (float) y, (float) (y * 0.25)),
ObjectAnimator.ofFloat(textViews.get(i), "alpha", 1, 0).setDuration(2000)
);
// set.setInterpolator(new AccelerateInterpolator());
set.setDuration(500);
set.start();
set.addListener(new Animator.AnimatorListener() {
@Override
public void onAnimationStart(Animator animation) {
}
@Override
public void onAnimationEnd(Animator animation) {
textView1.setVisibility(View.GONE);
textView2.setVisibility(View.GONE);
//菜單狀態(tài)置關(guān)閉
isMenuOpen = false;
}
@Override
public void onAnimationCancel(Animator animation) {
}
@Override
public void onAnimationRepeat(Animator animation) {
}
});
}
//轉(zhuǎn)動加號大圖標(biāo)本身45°
ObjectAnimator rotate = ObjectAnimator.ofFloat(imgPublish, "rotation", 0, 90).setDuration(300);
rotate.setInterpolator(new BounceInterpolator());
rotate.start();
}
private int dip2px(int value) {
float density = getResources()
.getDisplayMetrics().density;
return (int) (density * value + 0.5f);
}
}
布局文件
<?xml version="1.0" encoding="utf-8"?>
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.example.lina.animationapplication.MainActivity">
<TextView
android:id="@+id/tv_1"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_gravity="bottom|end"
android:layout_marginBottom="40dp"
android:layout_marginRight="40dp"
android:gravity="center"
android:text="標(biāo)題1"
android:textColor="#ffffff"
android:visibility="gone"
android:background="@drawable/circle_purple"
/>
<TextView
android:id="@+id/tv_2"
android:layout_width="40dp"
android:layout_height="40dp"
android:layout_gravity="bottom|end"
android:layout_marginBottom="40dp"
android:layout_marginRight="40dp"
android:gravity="center"
android:text="標(biāo)題2"
android:textColor="#ffffff"
android:visibility="gone"
android:background="@drawable/circle_orange"/>
<ImageView
android:id="@+id/img_publish"
android:layout_width="60dp"
android:layout_height="60dp"
android:layout_gravity="bottom|end"
android:layout_marginBottom="35dp"
android:layout_marginRight="35dp"
android:src="@mipmap/fabu"
/>
</FrameLayout>
circle_purple.xml
<?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http://schemas.android.com/apk/res/android" android:shape="oval"> <solid android:color="#5d2a89" /> </shape>
參考
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:
- Android編程實現(xiàn)仿優(yōu)酷圓盤旋轉(zhuǎn)菜單效果的方法詳解【附demo源碼下載】
- Android自定義控件之仿優(yōu)酷菜單
- Android仿優(yōu)酷圓形菜單學(xué)習(xí)筆記分享
- Android編程實現(xiàn)仿優(yōu)酷旋轉(zhuǎn)菜單效果(附demo源碼)
- Android菜單(動畫菜單、360波紋菜單)
- Android實現(xiàn)360手機(jī)助手底部的動畫菜單
- Android程序開發(fā)之使用Design包實現(xiàn)QQ動畫側(cè)滑效果和滑動菜單導(dǎo)航
- Android利用屬性動畫實現(xiàn)優(yōu)酷菜單
相關(guān)文章
Android平臺生成二維碼并實現(xiàn)掃描 & 識別功能
這篇文章主要介紹了Android平臺生成二維碼并實現(xiàn)掃描 & 識別功能的相關(guān)資料,需要的朋友可以參考下2016-06-06
淺析Flutter AbsorbPointer 與 IgnorePointer的區(qū)別
Flutter是Google一個新的用于構(gòu)建跨平臺的手機(jī)App的SDK。這篇文章主要介紹了Flutter AbsorbPointer 與 IgnorePointer的區(qū)別,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-04-04
Android webview手動校驗https證書(by 星空武哥)
有些時候由于Android系統(tǒng)的bug或者其他的原因,導(dǎo)致我們的webview不能驗證通過我們的https證書,最明顯的例子就是華為手機(jī)mate7升級到Android7.0后,手機(jī)有些網(wǎng)站打不開了,而更新了webview的補(bǔ)丁后就沒問題了2017-09-09

