Android实现带动画效果的Tab Menu

来源:互联网 发布:淘宝卖家怎么设置会员 编辑:程序博客网 时间:2024/04/30 08:46

大家好,今天给大家介绍如何在Android下实现一个带动画效果的Tab Menu。Tab Menu的打开动画效果为自下而上的淡入推进效果,关闭效果为自上而下的淡出推出效果。

实现的效果图如下(没有找到合适的屏幕录像工具,只能截静态图):


实现这个Tab可以替代android系统丑陋的menu界面,当用户点击menu按钮时,通过使用钩子函数onKeyDown(int keyCode, KeyEvent event)

捕获menu按键事件,实现打开或者关闭Tab。当Tab打开后,按back按键会关闭Tab。

以下为关键代码,代码说明请看注释,完整工程代码下载请按此:

TabMenuActivity.java

package com.zhuozhuo;import android.app.Activity;import android.os.Bundle;import android.view.KeyEvent;import android.widget.TextView;public class TabMenuActivity extends Activity {/** Called when the activity is first created. */TabView dockView;TextView tv;@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);tv = (TextView) findViewById(R.id.tv);dockView = new DockView(this);}public boolean onKeyDown(int keyCode, KeyEvent event) {if (keyCode == KeyEvent.KEYCODE_MENU) {//监听menu键if(dockView.isOpen()) {tv.setText("点击menu键打开dock");dockView.closeDock();//关闭dock}else {tv.setText("再次点击menu键或者back键关闭dock");dockView.openDock();//打开dock}return true;}if (keyCode == KeyEvent.KEYCODE_BACK) {//监听back键if(dockView.isOpen()) {//当dock打开时,按back键关闭dockdockView.closeDock();return true;}}return super.onKeyDown(keyCode, event);}}
TabView.java

package com.zhuozhuo;import android.app.Activity;import android.content.Context;import android.view.View;import android.view.View.OnClickListener;import android.view.animation.Animation;import android.view.animation.Animation.AnimationListener;import android.view.animation.AnimationUtils;import android.widget.Toast;public class TabView {private static final int INTERVAL_TIME = 50;// 每个tab之间的动画时间间隔msprivate View tab1;private View tab2;private View tab3;private View tab4;private Activity context;private boolean isOpen;public TabView(Activity context) {this.context = context;tab1 = context.findViewById(R.id.tab1);tab2 = context.findViewById(R.id.tab2);tab3 = context.findViewById(R.id.tab3);tab4 = context.findViewById(R.id.tab4);setOnClickListener(tab1, 1);setOnClickListener(tab2, 2);setOnClickListener(tab3, 3);setOnClickListener(tab4, 4);}public void openDock() {//打开docktab(tab1, 0, true);tab(tab2, INTERVAL_TIME * 1, true);tab(tab3, INTERVAL_TIME * 2, true);tab(tab4, INTERVAL_TIME * 3, true);isOpen = true;}private void setOnClickListener(View view, final int pos) {view.setOnClickListener(new OnClickListener() {@Overridepublic void onClick(View v) {Toast.makeText(context, "view" + pos + " click!", Toast.LENGTH_SHORT).show();//点击tab时显示toastcloseDock();}});}private void tab(final View view,int delayTime,final boolean toOpen) {view.postDelayed(new Runnable() {@Overridepublic void run() {Animation animation;if(toOpen) {view.setVisibility(View.VISIBLE);//动画开始前,设置view可见animation = AnimationUtils.loadAnimation(context, R.anim.show_tab);view.startAnimation(animation);}else {animation = AnimationUtils.loadAnimation(context, R.anim.close_tab);animation.setAnimationListener(new AnimationListener() {@Overridepublic void onAnimationStart(Animation animation) {}@Overridepublic void onAnimationRepeat(Animation animation) {}@Overridepublic void onAnimationEnd(Animation animation) {view.setVisibility(View.INVISIBLE);//动画结束时,view不可见}});view.startAnimation(animation);}}}, delayTime);}public boolean isOpen() {return isOpen;}public void closeDock() {//关闭docktab(tab1, 0, false);tab(tab2, INTERVAL_TIME * 1, false);tab(tab3, INTERVAL_TIME * 2, false);tab(tab4, INTERVAL_TIME * 3, false);isOpen = false;}}

res/anim/close_tab.xml

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android">    <translate android:fromYDelta="0" android:toYDelta="100%p" android:duration="300"/><alpha android:fromAlpha="1.0" android:toAlpha="0.0" android:duration="300" /></set>

res/anim/show_tab.xml

<?xml version="1.0" encoding="utf-8"?><set xmlns:android="http://schemas.android.com/apk/res/android">    <translate android:fromYDelta="100%p" android:toYDelta="0" android:duration="300"/><alpha android:fromAlpha="0.0" android:toAlpha="1.0" android:duration="300" /></set>
res/layout/main.xml

<?xml version="1.0" encoding="utf-8"?><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical" android:layout_width="fill_parent"android:layout_height="fill_parent"><TextView android:id="@+id/tv" android:layout_width="wrap_content" android:layout_height="wrap_content" /><LinearLayout android:layout_height="wrap_content"android:layout_width="match_parent" android:layout_alignParentBottom="true"><LinearLayout android:layout_weight="1" android:id="@+id/tab1"android:layout_height="wrap_content" android:gravity="center"android:layout_width="wrap_content" android:orientation="vertical"android:visibility="invisible"><ImageView android:layout_width="wrap_content"android:layout_height="wrap_content" android:src="@drawable/icon" /><TextView android:text="Tab1" android:layout_width="wrap_content"android:layout_height="wrap_content" /></LinearLayout><LinearLayout android:layout_weight="1" android:id="@+id/tab2"android:layout_height="wrap_content" android:layout_width="wrap_content"android:gravity="center" android:orientation="vertical"android:visibility="invisible"><ImageView android:layout_width="wrap_content"android:layout_height="wrap_content" android:src="@drawable/icon" /><TextView android:text="Tab1" android:layout_width="wrap_content"android:layout_height="wrap_content" /></LinearLayout><LinearLayout android:layout_weight="1" android:id="@+id/tab3"android:layout_height="wrap_content" android:layout_width="wrap_content"android:gravity="center" android:orientation="vertical"android:visibility="invisible"><ImageView android:layout_width="wrap_content"android:layout_height="wrap_content" android:src="@drawable/icon" /><TextView android:text="Tab1" android:layout_width="wrap_content"android:layout_height="wrap_content" /></LinearLayout><LinearLayout android:layout_weight="1" android:id="@+id/tab4"android:layout_height="wrap_content" android:layout_width="wrap_content"android:gravity="center" android:orientation="vertical"android:visibility="invisible"><ImageView android:layout_width="wrap_content"android:layout_height="wrap_content" android:src="@drawable/icon" /><TextView android:text="Tab1" android:layout_width="wrap_content"android:layout_height="wrap_content" /></LinearLayout></LinearLayout></RelativeLayout>


原创粉丝点击