Android中三种超实用的滑屏方式汇总(转载)

时间:2022-03-07 05:53:35

Android中三种超实用的滑屏方式汇总

 
    • 现如今主流的Android应用中,都少不了左右滑动滚屏这项功能,(貌似现在好多人使用智能机都习惯性的有事没事的左右滑屏,也不知道在干什么。。。嘿嘿),由于前段时间项目的需要,所以也对其研究了一下,总的来说滑屏实现有三种方式:(至于其他的实现方式目前后还没碰到。。。)

      1.ViewPager 2.ViewFlipper 3.ViewFlow

      一.ViewPager

      官方文档介绍:http://developer.android.com/reference/android/support/v4/view/ViewPager.html

      Android中三种超实用的滑屏方式汇总(转载)

      根据继承关系我们可以看出,ViewPager不在android sdk 自带jar包中,来源google 的补充组件android-support-v4.jar中,所以我们在3.0以前的版本中使用就需要导入该jar包了。

      1.1 介绍:该类是一个布局管理器,它允许用户通过滑动左、右页的数据。你必须要一个实现了PagerAdapter接口从而生成的页面视图。

      1.2 使用:

      activity_main.xml

       

      MainActivity类:

      package comzhf.android_viewpager;
      import java.util.ArrayList;
      import java.util.List;
      import android.os.Bundle;
      import android.app.Activity;
      import android.support.v4.view.ViewPager;
      import android.view.LayoutInflater;
      import android.view.View;
      import android.view.View.OnClickListener;
      import android.widget.Button;
      import android.widget.TextView;
      import android.widget.Toast;
      /**
      * 主界面:ViewPagerViewPager不在android sdk 自带jar包中,来源google 的补充组件android-support-v4.jar
      */
      public class ViewPagerActivity extends Activity {
      private ViewPager mViewPager;
      List<View> viewList;
      @Override
      protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      LayoutInflater mInflater = getLayoutInflater().from(this);
      View v1 = mInflater.inflate(R.layout.layout1, null);
      View v2 = mInflater.inflate(R.layout.layout2, null);
      View v3 = mInflater.inflate(R.layout.layout3, null);
      //添加页面数据
      viewList = new ArrayList<View>();
      viewList.add(v1);
      viewList.add(v2);
      viewList.add(v3);
      //实例化适配器
      mViewPager = (ViewPager) findViewById(R.id.viewpager);
      mViewPager.setAdapter(new MyPagerAdapter(viewList));
      mViewPager.setCurrentItem(0); //设置默认当前页
      View view = viewList.get(0);
      TextView textView = (TextView) view.findViewById(R.id.text_1);
      textView.setText("我是第一页");
      Button button = (Button) view.findViewById(R.id.button_1);
      button.setOnClickListener(new OnClickListener() {
      public void onClick(View v) {
      // TODO Auto-generated method stub
      Toast.makeText(getApplicationContext(), "你点击了按钮", Toast.LENGTH_SHORT).show();
      }
      });
      }
      }
       

      这里还有三个布局文件:layout1.xml (其余两个类似,略)

       

      效果图:

      Android中三种超实用的滑屏方式汇总(转载)Android中三种超实用的滑屏方式汇总(转载)Android中三种超实用的滑屏方式汇总(转载)

      补充说明:

      1.这里我们用了Layout作为每个page的填充数据,其实官方文档说ViewPager+Fragment配合使用更好

      2.每个页面的响应事件我们可以在OnPageChangeListener监听器类中进行捕获和处理对应事件。

      二.ViewFlipper

      官方文档:http://developer.android.com/reference/android/widget/ViewFlipper.html

      Android中三种超实用的滑屏方式汇总(转载)

      2.1 介绍:ViewFilpper控件是系统自带控件之一,主要用于在同一个屏幕间的切换及设置动画效果、间隔时间,且可以自动播放。

      顺便提及一下,View动画关系图:

      Android中三种超实用的滑屏方式汇总(转载)

      2.2 使用:

      2.2.1 静态加载:

      activity_main.xml:

       

      MainActivity类:

       

      动画配置文件(右进右出同理,略):

      push_left_in.xml:

      <?xml version="1.0" encoding="utf-8"?>
      <set xmlns:android="http://schemas.android.com/apk/res/android" >
      <translate
      android:duration="500"
      android:fromXDelta="100.0%p"
      android:toXDelta="0.0" />
      <alpha
      android:duration="500"
      android:fromAlpha="0.1"
      android:toAlpha="1.0" />
      </set>

      push_left_out.xml:

       

      效果:

      Android中三种超实用的滑屏方式汇总(转载)Android中三种超实用的滑屏方式汇总(转载)

      向左滑屏 向右滑屏

      补充:

      上述的page只有4个,而真实项目中的page页面个数是不确定的,所以下面这种方式是项目中经常用到的。

      2.2.2 动态加载(重要)

      参考文章:http://blog.csdn.net/yuzhiboyi/article/details/7702953

      activity_main2.xml

       

      flipper_view.xml:

       

      注:这里并不是所有的View都能有onFling回调函数,外部需要加ScrollView !

      MyGestureListener类:自定义滑动事件监听器

       

      MyViewFlipper类:自定义View滑动类:监听滑动事件,并做切换视图的处理。

       

      MainActivity2类:

       

      效果图:

      Android中三种超实用的滑屏方式汇总(转载)--向左滑动(渐变过程不好截图)--> Android中三种超实用的滑屏方式汇总(转载)

      补充说明:

      上述的三个类:

      MyGestureListener:继承了SimpleGestureListener手势监听类, 复写了该类onFling()方法,用于监听用户按下滑动事件的处理;还自定义了滑动的回调接口OnFlingListener(包含了两个抽象方法flingToNext(),flingToPrevious)。

      MyViewFlipper:是一个自定义ViewFlipper,该类首先实现和绑定了上一个类中的滑动的回调接口OnFlingListener,完成了接口中两个重要的方法。同时定义了一个View变化监听回调接口OnViewFlipperListener(包含了两个抽象方法getNextView(),getPreviousView())。

      MainActivity2:加载布局,实现监听,统一处理页面数据View和滑动事件的绑定。

      三.ViewFlow类

      3.1介绍:

      ViewFlow不是google官方的api,它是gethub上的一个开源项目,利用ViewFlow可以产生视图切换的效果。ViewFlow 相当于 Android UI 部件提供水平滚动的 ViewGroup,使用 Adapter 进行条目绑定,例如ViewPager或是ViewFlipper。它提供了三个组件ViewFlow、FlowIndicator和TitleFlowIndicator,一般情况下,当你需要做一个滑动然而不确定view的数目时,可以考虑使用ViewFlow。如果你的view数目确定,使用Fragments 或兼容库里的ViewPager比较好 。

      3.2使用:

      A.首先下载ViewFlow开源库代码:

      官方文档:https://github.com/pakerfeldt/android-viewflow

      Android中三种超实用的滑屏方式汇总(转载)

      B.下载之后我们解压打开viewflow文件夹:

      Android中三种超实用的滑屏方式汇总(转载)

      C.建项目将这三个类直接复制过来放项目中使用即可。

      Android中三种超实用的滑屏方式汇总(转载)

      注:这里可能还需要一个styleable文件,直接将value文件夹下的attrs.xml拷入即可。

      activity_main.xml

       

      注:这里需要强调一下,因为使用第三方的库组件,所以要在使用之前引入:

      xmlns:app="http://schemas.android.com/apk/res/com.zhf.android_viewflow"

      main_item.xml

       

      MainActivity类

       

      这里还有一个图片适配器:ImageAdapter

       

      运行一下吧!效果图:

      Android中三种超实用的滑屏方式汇总(转载)转屏后 Android中三种超实用的滑屏方式汇总(转载)

