android ViewFlipper屏幕切换

大家好,今天给我将介绍ViewFlipper屏幕切换,屏幕切换指的是在同一个Activity内屏幕间的切换,最常见的切换例如一个系统设置页面;一个个性化设置页面等。不说废话,直接看代码。

1.建立工程文件,命名TestviewfillerActivity。

   

2.布局文件main.xml 如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:background="#ffffff"
android:layout_width="fill_parent" android:layout_height="fill_parent">
<ViewFlipper android:layout_height="wrap_content"
android:layout_width="fill_parent" android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:id="@+id/main_vf">
</ViewFlipper>


<ImageView android:src="@drawable/left_arrow"
android:layout_width="wrap_content" android:id="@+id/main_letf"
android:layout_height="wrap_content" android:layout_alignParentLeft="true"
android:layout_centerVertical="true" />
<ImageView android:src="@drawable/right"
android:layout_width="wrap_content" android:id="@+id/main_right"
android:layout_height="wrap_content" android:layout_alignParentRight="true"
android:layout_centerVertical="true" />
</RelativeLayout>

3.这里是手势滑动的xml文件。     


分别如下:

(1)  in_lefttoright.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- 定义从左向右滑动时,后一页进入的动画 -->
 <translate 
 android:fromXDelta="-100%"
 android:toXDelta="0"
 android:duration="300"/>
</set>

(2)in_righttoleft.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- 定义从右向左滑动时,后一页进入的动画 -->
 <translate 
 android:fromXDelta="100%"
 android:toXDelta="0"
 android:duration="300"/>
</set>

(3)out_lefttoright.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- 定义从左向右滑动时,当前的页面出去的动画 -->
 <translate 
 android:fromXDelta="0"
 android:toXDelta="100%"
 android:duration="300"/>
</set>

(4)out_righttoleft.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
 <!-- 定义从右向左滑动时,当前页出去的动画 -->
 <translate 
 android:fromXDelta="0"
 android:toXDelta="-100%"
 android:duration="300"/>
</set>

4.下面上核心代码。

package com.test;


import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;
import android.widget.ViewFlipper;
/**
 * android 图片自动切换
 * @author song
 * 2012-03-07
 */
public class TestviewfillerActivity extends Activity implements OnClickListener{
//定义6张图片资源 存放在数组里
private int[] images = new int[]{R.drawable.p1,R.drawable.p2,R.drawable.p3,R.drawable.p4,R.drawable.p5,R.drawable.p6};
private ViewFlipper vf;
//定义两个图片按钮
private ImageView left;
private ImageView right;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        //初始化
        init();
    }


private void init() {
//实例化ViewFlipper
vf = (ViewFlipper) this.findViewById(R.id.main_vf);

for(int i = 0; i<images.length;i++){
//new 一个ImageView
ImageView iv = new ImageView(this);
//设置图片为背景 注意SetBackgroundDrawable和SetBackgroundResource有什么不同 ?这个大家自己总结
iv.setBackgroundResource(images[i]);
//setScaleType控制图片改变大小和移动
iv.setScaleType(ScaleType.CENTER_INSIDE);

//Set the layout parameters associated with this view
iv.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.WRAP_CONTENT));
vf.addView(iv);
}
//实例化ImageView
left = (ImageView) this.findViewById(R.id.main_letf);
right = (ImageView) this.findViewById(R.id.main_right);

if(vf.getChildCount() <2){
//隐藏
left.setVisibility(View.GONE);
right.setVisibility(View.GONE);
}
left.setVisibility(View.GONE);
left.setOnClickListener(this);
right.setOnClickListener(this);
//延时2秒
handler.sendMessageDelayed(new Message(), 2000);
}



private Handler handler = new Handler(){


@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
// if (vf.getDisplayedChild() == vf.getChildCount() - 1) {
// previous();
// }else if (vf.getDisplayedChild() != vf.getChildCount() - 1 ) {
next();
// }
isShow();
handler.sendMessageDelayed(new Message(), 2000);
}
   
    };


private void next() {
vf.setInAnimation(TestviewfillerActivity.this, R.anim.in_righttoleft);
vf.setOutAnimation(TestviewfillerActivity.this, R.anim.out_righttoleft);
vf.showNext();
}
private void previous() {
vf.setInAnimation(TestviewfillerActivity.this, R.anim.in_lefttoright);
vf.setOutAnimation(TestviewfillerActivity.this, R.anim.out_lefttoright);
vf.showPrevious();
}

@Override
public void onClick(View v) {
//判断是按下哪个ImageView
switch (v.getId()) {
case R.id.main_letf:
if (vf.getDisplayedChild() > 0) {
previous();
}
break;
case R.id.main_right:
if (vf.getDisplayedChild() < vf.getChildCount() - 1) {
next();
}
break;
}
isShow();


}
    //显示
private void isShow() {
if(vf.getDisplayedChild() == 0){
left.setVisibility(View.GONE);
right.setVisibility(View.VISIBLE);
}else if(vf.getDisplayedChild() == vf.getChildCount() - 1){
left.setVisibility(View.VISIBLE);
right.setVisibility(View.GONE);
}else{
left.setVisibility(View.VISIBLE);
right.setVisibility(View.VISIBLE);
}
}
}


5.运行程序:


ok,到处完毕!今天早点休息。明天继续。


  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值