`
jgsj
  • 浏览: 964272 次
文章分类
社区版块
存档分类
最新评论

Android应用程序介绍页面实现 (一)

 
阅读更多

在很多应用程序第一次启动的时候,会通过几个滑动页面来对该应用程序进行简要地介绍,本文通过ViewFlipper来实现展示效果。

public class ViewFlipperActivity extends Activity implements OnGestureListener{

	/**
	 * 使用ViewFlipper实现左右滑动效果
	 */
	private ViewFlipper mFlipper;
	private GestureDetector mDetector;
	private String TAG = "ViewFlipperActivity";
	
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE); 
        setContentView(R.layout.activity_viewflipper);
        /**
         * 添加滑动图片
         */
        mFlipper = (ViewFlipper) this.findViewById(R.id.flipper);
        mFlipper.addView(addImage(R.drawable.guide_1), 0);
        mFlipper.addView(addImage(R.drawable.guide_2), 1);
        mFlipper.addView(addImage(R.drawable.guide_3), 2);
        mFlipper.addView(addImage(R.drawable.guide_4), 3);

        /**
         * 创建一个手势监听器
         */
        mDetector = new GestureDetector(this);
    }

    private View addImage(int id){
    	ImageView imageView = new ImageView(ViewFlipperActivity.this);
    	imageView.setImageResource(id);
    	imageView.setLayoutParams(new LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT));
    	return imageView;
    }

	@Override
	public boolean onDown(MotionEvent arg0) {
		// TODO Auto-generated method stub
		return false;
	}


	@Override
	public boolean onFling(MotionEvent arg0, MotionEvent arg1, float arg2,
			float arg3) {
		/**
		 * 滑动显示图片
		 */
		if (arg0.getX() - arg1.getX() > 10) {
            mFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.push_left_in));
            mFlipper.setOutAnimation(AnimationUtils.loadAnimation(this, R.anim.push_left_out));
            mFlipper.showNext();
            return true;
        } else if (arg0.getX() - arg1.getX() < -10) {
        	mFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.push_right_in));
        	mFlipper.setOutAnimation(AnimationUtils.loadAnimation(this, R.anim.push_right_out));
        	mFlipper.showPrevious();
            return true;
        }
		// TODO Auto-generated method stub
		return false;
	}


	@Override
	public void onLongPress(MotionEvent arg0) {
		// TODO Auto-generated method stub
		
	}


	@Override
	public boolean onScroll(MotionEvent arg0, MotionEvent arg1, float arg2,
			float arg3) {
		// TODO Auto-generated method stub
		return false;
	}


	@Override
	public boolean onTouchEvent(MotionEvent event) {
		/**
		 * 将触摸事件发送到手势监听器中
		 */
		return mDetector.onTouchEvent(event);
	}

	@Override
	public void onShowPress(MotionEvent arg0) {
		// TODO Auto-generated method stub
		
	}


	@Override
	public boolean onSingleTapUp(MotionEvent arg0) {
		// TODO Auto-generated method stub
		return false;
	}
    
}

实现相当简单,就是将几张图片添加到ViewFlipper中,使用ViewFlipper来实现页面切换效果。在页面切换过程中,使用了动画来实现平滑过渡效果,分别定义了4个动画,分别为:

push_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="500" />
    <alpha android:fromAlpha="0.1" android:toAlpha="1.0"
        android:duration="500" />
</set>
push_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="500" />
    <alpha android:fromAlpha="1.0" android:toAlpha="0.1"
        android:duration="500" />
</set>
push_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="500" />
    <alpha android:fromAlpha="0.1" android:toAlpha="1.0"
        android:duration="500" />
</set>
push_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="500" />
    <alpha android:fromAlpha="1.0" android:toAlpha="0.1"
        android:duration="500" />
</set>

分享到:
评论

相关推荐

    Android应用程序实现欢迎引导页面的方法实现

    Android应用程序实现欢迎引导页面的方法实现,仿新浪启动界面

    Android应用程序实现欢迎引导页面的方法实现 (可运行)

    android实现应用程序只有在第一次启动时显示引导界面 ,以后就不在显示了...判断系统是第一次运行的代码实现如

    Android应用源码45套安卓源码合集.zip

    Android应用源码(精)记事本小程序,加注释,适合阅读.rar Android应用源码Android平台下通过HTTP协议实现断点续传下载.rar Android应用源码Hibernate4Android.rar Android应用源码http、udp、tcp网络交互组件.rar ...

    Android Studio实现天气预报小程序

    Android Studio实现天气预报小程序

    Android实现应用程序只启动一次引导界面(源码)

    实现了Android程序第一次使用时启动了引导界面,而以后使用的时候就不启动了。。。

    android简单的应用程序管理器

    android简单的应用程序管理器,实现的手机上的应用程序的管理,主要是运行和卸载。

    AndroidStudio实现天气预报小程序源码

    AndroidStudio实现天气预报小程序源码

    Android应用程序启动白屏黑屏优化

    大家最为熟悉的拨号盘或者短信应用,在第一次启动的时候,会有一定时间的白屏现象,其实,默认的情况下,android程序启动时,都会有一个黑屏或者白屏闪过的现象,在白屏或者黑屏过后才显示真正的应用界面。...

    Android程序设计基础

     作为基于Linux的开源手机平台,Android包括一部手机工作所需的全部软件——操作系统、用户界面和应用程序,而且不存在任何以往阻碍移动产业创新的专有权障碍。谷歌公司与开放手机联盟合作开发了Android,这个联盟...

    Android开发应用实战详解源代码

    1.1.4 android应用程序框架 1.1.5 android的竞争优势 1.1.6 android模拟器 1.2 搭建android开发环境 1.2.1 准备工作 1.2.2 windows系统下的搭建过程 1.2.3 linux系统下的搭建过程 1.3 常见问题汇总 1.4 使用本书的...

    android的几个小应用程序

    摇传是一个手机间文件传输工具,可以在两部安卓手机间传输照片、视频、音乐、程序及其他各种类型的文件。 传输的方法很简单:两部手机同时运行该软件,在其中一部手机上选中要传输的文件后,摇一下手机即可。文件...

    News App Flutter完整Android/iOS的应用新闻类头条应用程序

    Ultimate Flutter News App(InitNews)是一个Flutter完整应用程序,允许您使用Android/iOS的应用程序新闻应用程序,该应用程序的许多不同功能已经开发,为所有用户提供流畅的用户体验。预构建应用程序的目的是保存...

    CiyaShop v5.14 -基于WooCommerce的原生Android类亚马逊应用程序java项目源码

    CiyaShop v5.14 -基于WooCommerce的原生Android应用程序 CiyaShop原生Android应用程序是您的购物业务或您的客户购物商店作为代理或自由职业者的完美解决方案。它吸引消费者构成忠诚与尖锐的设计和功能,这对网上商店...

    Android项目源码给其他应用加锁的程序锁源代码.zip

    Android项目源码给其他应用加锁的程序锁源代码本项目是一个比较有趣的项目源码,可以给其他项目加锁,程序锁的原理是一个“看门狗”的服务定时监视顶层activity,如果activity对应的包名是之前上锁的应用程序的,则...

    基于Android的天气预报应用系统设计与实现.zip

    界面采用了viewpager与fragment结合的方式进行设计,每个fragment对应一个城市页面,可以通过滑动进行翻页控制。且为防止多页面造成的卡顿,app会首先进行fragment的初始化缓存,使软件响应速度得到提升。详细介绍...

    C#开发Android应用实战

    后面6-10章介绍的是如何应用手机中文件、网络、应用程序、摄像头设备、电子邮件、通讯录等资料。 11-17章介绍的是后台线程开发服务,自定义图片、画布操作、GPS、Google地图,多语言,平板电脑程序开发技巧。

    Android应用程序窗口(Activity)的窗口对象(Window)

    在本文中,我们就将详细分析Android应用程序窗口对象的创建过程。为了方便接下来描述类型为PhoneWindow的应用程序窗口的创建过程,我们将这两个图拿过来,如以下的图1和图2所示:图1Activity和Win

    Dooo v2.7.5 电影和网络系列门户应用程序Java项目源码 Android播放器

    Android应用程序使用原生Java构建,管理面板使用PHP,JS,Html构建。从管理面板组织Dooo,电影或网络系列,也可自定义用户登录系统,添加到收藏夹和更多。 特征 实现Android的Material Design 自动下一集播放 添加到...

    Android 实现微信界面

    程序总体使用TabHost实现微信界面的四个模块,在每一个tab选项布局里使用自定义的ListView,添加ImageView和TextView控件,显示通讯录列表信息。自定义ListView的列表项布局文件,将每个ListView要显示的内容构成一个...

    Android实现应用程序的闪屏效果

    每个应用程序都会有闪屏页面的,那么接下来就看看闪屏页面是如何实现的? 效果图: demo框架如下: 1、闪屏的布局如下:其实就是一张背景图 &lt;?xml version=1.0 encoding=utf-8?&gt; &lt;LinearLayout xmlns:...

Global site tag (gtag.js) - Google Analytics