大家好,今天给大家介绍如何在Android下实现一个带动画效果的Tab Menu。Tab Menu的打开动画效果为自下而上的淡入推进效果,关闭效果为自上而下的淡出推出效果。
实现的效果图如下(没有找到合适的屏幕录像工具,只能截静态图):
效果: 点击MENU键,系统的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;
- @Override
- public 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键关闭dock
- dockView.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之间的动画时间间隔ms
- private 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() {//打开dock
- tab(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() {
- @Override
- public void onClick(View v) {
- Toast.makeText(context, "view" + pos + " click!", Toast.LENGTH_SHORT).show();//点击tab时显示toast
- closeDock();
- }
- });
- }
- private void tab(final View view,int delayTime,final boolean toOpen) {
- view.postDelayed(new Runnable() { //延迟调用
- @Override
- public 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() {
- @Override
- public void onAnimationStart(Animation animation) {
- }
- @Override
- public void onAnimationRepeat(Animation animation) {
- }
- @Override
- public void onAnimationEnd(Animation animation) {
- view.setVisibility(View.INVISIBLE);//动画结束时,view不可见
- }
- });
- view.startAnimation(animation);
- }
- }
- }, delayTime);
- }
- public boolean isOpen() {
- return isOpen;
- }
- public void closeDock() {//关闭dock
- tab(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>