Android仿淘宝头条向上滚动广告条ViewFlipper

所谓前人栽树,后人乘凉,在此感谢博主的贡献。
参考博文:

仿淘宝首页的淘宝头条View垂直滚动

欢迎关注我的微信公众号

不只是原创技术文章,更多的是对生活的思考总结

我在博主的基础上做了如下工作:

  • 修复了滚动条第二条点击事件无法触发这个bug;
  • 充分简化了自定义ViewFlipper类的代码;
  • 添加了直接使用ViewFlipper控件实现同样效果;

先上效果图:

这里使用了一个比较少用的控件:ViewFlipper
学习一个未知的东西,第一步就是要搞懂what:学的这个东西是什么以及能够实现什么效果!第二步就是要搞懂How:这个东西如何使用。

What:

该控件的官方介绍:

Simple ViewAnimator that will animate between two or more views that have been added to it. Only one child is shown at a time. If requested, can automatically flip between each child at a regular interval.

鄙人的翻译:

简单ViewAnimator实现器将已添加到其两个或多个视图之间实现动画效果。 一次只显示一个孩子(子视图)。
如果需要,可以在每个孩子(子视图)之间定期自动翻转。

How:

实现方式:

1.继承ViewFlipper类通过代码设置动画间隔时间以及动画效果

1.1自定义ViewFlipper

/**
 * Created by Veyron on 2017/2/20.
 * Function:自定义ViewFlipper控件
 */

public class UpView extends ViewFlipper {

 private Context mContext;
 private boolean isSetAnimDuration = false;
 private int interval = 2000;
 /**
 * 动画时间
 */
 private int animDuration = 500;

 public UpView(Context context, AttributeSet attrs) {
 super(context, attrs);
 init(context, attrs, 0);
 }

 private void init(Context context, AttributeSet attrs, int defStyleAttr) {
 this.mContext = context;
 setFlipInterval(interval);//设置时间间隔2000毫秒
 //进来的动画
 Animation animIn = AnimationUtils.loadAnimation(mContext, R.anim.anim_in);
 if (isSetAnimDuration)
  animIn.setDuration(animDuration);
 setInAnimation(animIn);
 //退出的动画
 Animation animOut = AnimationUtils.loadAnimation(mContext, R.anim.anim_out);
 if (isSetAnimDuration)
  animOut.setDuration(animDuration);
 setOutAnimation(animOut);
 }

 /**
 * 设置循环滚动的View数组
 *
 * @param views
 */
 public void setViews(final List<View> views) {
 if (views == null || views.size() == 0) return;
 removeAllViews();
 for ( int i = 0; i < views.size(); i++) {
  final int position=i;
  //设置翻滚的子view
  addView(views.get(i));
 }
 startFlipping(); //开启翻滚
 }
}

1.2布局文件中引入

 <com.veyron.www.viewflipperdemo.View.UpView
  android:id="@+id/upview1"
  android:layout_marginLeft="20dp"
  android:layout_width="match_parent"
  android:layout_toRightOf="@+id/tbtv"
  android:layout_centerVertical="true"
  android:layout_marginTop="10dp"
  android:layout_height="match_parent">
  </com.veyron.www.viewflipperdemo.View.UpView>

2.除了方式一,还可以在布局文件中通过设定ViewFlipper的属性来达到同样的效果。

<ViewFlipper
  android:id="@+id/upview2"
  android:autoStart="true"
  android:background="#fff"
  android:inAnimation="@anim/anim_in"
  android:outAnimation="@anim/anim_out"
  android:flipInterval="3000">
  </ViewFlipper>

具体实现上面两种方式

MainActivity.java

/**
 * Created by Veyron on 2017/2/20.
 * Function:主界面,加载布局
 */
public class MainActivity extends AppCompatActivity {
 private UpView upview1; //自定义的ViewFlipper
 private ViewFlipper mViewFlipper; //直接使用该控件

