AdvserView.java

package com.earen.viewflipper;

import android.content.Context;

import android.graphics.Bitmap;

import android.graphics.BitmapFactory;

import android.util.AttributeSet;

import android.view.Gravity;

import android.view.MotionEvent;

import android.view.animation.Animation;

import android.view.animation.TranslateAnimation;

import android.widget.FrameLayout;

import android.widget.ImageView;

import android.widget.LinearLayout;

import android.widget.ViewFlipper;

public class AdvserView extends FrameLayout {

  /** 当前索引值.默认第一张图片被选中 */

  private int _CurrentIndex = 0;

  /** 上下文对象 */

  private Context _Context;

  /**  点击屏幕的 X 左边值(触摸屏,告知绝对X屏幕位置接触点的中心区域。单位:像素。) */

  private float _startX;

  /**  设备的宽度 */

  private int _DisplayWidth;

  /**  从左到右进入的动画 */

  private Animation _Left2RightInAnimation;

  /**  从左到右出去动画 */

  private Animation _Left2RightOutAnimation;

  /**  从右到左进入动画 */

  private Animation _Right2LeftInAnimation;

  /**  从右到左出去动画 */

  private Animation _Right2LeftOutAnimation;

  /**  动画持续时间 */

  private long _duration = 1000;

  /**  ViewFlipper 控件 图片的容器 */

  private ViewFlipper _ViewFlipper;

  /**  屏幕上方动态生成点的容器(用于表示图片总数,和提示当前所查看的图片位置) */

  private LinearLayout _TopTipLinearLayout;

  /**  默认点的 Bitmap 对象 */

  private Bitmap _PointNormalBitmap;

  /**  被选中的点的 Bitmap 对象 */

  private Bitmap _PointSelectedBitmap;

  /**  图片的资源  */

  private int[] _imgResource = {R.drawable.image1,

                                       R.drawable.image2,

                   R.drawable.image3,

R.drawable.image4,

R.drawable.image5,

R.drawable.image6};

  public AdvserView(Context context) {

     super(context);

     setupViews();

}

  public AdvserView(Context context,AttributeSet attr) {

super(context,attr);

setupViews();

}

  /** 装载 视图 控件*/

  private void setupViews() {

     _Context = getContext();     // 获取上下文对象

     _DisplayWidth = getResources().getDisplayMetrics().widthPixels;  // 获取设备屏幕宽度(单位:像素)

       _ViewFlipper = new ViewFlipper(_Context);             // 创建 ViewFlipper 控件对象

     _TopTipLinearLayout = new LinearLayout(_Context);  // 创建 LinearLayout 线性布局控件对象

     _TopTipLinearLayout.setGravity(Gravity.CENTER_HORIZONTAL);

_PointNormalBitmap =BitmapFactory.decodeResource(getResources(), R.drawable.point_normal);

_PointSelectedBitmap =BitmapFactory.decodeResource(getResources(), R.drawable.point_selected);

// 添加 图片指定的图片资源到 ViewFlipper 对象中

    for (int i = 0; i < _imgResource.length; i++) {

        ImageView imageView = new ImageView(_Context);

        imageView.setImageResource(_imgResource[i]);    _ViewFlipper.addView(imageView);

     }

// 为 _TopTipLinearLayout 对象添加 表示图片显示的点情况

    for (int i = 0; i < _imgResource.length; i++) {

      ImageView imageView = new ImageView(_Context);

if (i==0) { // 默认第一个为选中情况下的图片

                  imageView.setImageBitmap(_PointSelectedBitmap);

}else {

          imageView.setImageBitmap(_PointNormalBitmap);

       }

_TopTipLinearLayout.addView(imageView);

}

        addView(_ViewFlipper);

        addView(_TopTipLinearLayout);

//初始化动画.

_Left2RightInAnimation = new TranslateAnimation(-_DisplayWidth, 0, 0, 0);

_Left2RightInAnimation.setDuration(_duration);

_Left2RightOutAnimation = new TranslateAnimation(0, _DisplayWidth, 0, 0);

_Left2RightOutAnimation.setDuration(_duration);

_Right2LeftInAnimation = new TranslateAnimation(_DisplayWidth, 0, 0, 0);

_Right2LeftInAnimation.setDuration(_duration);

_Right2LeftOutAnimation = new TranslateAnimation(0, -_DisplayWidth, 0, 0);

_Right2LeftOutAnimation.setDuration(_duration);

  }

