Android_Android实现带动画效果的Tab Menu

package com.zhuozhuo;
import android.app.Activity;
import android.os.Bundle;
import android.view.KeyEvent;
import android.widget.TextView;
public class DockMenuActivity extends Activity {
/** Called when the activity is first created. */
DockView 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);
}

}


DockView.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 DockView {
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文件夹,包括2个文件:close_tab.xml, show_tab.xml

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>

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>


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" android:text="点击menu键打开dock"/>
<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>


转载自:http://www.oschina.net/code/snippet_54100_6263

你可能感兴趣的:(Android_Android实现带动画效果的Tab Menu)