 List<String> data = new ArrayList<>(); //文字数据集合
 List<View> views = new ArrayList<>(); //滚动的view集合

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);
  initdata();
  initView();
 }

 private void initView() {
 //自定义的
 upview1 = (UpView) findViewById(R.id.upview1);
 setView();
 upview1.setViews(views);//给自定义的ViewFlipper设置滚动的view

 //非自定义的,直接使用控件的
 mViewFlipper = (ViewFlipper) findViewById(R.id.upview2);
 //添加翻滚的子view
 mViewFlipper.addView(View.inflate(this, R.layout.view1, null));
 mViewFlipper.addView(View.inflate(this, R.layout.view2, null));
 }

 /**
 * 初始化需要循环的View
 * 为了灵活的使用滚动的View,所以把滚动的内容让用户自定义
 * 假如滚动的是三条或者一条,或者是其他,只需要把对应的布局,和这个方法稍微改改就可以了,
 */
 private void setView() {
 for (int i = 0; i < data.size(); i = i + 2) {
  final int position = i;
  //设置滚动的单个布局
  LinearLayout moreView = (LinearLayout) LayoutInflater.from(this).inflate(R.layout.item_view, null);
  //初始化布局里面的控件,只要设置这两个控件的监听就达到目的
  TextView tv1 = (TextView) moreView.findViewById(R.id.tv1);
  TextView tv2 = (TextView) moreView.findViewById(R.id.tv2);

  /**
  * 设置监听
  */
  moreView.findViewById(R.id.rl).setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
   Toast.makeText(MainActivity.this, data.get(position).toString(), Toast.LENGTH_SHORT).show();
   Log.d("TAG",data.get(position).toString());
   /**
   * 添加业务代码
   */
  }
  });
  /**
  * 设置监听
  */
  moreView.findViewById(R.id.rl2).setOnClickListener(new View.OnClickListener() {
  @Override
  public void onClick(View view) {
   Toast.makeText(MainActivity.this, data.get(position+1).toString(), Toast.LENGTH_SHORT).show();
   Log.d("TAG",data.get(position+1).toString());
   /**
   * 添加业务代码
   */
  }
  });

  //进行对控件赋值
  tv1.setText(data.get(i).toString());
  if (data.size() > i + 1) {
  //因为淘宝那儿是两条数据,但是当数据是奇数时就不需要赋值第二个,所以加了一个判断,还应该把第二个布局给隐藏掉
  tv2.setText(data.get(i + 1).toString());
  } else {
  moreView.findViewById(R.id.rl2).setVisibility(View.GONE);
  }

  //添加到循环滚动数组里面去
  views.add(moreView); //也就是滚动的view集合
 }
 }
 /**
 * 初始化数据
 */
 private void initdata() {
 data = new ArrayList<>();
 data.add("美剧《行尸走肉》上线Steam 每一集售价2.99...");
 data.add("2017四月新番动画全预览!你期待那部");
 data.add("生娃后,老公有过这些举动,你却没加错人!");
 data.add("汽车开空调耗油?只因为按错了一个键");
 data.add("心疼S7 edge 三星官方‘虐机'视频上线");
 }
}

API介绍

常用属性:

  • autoStart:ture,则自动开始滚动
  • inAnimation:滚动进入的动画
  • outAnimation:滚动出去的动画
  • flipInterval:时间间隔

常用方法:

  • startFlipping():开始翻滚
  • setOutAnimation():滚动出去的动画
  • setInAnimation():滚动进入的动画
  • setFlipInterval():设置时间间隔-毫秒
  • ViewFlipper对象的addView():加载需要滚动的视图对象

ViewFlipper具体属性详见:ViewFlipper控件的官方api

源码:

ViewFlipperDemo