Android中三种超实用的滑屏方式汇总(转载)的更多相关文章

  1. (转)【移动开发】Android中三种超实用的滑屏方式汇总(ViewPager、ViewFlipper、ViewFlow)

    转自: http://smallwoniu.blog.51cto.com/3911954/1308959 现如今主流的Android应用中,都少不了左右滑动滚屏这项功能,(貌似现在好多人使用智能机都习 ...

  2. Android 中三种启用线程的方法

    在多线程编程这块,我们经常要使用Handler(处理),Thread(线程)和Runnable这三个类,那么他们之间的关系你是否弄清楚了呢? 首先说明Android的CPU分配的最小单元是线程,Han ...

  3. Android中三种计时器Timer、CountDownTimer、handler&period;postDelayed的使用

    在android开发中,我们常常需要用到计时器,倒计时多少秒后再执行相应的功能,下面我就分别来讲讲这三种常用的计时的方法. 一.CountDownTimer 该类是个抽象类,如果要使用这个类中的方法, ...

  4. Android中三种onClick事件的实现与对比

    方式一:在activity的onCreate()方法中,嵌入如下代码: Button button = (Button)findViewById(R.id.button1); button.setOn ...

  5. iOS开发UI篇—iOS开发中三种简单的动画设置

    iOS开发UI篇—iOS开发中三种简单的动画设置 [在ios开发中,动画是廉价的] 一.首尾式动画 代码示例: // beginAnimations表示此后的代码要“参与到”动画中 [UIView b ...

  6. smarty中三种变量的访问方式

    在模板中smarty有三种变量,第一种,php分配的变量,第二种配置文件里的变量,第三种,PHP全局数组里的变量,配置文件里变量的访问方式可以是{#bgcolor#},"#"必须紧 ...

  7. C&num;中三种定时器对象的比较

    ·关于C#中timer类 在C#里关于定时器类就有3个1.定义在System.Windows.Forms里2.定义在System.Threading.Timer类里3.定义在System.Timers ...

  8. Android动画 三种动画

    Android可以使用三种动画 Frame Animation-帧动画 ,就像GIF图片,通过一系列Drawable依次显示来模拟动画的效果 Tween Animation-补间动画,给出两个关键帧, ...

  9. 转-Web Service中三种发送接受协议SOAP、http get、http post

    原文链接:web服务中三种发送接受协议SOAP/HTTP GET/HTTP POST 一.web服务中三种发送接受协议SOAP/HTTP GET/HTTP POST 在web服务中,有三种可供选择的发 ...

随机推荐

  1. CozyRSS开发记录1-原型图与Grid

    CozyRSS开发记录1-原型图与Grid 1.使用MockPlus画出最简陋的原型图 这个界面参考了目前我最常使用的RSS阅读-傲游浏览器的内置RSS阅读器.主体框架划分为上.左下.右下三块,分别是 ...

  2. Oracle、Mysql、Sql Server语句的区别

    1.空值的处理——判断是否为空,为空时取一个值,不为空时取另一个值 1).Sql Server 中 ISNULL(check_expression,replacement_value) 解释:如果ch ...

  3. Linux Maven安装

    Maven 官网,下载maven 包 http://maven.apache.org/download.cgi 下载完成:apache-maven-3.6.1-bin.tar.gz 解压到自定义目录: ...

  4. 2018-11-09 VS Code英汉词典插件v0&period;0&period;4-驼峰下划线命名

    首先, 在两天时间内安装数破百, 多谢支持. VS Code插件市场地址: 英汉词典 - Visual Studio Marketplace 开源库地址同前文: Visual Studio Code插 ...

  5. 区间最深LCA

    求编号在区间[l, r]之间的两两lca的深度最大值. 例题. 解:口胡几种做法.前两种基于莫队,第三种是启发式合并 + 扫描线,第四种是lct + 线段树. ①: 有个结论就是这个答案一定是点集中D ...

  6. Chapter 5 -- ImmutableCollections

    Example publicstatic final ImmutableSet<String> COLOR_NAMES =ImmutableSet.of(  "red" ...

  7. PCL点云分割(2)

    关于点云的分割算是我想做的机械臂抓取中十分重要的俄一部分,所以首先学习如果使用点云库处理我用kinect获取的点云的数据,本例程也是我自己慢慢修改程序并结合官方API 的解说实现的,其中有很多细节如果 ...

  8. HDU 4568 Hunter 最短路&plus;TSP

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4568 Hunter Time Limit: 2000/1000 MS (Java/Others)Me ...

  9. C&num;一个FTP操作封装类FTPHelper

    参考了网上一些代码,作了一些调整优化. 001 using System; 002 using System.Collections.Generic; 003 using System.Linq; 0 ...

  10. Axure多人协作

    这几天搞<材料採购系统>需求.我们组须要分模块画模型图,可是假设每一个人各自画各自的,最后整合,这样就太麻烦了.小左说Axure能够实现多人协作,于是我就研究了一下.我们组已经在用了.以下 ...