viewFlipper 之二
main.xml
<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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".Main" >
<ViewFlipper
        android:id="@+id/viewFlipper1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true" >
         <!-- 第一个页面 -->
        <LinearLayout android:layout_width="fill_parent"
            android:layout_height="fill_parent" android:gravity="center">
<ImageView android:layout_width="wrap_content"
                android:layout_height="wrap_content" android:src="@drawable/a3" />
<Button
                android:id="@+id/button1"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="start1" />
</LinearLayout>
        <!-- 第二个页面 -->
        <LinearLayout android:layout_width="fill_parent"
            android:layout_height="fill_parent" android:gravity="center">
            <ImageView android:layout_width="wrap_content"
                android:layout_height="wrap_content" android:src="@drawable/a4"
                android:gravity="center" />
            <Button
                android:id="@+id/button2"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="start2" />
        </LinearLayout>
        <!-- 第三个页面 -->
        <LinearLayout android:layout_width="fill_parent"
            android:layout_height="fill_parent" android:gravity="center">
<ImageView android:layout_width="wrap_content"
                android:layout_height="wrap_content" android:src="@drawable/a5"
                android:gravity="center" />
            <Button
                android:id="@+id/button3"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="start3" />
        </LinearLayout>
        <!-- 第四个页面 -->
        <LinearLayout android:layout_width="fill_parent"
            android:layout_height="fill_parent" android:gravity="center">
<ImageView android:layout_width="wrap_content"
                android:layout_height="wrap_content" android:src="@drawable/a6"
                android:gravity="center" />
            <Button
                android:id="@+id/button4"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:text="start4" />
        </LinearLayout>
    </ViewFlipper>
</RelativeLayout>
Main.java
package com.example.myflipper;
import android.os.Bundle;
import android.app.Activity;
import android.app.Notification;
import android.app.NotificationManager;
import android.app.PendingIntent;
import android.content.Intent;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.Window;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.Button;
import android.widget.ViewFlipper;
public class Main extends Activity {
NotificationManager mManager;
Notification mNotification;
private ViewFlipper viewFlipper;
private GestureDetector detector; // 手势检测
Animation leftInAnimation;
Animation leftOutAnimation;
Animation rightInAnimation;
Animation rightOutAnimation;
Button btn1, btn2, btn3, btn4;
@Override
	public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.main);
btn1 = (Button) findViewById(R.id.button1);
		btn2 = (Button) findViewById(R.id.button2);
		btn3 = (Button) findViewById(R.id.button3);
		btn4 = (Button) findViewById(R.id.button4);
mManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
mNotification = new Notification();
mNotification.icon = R.drawable.a2;
mNotification.when = System.currentTimeMillis();
OnClickListener myClick = new View.OnClickListener() {
@Override
			public void onClick(View v) {
String btext = "";
switch (v.getId()) {
					case R.id.button1:
						btext = "你点了Button1";
						break;
					case R.id.button2:
						btext = "你点了Button2";
						break;
					case R.id.button3:
						btext = "你点了Button3";
						break;
					case R.id.button4:
						btext = "你点了Button4";
						break;
}
// TODO Auto-generated method stub
				mNotification.tickerText = btext;
				mNotification.flags = Notification.FLAG_AUTO_CANCEL;
Intent intent = new Intent(Main.this,Notice.class);
PendingIntent pIntent=PendingIntent.getActivity(Main.this, 0, intent, 0);
mNotification.setLatestEventInfo(getApplicationContext(), "小心正文", btext,pIntent );
				mManager.notify(1, mNotification);
}
		};
btn1.setOnClickListener(myClick);
		btn2.setOnClickListener(myClick);
		btn4.setOnClickListener(myClick);
		btn3.setOnClickListener(myClick);