  @Override

public boolean onTouchEvent(MotionEvent event) {

switch (event.getAction()) {

             case MotionEvent.ACTION_DOWN:    // 手指按下

                 _startX = event.getX();

break;

case MotionEvent.ACTION_UP:      // 手指弹起

/** 最后一个被选中的 图片视图控件 ,即当前看到的图片视图控件 */

ImageView lastSellectedImageView  = (ImageView)_TopTipLinearLayout.getChildAt(_CurrentIndex);

//判断左右滑动切换图片.

if(event.getX() > _startX){  //  从左向右滑动

_ViewFlipper.setInAnimation(_Left2RightInAnimation);

_ViewFlipper.setOutAnimation(_Left2RightOutAnimation);

_ViewFlipper.showNext();

_CurrentIndex--;

if(_CurrentIndex < 0){

_CurrentIndex = _imgResource.length -1;

}

}else if(event.getX() < _startX){  //  从右向左滑动

                         _ViewFlipper.setInAnimation(_Right2LeftInAnimation);

_ViewFlipper.setOutAnimation(_Right2LeftOutAnimation);

_ViewFlipper.showPrevious();

_CurrentIndex++;

if(_CurrentIndex > _imgResource.length -1){

_CurrentIndex = 0;

}

}

// 设置 标识 图片位置的  点 图标

ImageView imageview = (ImageView)_TopTipLinearLayout.getChildAt(_CurrentIndex);

imageview.setImageBitmap(_PointSelectedBitmap);

lastSellectedImageView.setImageBitmap(_PointNormalBitmap);

break;

default:

break;

}

return true;

}

}

MainActivity.java

package com.earen.viewflipper;

import android.os.Bundle;

import android.app.Activity;

import android.view.Menu;

import android.view.Window;

public class MainActivity extends Activity {

  @Override

  protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);

       //setContentView(R.layout.activity_main);

// 不显示标题栏(须在 setContentView之前使用方能生效)

requestWindowFeature(Window.FEATURE_NO_TITLE);

setContentView(new AdvserView(this));  

  }

   @Override

  public boolean onCreateOptionsMenu(Menu menu) {

     // Inflate the menu; this adds items to the action bar if it is present.

        //getMenuInflater().inflate(R.menu.main, menu);

return true;

}

}

最终效果:

