层叠按钮,展开、收起(安卓)

本文介绍了一种通过Java实现的层叠按钮动画效果,包括旋转动画和位移动画的实现方式。通过设置按钮状态,可以控制子按钮的展开与收起,并详细展示了如何使用TranslateAnimation和RotateAnimation来实现这一效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

// 设置
boolean SettingAniOn = true;

// 切换层叠按钮状态(层叠、展开)
public void Setting(View view)
{
	settingAni(!SettingAniOn);
}

// 设置按钮层叠动画效果
private void settingAni(boolean on)
{
	SettingAniOn = on;
	final int ANITIME = 300;
	
	// 旋转动画
	View setting = this.findViewById(R.id.setting);
	rotateAni(setting, on, ANITIME);
	
	// 位移动画
	int[] ids = { R.id.music, R.id.about, R.id.more, R.id.help };
	for (int i = 0; i < ids.length; i++)
	{
		View V = findViewById(ids[i]);
		transAni(V, i + 1, on, ANITIME);
	}
}

private void transAni(final View view, int id, final boolean on, final int ANITIME)
{
	final float Y = id * 40;
	
	AnimationSet AniSet = new AnimationSet(true);
	
	TranslateAnimation transAin = new TranslateAnimation(0, 0, on ? Y : 0, on ? 0 : Y);
	transAin.setDuration(ANITIME);
	transAin.setAnimationListener(new AnimationListener()
	{
		@Override
		public void onAnimationStart(Animation arg0)
		{
			view.setClickable(false);
		}
		
		@Override
		public void onAnimationRepeat(Animation arg0)
		{}
		
		@Override
		public void onAnimationEnd(Animation arg0)
		{
			view.setClickable(true);
			view.setVisibility(on ? View.VISIBLE : View.INVISIBLE);
		}
	});
	
	AniSet.addAnimation(transAin);
	view.startAnimation(AniSet);
}

private void rotateAni(final View view, final boolean on, final int ANITIME)
{
	AnimationSet AniSet = new AnimationSet(true);
	final float DEGREE = 180;
	
	RotateAnimation rotateAni = new RotateAnimation(0, on ? DEGREE : -DEGREE, Animation.RELATIVE_TO_SELF, 0.5f, Animation.RELATIVE_TO_SELF, 0.5f);
	rotateAni.setDuration(ANITIME + 30);
	rotateAni.setAnimationListener(new AnimationListener()
	{
		@Override
		public void onAnimationStart(Animation arg0)
		{
			view.setClickable(false);
		}
		
		@Override
		public void onAnimationRepeat(Animation arg0)
		{}
		
		@SuppressLint("NewApi")
		@Override
		public void onAnimationEnd(Animation arg0)
		{
			view.setClickable(true);
			view.setRotation(on ? -DEGREE : 0);
		}
	});
	
	AniSet.addAnimation(rotateAni);
	view.startAnimation(AniSet);
}
// 设置层叠按钮初始状态 true展开、false层叠
public void initSetting(boolean on)
{
	SettingAniOn = on;
	int[] ids = { R.id.music, R.id.about, R.id.more, R.id.help };
	for (int i = 0; i < ids.length; i++)
		findViewById(ids[i]).setVisibility(on ? View.VISIBLE : View.INVISIBLE);
}
ToggleExpandLayout是一个可折叠和展开子view的开关布局控件。它可以将它的子view以阶梯式的展开。项目地址:https://github.com/fenjuly/ToggleExpandLayout 效果图:如何使用<com.fenjuly.mylibrary.ToggleExpandLayout             android:id="@ id/toogleLayout"             android:layout_width="wrap_content"             android:layout_height="80dp"             >             <TextView                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:text="view 1"/>             <TextView                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:text="view 2"/>             <TextView                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:text="view"/>                      </com.fenjuly.mylibrary.ToggleExpandLayout>注意,由于ToggleExpandLayout的本质是个FrameLayout,所以必须将其高度设置为大于所有子view展开状态的高度,不能设为wrap_content。为了解决这个问题,你可以将ToggleExpandLayout的外面在加个DropDownLayout:<com.fenjuly.mylibrary.DropDownLayout         android:layout_width="match_parent"         android:layout_height="match_parent"         >         <com.fenjuly.mylibrary.ToggleExpandLayout             android:id="@ id/toogleLayout"             android:layout_width="wrap_content"             android:layout_height="wrap_content"             >             <TextView                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:text="view 1"/>              <TextView                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:text="view 2"/>               <TextView                 android:layout_width="wrap_content"                 android:layout_height="wrap_content"                 android:text="view"/>                              </com.fenjuly.mylibrary.ToggleExpandLayout> </com.fenjuly.mylibrary.DropDownL
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值