viewFlipper = (ViewFlipper) findViewById(R.id.viewFlipper1);
		detector = new GestureDetector(this,
				new GestureDetector.OnGestureListener() {
@Override
					public boolean onSingleTapUp(
							MotionEvent e) {
// TODO Auto-generated method
						// stub
						return false;
					}
@Override
					public void onShowPress(MotionEvent e) {
// TODO Auto-generated method
						// stub
}
@Override
					public boolean onScroll(MotionEvent e1,
							MotionEvent e2,
							float distanceX,
							float distanceY) {
// TODO Auto-generated method
						// stub
						return false;
					}
@Override
					public void onLongPress(MotionEvent e) {
// TODO Auto-generated method
						// stub
}
@Override
					public boolean onFling(MotionEvent e1,
							MotionEvent e2,
							float velocityX,
							float velocityY) {
if (e1.getX() - e2.getX() > 120) {
							viewFlipper.setInAnimation(leftInAnimation);
							viewFlipper.setOutAnimation(leftOutAnimation);
							viewFlipper.showNext();// 向右滑动
							return true;
						} else if (e1.getX()
								- e2.getY() < -120) {
							viewFlipper.setInAnimation(rightInAnimation);
							viewFlipper.setOutAnimation(rightOutAnimation);
							viewFlipper.showPrevious();// 向左滑动
							return true;
						}
						return false;
					}
@Override
					public boolean onDown(MotionEvent e) {
// TODO Auto-generated method
						// stub
						return false;
					}
				});
// 动画效果
		leftInAnimation = AnimationUtils.loadAnimation(this,
				R.layout.left_in);
		leftOutAnimation = AnimationUtils.loadAnimation(this,
				R.layout.left_out);
		rightInAnimation = AnimationUtils.loadAnimation(this,
				R.layout.right_in);
		rightOutAnimation = AnimationUtils.loadAnimation(this,
				R.layout.right_out);
	}
@Override
	public boolean onTouchEvent(MotionEvent event) {
return this.detector.onTouchEvent(event); // touch事件交给手势处理。
	}
}
notice.xml
<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:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin"
    tools:context=".Notice" >
<TextView
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/hello_world" />
</RelativeLayout>
Notice.java
package com.example.myflipper;
import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;
public class Notice extends Activity {
@Override
	protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
		setContentView(R.layout.notice);
	}
@Override
	public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is
		// present.
		getMenuInflater().inflate(R.menu.notice, menu);
		return true;
	}
}
动画配置文件
left_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate 
android:fromXDelta="100%p"
android:toXDelta="0"
android:duration="600"
/>
<alpha 
android:fromAlpha="0.1"
android:toAlpha="1.0"
android:duration="600"
/>
</set>
left_out.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%p"
android:duration="600"
/>
<alpha 
android:fromAlpha="1.0"
android:toAlpha="0.1"
android:duration="600"
/>
</set>
right_in.xml
<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate 
android:fromXDelta="-100%p"
android:toXDelta="0"
android:duration="600"
/>
<alpha 
android:fromAlpha="0.1"
android:toAlpha="1.0"
android:duration="600"
/>
</set>
right_out.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%p"
android:duration="600"
/>
<alpha 
android:fromAlpha="1.0"
android:toAlpha="0.1"
android:duration="600"
/>
</set>
viewFlipper 之二的更多相关文章
- 【Android 复习】:Android之ViewFlipper(二)
		通过手势移动屏幕 上面是通过屏幕上的按钮来在屏幕间切换的,这看起来多少有点不符合Android的风格,如果要是能通过手势的左右滑动来实现屏幕的切换就比较优雅了. 通过android.view.Gest ... 
- 学习Jammendo代码的心路历程(二)ViewFlipper数据的填充
		打开Jammendo进入到首页之后,会看到这样一个界面.可以看到下左效果,我们可以看到,他是上部分的ViewFlipper模块和下半部分的listview模块构成的,今天就简单的说一下Jammendo ... 
- <Android 基础(三十二)> ViewFlipper
		简介 View Flipper,是ViewAnimator的子类,而ViewAnimator又是继承自FrameLayout,而FrameLayout就是平时基本上只显示一个子视图的布局,由于Fram ... 
- 二、Android应用的界面编程(七)ViewAnimator及其子类[ ViewSwitcher、ImageSwitcher、TextSwitcher、ViewFlipper ]
		ViewAnimator是一个基类,它继承了FrameLayout.因此它表现出FrameLayout的特征,可以将多个View组“叠”在一起. ViewAnimator可以在View切换时表现出动画 ... 