ViewFlipper 简单应用的更多相关文章

  1. Android 控件

    1. WebView <uses-permission android:name="android.permission.INTERNET" /> WebView wv ...

  2. ViewFlipper的简单使用实现图片轮播效果

    /** * ViewFlipper: * 安卓系统自带的一个多页面管理控件,它可以实现子页面的自动切换 * 为ViewFlipper加入View: * (1)在layout布局文件静态导入子View ...

  3. Android真正简单的教程-第十二枪(ViewFlipper实现滑动效果)

    直接看代码 1.MainActivity.java: package org.yayun.demo; import android.app.Activity; import android.os.Bu ...

  4. ViewFlipper的简单用法

    ViewFlipper和ViewPager挺像的,都是一个view容器.内部可以添加多个view,只是viewpager可以通过左右滑动来切换view,而viewFlipper则没有这个功能,所以需要 ...

  5. Android中使用ViewFlipper实现屏幕页面切换(关于坐标轴的问题已补充更改)

    屏幕切换指的是在同一个Activity内屏幕间的切换,ViewFlipper继承了Framelayout类,ViewAnimator类的作用是为FrameLayout里面的View切换提供动画效果.如 ...

  6. Android ViewFlipper的使用分析

    [ViewFlipper]——基础 1.ViewPager 和ViewFliping的区别: 最显著的区别就是ViewPager在滑动的时候内部的View默认就能够跟随手指滑动,而 ViewFlipi ...

  7. Android 通过ViewFlipper实现广告轮播功能并可以通过手势滑动进行广告切换

    为了实现广告轮播功能,在网上找了很多方法,有的效果很好,但是代码太麻烦,并且大多是用的viewpager,总之不是很满意. 于是看了一下sdk有个控件是ViewFlipper,使用比较方便,于是尝试了 ...

  8. Android ViewFlipper用法浅析

    在Android应用开发中,我们经常会需要实现左右切换视图的功能,这通常需要在LinearLayout.RelativeLayout等布局中添加ImageView来实现.如果每次只需展示一张图片,并可 ...

  9. UI特效--Android利用ViewFlipper实现屏幕切换动画效果

    .屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面.2.介绍ViewFilpper类ViewFl ...

随机推荐

  1. 使用IDEA开发SpringBoot不加载application.yml配置文件的解决方案

    1.如果启动项目不加载application.yml配置文件,那么请确认下是否应用了Resources为项目资源文件夹 2.如果项目起初是可以正常使用的,突然不知道改了什么,然后进行启动项目的时候不加 ...

  2. 学习Solr(三)

    本文以solr5为例说明在linux系统上单机安装过程. 一.    solr的安装 1.   solr能够安装在不同的操作系统上,安装solr前需要安装何时的JRE.当前版本5.5最低需要JRE1. ...

  3. 每天坚持一个CSS——社会人

    每天一个CSS-社会人 实现效果 想法 之前看到一篇博客,使用python绘制出了小猪佩奇,所以自己想试一试,采用纯html + CSS绘制出低配版的小猪佩奇. 实现思路 使用上一篇,圆与边框实现.最 ...

  4. 来扯点ionic3[7] LocalStorage的使用—以登录和注销为例

    一般意义上,一个互联网 APP 中的数据主自与服务器的交互,但是对于有些数据,我们希望获取到它们以后能保存,并在全局环境使用,比如用户数据--我们不希望在每个页面都从服务器拉取一遍.这时我们就可以利用 ...

  5. 从kill-chain的角度检测APT攻击

    前言 最近一直在考虑如何结合kill chain检测APT攻击.出发点是因为尽管APT是一种特殊.高级攻击手段,但是它还是会具有攻击的common feature,只要可以把握住共同特征,就能进行检测 ...

  6. Idea运行时Scala报错Exception in thread "main" java.lang.NoSuchMethodError:com.google.common.base.Preconditions.checkArgument(ZLjava/lang/String;Ljava/lang/Object;)V

    一.情况描述 使用idea +scala+spark,运行程序代码如下: package cn.idcast.hello import org.apache.spark.rdd.RDD import ...

  7. java堆排序

    直接贴源代码: package com.java.fmd; import java.util.Scanner; public class HeapSort { int[] arr; public st ...

  8. 校验ip地址的格式

    /*输入:strIP:ip地址 返回:如果通过验证返回true,否则返回false: */ function isIP(strIP) { if (isNull(strIP)) return false ...

  9. 体验了一把最近很火的开源项目-MASA Blazor

    前言 很惭愧直到去年底才接触到Blazor.那什么是Blazor呢?相信大家都看过官方文档的详细说明,另外MASA团队也有不错的说明介绍 .用官方的话说Blazor是一个交互式客户端Web UI的框架 ...

  10. OllyDbg---比较、条件跳转指令

    比较和条件跳转 CMP 比较两个操作数,相当于SUB指令,但是相减的结果不保存到第一个操作数,而是根据相减的结果来改变零标志位.当两个操作数相等时,零标志位Z置为1. 两个操作数不相等时,零标志位Z被 ...