如果该你喜欢该项目,欢迎fork,欢迎点个Star!!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • Android ViewFlipper简单用法解析

    ViewFlipper和ViewPager挺像的,都是一个view容器.内部可以添加多个view,只是viewpager可以通过左右滑动来切换view,而viewFlipper则没有这个功能,所以需要在它上面监听手势.比较方便的是它不用使用适配器就能添加view,所以比较方便. 首先在布局文件中定义这个控件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android=&qu

  • Android ViewFlipper翻转视图使用详解

    简介 ViewFlipper是Android自带的一个多页面管理控件且可以自动播放!它和ViewPager有所不同,ViewPager继承自ViewGroup,是一页一页的,可以带动画效果,可以兼容低版本:而ViewFlipper继承ViewAnimator,是一层一层的,切换View的时候可以设置动画效果,是Android 4.0才引入的新控件.使用场景和ViewPager基本一样,在很多时候都是用来实现进入应用后的引导页或者用于图片轮播显示. 常用方法 setInAnimation:View

  • 解析Android中实现滑动翻页之ViewFlipper的使用详解

    1)View切换的控件-ViewFlipper介绍 ViewFilpper类继承于ViewAnimator类.而ViewAnimator类继承于FrameLayout. 查看ViewAnimator类的源码可以看出此类的作用主要是为其中的View切换提供动画效果.该类有如下几个和动画相关的方法. setInAnimation:设置View进入屏幕时候使用的动画.该方法有两个重载方法,即可以直接传入Animation对象,也可以传入定义的Animation文件的resourceID. setOut

  • Android中利用viewflipper动画切换屏幕效果

    整个项目的 package com.example.viewflipper; import android.R.integer; import android.app.Activity; import android.os.Bundle; import android.util.Log; import android.view.GestureDetector.OnDoubleTapListener; import android.view.Menu; import android.view.Me

  • Android TextSwitcher文本切换器和ViewFlipper使用详解

    本文为大家分享了Android TextSwitcher文本切换器的使用,供大家参考,具体内容如下 1.TextSwitcher 使用: 应用分为三步: 1.得到 TextSwitcher 实例对象   TextSwitcher switcher = (TextSwitcher) findViewById(R.id.textSwitcher); 2.为switcher指定ViewSwitcher.ViewFactory工厂,该工厂会产生出转换时需要的View   switcher.setFact

  • Android中使用ViewFlipper进行手势切换实例

    本文实例讲述了Android中使用ViewFlipper进行手势切换的方法,分享给大家供大家参考.具体实现步骤如下: 首先在layout的xml文件中定义一个ViewFlipper: 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?>  <ViewFlipper xmlns:android="http://schemas.android.com/apk/res/android" 

  • ANDROID中使用VIEWFLIPPER类实现屏幕切换(关于坐标轴的问题已补充更改)

    屏幕切换指的是在同一个Activity内屏幕间的切换,ViewFlipper继承了Framelayout类,ViewAnimator类的作用是为FrameLayout里面的View切换提供动画效果.如下动图: 该类有如下几个和动画相关的函数: setInAnimation:设置View进入屏幕时候使用的动画,该函数有两个版本,一个接受单个参数,类型为android.view.animation.Animation:一个接受两个参数,类型为Context和int,分别为Context对象和定义An

  • Android中ViewFlipper的使用及设置动画效果实例详解

    本文实例讲述了Android中ViewFlipper的使用及设置动画效果.分享给大家供大家参考,具体如下: 说到左右滑动,其实实现左右滑动的方式很多,有ViewPaer,自定义实现Viewgroup,gallery等都可以达到这种效果.这里做下ViewFliper实现左右滑动的效果. 会用到以下的技术: 1.ViewFlipper 2.GestureDetector 3.Animation 主要是这三个类在起作用. ViewFlipper,不妨把它看做一个容器吧,你可以把许多的View放在这个容

  • Android ViewFlipper用法实例分析

    本文实例讲述了Android ViewFlipper用法.分享给大家供大家参考,具体如下: 这里实现的效果是当手动滑动手机屏幕时会一个一个地显示图片,一次显示一张图片 package com.my.viewflippertest; import android.app.Activity; import android.os.Bundle; import android.view.GestureDetector; import android.view.GestureDetector.OnGest

  • Android使用ViewFlipper实现图片切换功能

    今天给大家简单的讲一下Android手势,目前市场上的App中手势的运用比较少. Android提供了两种手势: ①.Android提供了手势检测,并为手势检测提供了相应的监听器 ②.Android允许开发者添加手势,并提供了相应的API识别用户手势 在之前的一片博客我讲过如何使用ViewPager实现图片滑动切换 地址:Android使用ViewPager实现图片滑动预览效果 但是ViewPager拥有自带的手势识别,意思就是它会自动识别手势是右滑还是左滑. 今天我讲一下如何使用ViewFli

随机推荐