- Android中使用ViewFlipper实现屏幕页面切换(关于坐标轴的问题已补充更改)
		屏幕切换指的是在同一个Activity内屏幕间的切换,ViewFlipper继承了Framelayout类,ViewAnimator类的作用是为FrameLayout里面的View切换提供动画效果.如 ... 
- Android成长日记-使用ViewFlipper实现屏幕切换动画效果
		(一) ViewFlipper介绍 Android系统自带的一个多页面管理控件,它可以实现子界面的自动切换 (二) 为ViewFlipper加入View 1. 静态导入:在Layout布局文件中直接导 ... 
- Android 滑动效果入门篇(一)—— ViewFlipper
		ViewFilpper 是Android官方提供的一个View容器类,继承于ViewAnimator类,用于实现页面切换,也可以设定时间间隔,让它自动播放.又ViewAnimator继承至于Frame ... 
- (转)【移动开发】Android中三种超实用的滑屏方式汇总(ViewPager、ViewFlipper、ViewFlow)
		转自: http://smallwoniu.blog.51cto.com/3911954/1308959 现如今主流的Android应用中,都少不了左右滑动滚屏这项功能,(貌似现在好多人使用智能机都习 ... 
- Android高手进阶教程(二十八)之---Android ViewPager控件的使用(基于ViewPager的横向相册)!!!
		分类: Android高手进阶 Android基础教程 2012-09-14 18:10 29759人阅读 评论(35) 收藏 举报 android相册layoutobjectclassloade ... 
随机推荐
- JAVA中有一个特殊的类: Object
			JAVA中有一个特殊的类: Object.它是JAVA体系中所有类的父类(直接父类或者间接父类). 此类中的方法可以使所的类均继承. 以下介绍的三种方法属于Object: (1) finalize方法 ... 
- java---servlet与filter的联系与区别
			filter是一个可以复用的代码片段,可以用来转换HTTP请求.响应和头信息.Filter不像Servlet,它不能产生一个请求或者响应,它只是修改对某一资源的请求,或者修改从某一的响应. 最近使用插 ... 
- java----序列化与反序列化中及java序列化本质就是存储一个对象,然后在其他地方在调用它
			Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization是 ... 
- Cocos2d-x-Lua (2.x)脚本开发之 Lua语言基础
			从今天開始,往后将陆续更新Lua教程,主要是搭载Cocos2dx ,有不论什么疑惑或者不正确的地方.尽情指正.交流.探讨. 那么首先肯定是Lua语言基础的知识点.以下直接附上代码,凝视已经非常清楚.无 ... 
- (转)有关thread线程
			Python 标准库提供了 thread 和 threading 两个模块来对多线程进行支持.其中, thread 模块以低级.原始的方式来处理和控制线程,而 threading 模块通过对 thre ... 
- 【ArcGIS for Android】经纬度坐标、地图投影坐标、屏幕坐标互相转换
			SpatialReference mSR4326 = SpatialReference.create(4326); SpatialReference mSR3857 = SpatialReferenc ... 
- Python学习笔记14—模块
			在python中所有的模块都被加入到了sys.path中,用下面的方法可以看见模块的位置. >>> import sys >>> import pprint > ... 
- kotlin gradle的修改
			Kotlin插件包括一个让我们配置Gradle的工具.但是我还是倾向于保持我对Gradle文件读写的控制权,否则它只会变得混乱而不会变得简单.不管怎么样,在使用自动工具之前知道它是怎么工作的是个不错的 ... 
- C语言switch语句
			C语言虽然没有限制 if else 能够处理的分支数量,但当分支过多时,用 if else 处理会不太方便,而且容易出现 if else 配对出错的情况.例如,输入一个整数,输出该整数对应的星期几的英 ... 
- IOS7 新特性(针对同样讨厌更新后IOS7的开发者)
			本文转载至 http://blog.csdn.net/hanbing861210/article/details/13614211 您还未登录!|登录|注册|帮助 首页 业界 移动 云计算 研发 论坛 ... 
