ViewPager+Animation简单示例

<span style="font-size:24px;"><span style="font-size:24px;">第二个活动界面</span>
public class MainActivity extends Activity {

	private Button bt1;
	private Button bt2;
	private ArrayList<View> list;

	private void getdata() {
		list = new ArrayList<View>();
		list.add(getLayoutInflater().inflate(R.layout.a1, null));
		list.add(getLayoutInflater().inflate(R.layout.a2, null));
		list.add(getLayoutInflater().inflate(R.layout.a3, null));
	}

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);
		getdata();

		ViewPager vp = (ViewPager) findViewById(R.id.vp);
		bt1 = (Button) list.get(0).findViewById(R.id.button1);
		bt2 = (Button) list.get(1).findViewById(R.id.button2);
//		Log.i("zzzz", bt1.toString()+"dd");
		vp.setAdapter(pa);
		bt1.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View v) {
				MainActivity.this.tiaozhuan();

			}
		});

		bt2.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View v) {
				MainActivity.this.tiaozhuan();

			}
		});
	}

	private PagerAdapter pa = new PagerAdapter() {

		@Override
		public boolean isViewFromObject(View arg0, Object arg1) {
			// TODO Auto-generated method stub
			return arg0 == arg1;
		}

		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return list.size();
		}

		// 删除页面
		@Override
		public void destroyItem(ViewGroup container, int position, Object object) {
			container.removeView(list.get(position));
		}

		@Override
		public Object instantiateItem(ViewGroup container, int position) {
			container.addView(list.get(position));

			if (position == 2) {
				Animation anim = AnimationUtils.loadAnimation(
						MainActivity.this, R.anim.test);
				list.get(position).startAnimation(anim);
				anim.setAnimationListener(new AnimationListener() {

					@Override
					public void onAnimationStart(Animation animation) {
						// TODO Auto-generated method stub

					}

					@Override
					public void onAnimationRepeat(Animation animation) {
						// TODO Auto-generated method stub

					}

					@Override
					public void onAnimationEnd(Animation animation) {
						MainActivity.this.tiaozhuan();

					}
				});
			}
			return list.get(position);
		}

	};

	private void tiaozhuan() {
		Intent i = new Intent(MainActivity.this, TwoActivity.class);
		startActivity(i);
	}

}</span>



第二个活动界面

public class TwoActivity extends Activity {

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_two);
	}

	@Override
	public boolean onCreateOptionsMenu(Menu menu) {
		// Inflate the menu; this adds items to the action bar if it is present.
		getMenuInflater().inflate(R.menu.two, menu);
		return true;
	}

}

动画布局

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <rotate
        android:fromDegrees="0"
        android:toDegrees="720"
        
        android:pivotX="50%"
        android:pivotY="50%"
        
        android:duration="3000"
        />
    
    <scale
        android:fromXScale="0"
        android:toXScale="1"
        
        android:fromYScale="0"
        android:toYScale="1"
        
        android:pivotX="50%"
        android:pivotY="50%"
        
        android:duration="5000"
        />

</set>

主函数布局

<RelativeLayout 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" >

    <android.support.v4.view.ViewPager
        android:id="@+id/vp"
        android:layout_width="match_parent"
        android:layout_height="match_parent" >
    </android.support.v4.view.ViewPager>

</RelativeLayout>


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值