Android使用ViewFlipper实现左右滑动效果面
在我的博客中,上次是使用ViewPager实现左右滑动的效果的,请看文章:Android使用ViewPager实现左右滑动效果。
这次我来使用ViewFlipper实现这种效果,好了,先看看效果吧:
效果看完了就来实现这个效果。
1.布局文件
主界面使用下面的布局:
- <?xml version="1.0" encoding="utf-8"?>
- <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- android:orientation="vertical" >
- <ViewFlipper android:id="@+id/ViewFlipper1"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent">
- </ViewFlipper>
- <LinearLayout
- android:orientation="horizontal"
- android:layout_width="wrap_content"
- android:layout_gravity="bottom|center_horizontal"
- android:layout_height="wrap_content"
- >
- <ImageView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:src="@drawable/da"
- android:id="@+id/imageview1"
- />
- <ImageView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:src="@drawable/xiao"
- android:id="@+id/imageview2"
- />
- <ImageView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:src="@drawable/xiao"
- android:id="@+id/imageview3"
- />
- <ImageView
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:src="@drawable/xiao"
- android:id="@+id/imageview4"
- />
- </LinearLayout>
- </FrameLayout>
简单的介绍一下布局文件:最外层是一个FrameLayout,使用FrameLayout就是为了是的下面的四个点在ViewFlipper上面。LayoutLayout在FrameLayout的下面和水平居中。
2.ViewFlipper的使用
- flipper = (ViewFlipper) this.findViewById(R.id.ViewFlipper1);
- flipper.addView(addImageView(R.drawable.png1o));
- flipper.addView(addImageView(R.drawable.png2o));
- flipper.addView(addImageView(R.drawable.png3o));
- flipper.addView(addView());
在Activity中声明一个ViewFlipper的对象,在布局中找到。将三张图片加到ViewFlipper中,另外再加一个View,这个View是从XML布局文件中得到的。布局文件如下:
- <?xml version="1.0" encoding="utf-8"?>
- <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
- android:orientation="vertical"
- android:layout_width="fill_parent"
- android:layout_height="fill_parent"
- >
- <Button
- android:id="@+id/button"
- android:layout_width="wrap_content"
- android:layout_height="wrap_content"
- android:layout_marginBottom="45dp"
- android:text="进入程序"
- android:textColor="#3E3E3E"
- android:layout_gravity="center_horizontal"
- />
- </LinearLayout>
在这个布局文件中有一个Button,用于跳转Activity用。
在Activity中声明一个GestureDetector对象,在onCreate方法中分配内存。
detector = new GestureDetector(this);
使用this为参数,那么就要使得activity类impllements OnGestureListener接口。重写几个方法。覆盖父类的onTouchEvent方法,在这个方法中如下写:
- @Override
- public boolean onTouchEvent(MotionEvent event) {
- // TODO Auto-generated method stub
- return this.detector.onTouchEvent(event);
- }
这样就使得detector能接受消息响应了。
在实现OnGestureListener的方法中判断用户的滑动来切换界面:
- @Override
- public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
- float velocityY) {
- System.out.println("in------------>>>>>>>");
- ) {
- ) {
- i++;
- setImage(i);
- this.flipper.setInAnimation(AnimationUtils.loadAnimation(this,
- R.anim.animation_right_in));
- this.flipper.setOutAnimation(AnimationUtils.loadAnimation(this,
- R.anim.animation_left_out));
- this.flipper.showNext();
- }
- return true;
- }
- ) {
- ) {
- i--;
- setImage(i);
- this.flipper.setInAnimation(AnimationUtils.loadAnimation(this,
- R.anim.animation_left_in));
- this.flipper.setOutAnimation(AnimationUtils.loadAnimation(this,
- R.anim.animation_right_out));
- this.flipper.showPrevious();
- }
- return true;
- }
- return false;
- }
- void setImage(int i)
- {
- ;j++)
- {
- if(j!=i)
- iamges[j].setImageResource(R.drawable.xiao);
- else
- iamges[j].setImageResource(R.drawable.da);
- }
- }
界面切换的时候改变下面的四个小ImageView的图片。切换的动画在res/anim文件夹中,这里就不多说了。
整个工程的下载:Android使用ViewFlipper实现左右滑动效果面。
-------------------------------------------------------------------------------------------------------------------------------
在android的图片的浏览时候经常使用。最近在网上查找资料自己也做一个如下:
- package com.easyway.buttonpageflipper;
- import com.easyway.buttonpageflipper.R;
- import android.app.Activity;
- import android.graphics.PixelFormat;
- import android.os.Bundle;
- import android.os.Handler;
- import android.os.Message;
- import android.view.GestureDetector;
- import android.view.GestureDetector.OnGestureListener;
- import android.view.Gravity;
- import android.view.MotionEvent;
- import android.view.View;
- import android.view.WindowManager;
- import android.view.WindowManager.LayoutParams;
- import android.view.animation.AnimationUtils;
- import android.widget.ImageView;
- import android.widget.ViewFlipper;
- /**
- * Android实现带渐显按钮的左右滑动效果 自然状态下按钮不可见,触摸屏幕时显示按钮
- *
- * @author longgangbai
- *
- */
- public class ButtonpageflipperActivity extends Activity implements OnGestureListener{
- // 声明两个按钮,分别代表向左和向右滑动
- private ImageView btnLeft = null;
- private ImageView btnRight = null;
- // 设置WindowManager
- private WindowManager wm = null;
- private WindowManager.LayoutParams wmParams = null;
- // ImageView的alpha值
- ;
- private boolean isHide;
- private ViewFlipper viewFlipper = null;
- private GestureDetector detector;
- /** Called when the activity is first created. */
- @Override
- public void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.main);
- setTitle("Android实现渐显按钮的左右滑动效果");
- viewFlipper = (ViewFlipper) this.findViewById(R.id.myViewFlipper);
- detector = new GestureDetector(this);
- // 初始化左右按钮
- initImageButtonView();
- viewFlipper.addView(addImageView(R.drawable.photo1));
- viewFlipper.addView(addImageView(R.drawable.photo2));
- viewFlipper.addView(addImageView(R.drawable.photo3));
- viewFlipper.addView(addImageView(R.drawable.photo4));
- viewFlipper.addView(addImageView(R.drawable.photo5));
- }
- private View addImageView(int id) {
- ImageView iv = new ImageView(this);
- iv.setImageResource(id);
- return iv;
- }
- /**
- * 初始化悬浮按钮
- */
- private void initImageButtonView() {
- // 获取WindowManager
- wm = (WindowManager) getApplicationContext().getSystemService("window");
- // 设置LayoutParams相关参数
- wmParams = new WindowManager.LayoutParams();
- // 设置window type
- wmParams.type = LayoutParams.TYPE_PHONE;
- // 设置图片格式,效果为背景透明
- wmParams.format = PixelFormat.RGBA_8888;
- // 设置Window flag参数
- wmParams.flags = LayoutParams.FLAG_NOT_TOUCH_MODAL
- | LayoutParams.FLAG_NOT_FOCUSABLE;
- // 设置x、y初始值
- ;
- ;
- // 设置窗口长宽数据
- ;
- ;
- // 创建左右按钮
- createLeftButtonView();
- createRightButtonView();
- }
- /**
- * 设置左边按钮
- */
- private void createLeftButtonView() {
- btnLeft = new ImageView(this);
- btnLeft.setImageResource(R.drawable.left);
- );
- btnLeft.setOnClickListener(new View.OnClickListener() {
- public void onClick(View arg0) {
- // 上一个图像
- viewFlipper.setInAnimation(ButtonpageflipperActivity.this,
- R.anim.push_left_in);
- viewFlipper.setOutAnimation(ButtonpageflipperActivity.this,
- R.anim.push_left_out);
- viewFlipper.showPrevious();
- }
- });
- // 调整窗口
- wmParams.gravity = Gravity.LEFT | Gravity.CENTER_VERTICAL;
- // 显示图像
- wm.addView(btnLeft, wmParams);
- }
- /**
- * 设置右边按钮
- */
- private void createRightButtonView() {
- btnRight = new ImageView(this);
- btnRight.setImageResource(R.drawable.right);
- );
- btnRight.setOnClickListener(new View.OnClickListener() {
- public void onClick(View arg0) {
- // 下一个图像
- viewFlipper.setInAnimation(ButtonpageflipperActivity.this,
- R.anim.push_right_in);
- viewFlipper.setOutAnimation(ButtonpageflipperActivity.this,
- R.anim.push_right_out);
- viewFlipper.showNext();
- }
- });
- // 调整窗口
- wmParams.gravity = Gravity.RIGHT | Gravity.CENTER_VERTICAL;
- // 显示图像
- wm.addView(btnRight, wmParams);
- }
- /**
- * 设置按钮渐显效果
- */
- private Handler mHandler = new Handler() {
- public void handleMessage(Message msg) {
- ) {
- // 通过设置不透明度设置按钮的渐显效果
- ;
- )
- ;
- btnLeft.setAlpha(mAlpha);
- btnLeft.invalidate();
- btnRight.setAlpha(mAlpha);
- btnRight.invalidate();
- )
- );
- ) {
- ;
- )
- ;
- btnLeft.setAlpha(mAlpha);
- btnLeft.invalidate();
- btnRight.setAlpha(mAlpha);
- btnRight.invalidate();
- )
- );
- }
- }
- };
- private void showImageButtonView() {
- isHide = false;
- );
- }
- private void hideImageButtonView() {
- new Thread() {
- public void run() {
- try {
- );
- isHide = true;
- );
- } catch (Exception e) {
- ;
- }
- }
- }.start();
- }
- @Override
- public boolean onTouchEvent(MotionEvent event) {
- this.detector.onTouchEvent(event);
- switch (event.getAction()) {
- case MotionEvent.ACTION_MOVE:
- case MotionEvent.ACTION_DOWN:
- showImageButtonView();
- break;
- case MotionEvent.ACTION_UP:
- hideImageButtonView();
- break;
- }
- return true;
- }
- @Override
- public void onDestroy() {
- super.onDestroy();
- // 在程序退出(Activity销毁)时销毁窗口
- wm.removeView(btnLeft);
- wm.removeView(btnRight);
- }
- @Override
- public boolean onDown(MotionEvent e) {
- // TODO Auto-generated method stub
- return false;
- }
- @Override
- public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
- float velocityY) {
- ) {
- this.viewFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.push_left_in));
- this.viewFlipper.setOutAnimation(AnimationUtils.loadAnimation(this, R.anim.push_left_out));
- this.viewFlipper.showNext();
- return true;
- ) {
- this.viewFlipper.setInAnimation(AnimationUtils.loadAnimation(this, R.anim.push_right_in));
- this.viewFlipper.setOutAnimation(AnimationUtils.loadAnimation(this, R.anim.push_right_out));
- this.viewFlipper.showPrevious();
- return true;
- }
- return false;
- }
- @Override
- public void onLongPress(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 onShowPress(MotionEvent e) {
- // TODO Auto-generated method stub
- }
- @Override
- public boolean onSingleTapUp(MotionEvent e) {
- // TODO Auto-generated method stub
- return false;
- }
- }
- buttonpageflipper.zip (801.6 KB)
- 下载次数: 41
Android使用ViewFlipper实现左右滑动效果面的更多相关文章
- Android 通过ViewFlipper实现广告轮播功能并可以通过手势滑动进行广告切换
为了实现广告轮播功能,在网上找了很多方法,有的效果很好,但是代码太麻烦,并且大多是用的viewpager,总之不是很满意. 于是看了一下sdk有个控件是ViewFlipper,使用比较方便,于是尝试了 ...
- 【转】android ViewPager,ViewFlipper,ViewFlow实现左右滑动
转自:http://blog.csdn.net/zhouyuanjing/article/details/8290454 开篇 首页只是作为ViewPager,ViewFlipper,ViewFlow ...
- android之ViewFlipper
xml文件 activity-main.xml <ViewFlipper xmlns:android="http://schemas.android.com/apk/res/andro ...
- UI特效--Android利用ViewFlipper实现屏幕切换动画效果
.屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面.2.介绍ViewFilpper类ViewFl ...
- Android利用ViewFlipper实现屏幕切换动画效果
1.屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面. 2.介绍ViewFilpper类 Vie ...
- Android中ViewFlipper的使用详解
说到android的左右滑动效果我们可以说是在每个应用上面都可以看到这样的效果,不管是微博,还是QQ等. 实现左右滑动的方式很多,有ViewPager(不过这个和需要android-support-v ...
- android手势识别ViewFlipper触摸动画
使用ViewFlipper来将您要来回拖动的View装在一起,然 后与GestureDetector手势识别类来联动,确定要显示哪个View,加上一点点动画效果即可.比如当手指向左快速滑动时跳转到上一 ...
- Android 实现两屏幕互相滑动
Android 实现两屏幕互相滑动 下文来自: http://blog.csdn.net/song_shi_chao/article/details/7081664 ----------------- ...
- Android实现浮层的上下滑动(支持内部加入View)
前言 我K.今天竟然是情人节.对于资深的单身狗来说,简直是个噩耗,今天注定是各种秀恩爱.心塞中.. .. 话题到此结束,管他什么情人节,今天给大家带来的是一个浮层的上下滑动,浮层滑动时分三种状态:所有 ...
随机推荐
- c语言 选择排序
选择排序 // int array[] = {3, 2, 6, 9, 8, 5, 7, 1, 4}; // int count = sizeof(array) / sizeof(array ...
- CentOS下重新安装yum
1,下载最新的yum-3.2.28.tar.gz并解压 #wget http://yum.baseurl.org/download/3.2/yum-3.2.28.tar.gz#tar xvf yum- ...
- Genymotion中SD卡目录在Eclipse中查看,以及创建SDCard
咦?这后面似乎指向一个目录,我就去找/mnt/shell/emulated/0 Wow~好熟悉的目录..不熟悉的同学可以打开android模拟器的File Manger App 里面就是这些目录了,然 ...
- javascript数组去重算法-----5
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- A Simple Problem with Integers(线段树,区间更新)
A Simple Problem with Integers Time Limit: 5000MS Memory Limit: 131072K Total Submissions: 83822 ...
- POJ 1077 HDU 1043 Eight (IDA*)
题意就不用再说明了吧......如此经典 之前想用双向广搜.a*来写,但总觉得无力,现在用IDA*感觉其他的解法都弱爆了..............想法活跃,时间,空间消耗很小,给它跪了 启发式搜索关 ...
- Hdu Binary Tree Traversals
Problem Description A binary tree is a finite set of vertices that is either empty or consis ...
- CSS Sprite小图片自动合并工具
css-sprite是将css样式中零星的小图标,小图片合并成大图显示,这样能减小服务器并发连接数,减小服务器负载和带宽使用,有很高的实用价值.这里介绍一些自动合并图片并生成样式的工具. NodeJS ...
- SQL标识列的查询
1.判段一个表是否具有标识列 www.2cto.com 可以使用 OBJECTPROPERTY 函数确定一个表是否具有 IDENTITY(标识)列,用法: Select OBJECT ...
- 计算Date间的分钟数
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("HH:mm"); Date date_begin = simpl ...