ViewFlipper 简单应用
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 简单应用的更多相关文章
- Android 控件
1. WebView <uses-permission android:name="android.permission.INTERNET" /> WebView wv ...
- ViewFlipper的简单使用实现图片轮播效果
/** * ViewFlipper: * 安卓系统自带的一个多页面管理控件,它可以实现子页面的自动切换 * 为ViewFlipper加入View: * (1)在layout布局文件静态导入子View ...
- Android真正简单的教程-第十二枪(ViewFlipper实现滑动效果)
直接看代码 1.MainActivity.java: package org.yayun.demo; import android.app.Activity; import android.os.Bu ...
- ViewFlipper的简单用法
ViewFlipper和ViewPager挺像的,都是一个view容器.内部可以添加多个view,只是viewpager可以通过左右滑动来切换view,而viewFlipper则没有这个功能,所以需要 ...
- Android中使用ViewFlipper实现屏幕页面切换(关于坐标轴的问题已补充更改)
屏幕切换指的是在同一个Activity内屏幕间的切换,ViewFlipper继承了Framelayout类,ViewAnimator类的作用是为FrameLayout里面的View切换提供动画效果.如 ...
- Android ViewFlipper的使用分析
[ViewFlipper]——基础 1.ViewPager 和ViewFliping的区别: 最显著的区别就是ViewPager在滑动的时候内部的View默认就能够跟随手指滑动,而 ViewFlipi ...
- Android 通过ViewFlipper实现广告轮播功能并可以通过手势滑动进行广告切换
为了实现广告轮播功能,在网上找了很多方法,有的效果很好,但是代码太麻烦,并且大多是用的viewpager,总之不是很满意. 于是看了一下sdk有个控件是ViewFlipper,使用比较方便,于是尝试了 ...
- Android ViewFlipper用法浅析
在Android应用开发中,我们经常会需要实现左右切换视图的功能,这通常需要在LinearLayout.RelativeLayout等布局中添加ImageView来实现.如果每次只需展示一张图片,并可 ...
- UI特效--Android利用ViewFlipper实现屏幕切换动画效果
.屏幕切换指的是在同一个Activity内屏幕见的切换,最长见的情况就是在一个FrameLayout内有多个页面,比如一个系统设置页面:一个个性化设置页面.2.介绍ViewFilpper类ViewFl ...
随机推荐
- JVM中的常量池
在Java的内存分配中,总共3种常量池: ref:https://blog.csdn.net/zm13007310400/article/details/77534349 1.字符串常量池(Strin ...
- Kali Linux 下安装配置MongoDB数据库 ubuntu 下安装配置MongoDB源码安装数据库
Kali Linux 下安装配置MongoDB数据库 1.下载mongodb.tgz 压缩包: 2.解压到:tar -zxvf mongodb.tgz /usr/local/mongodb 3.创 ...
- '\ddd'转义字符与八进制转换
所有的ASCII码都可以用"\"加数字(一般是8进制数字)来表示.而C中定义了一些字母前加"\"来表示常见的那些不能显示的ASCII字符,如\0,\t,\n等, ...
- 220v-5v稳压电路
5V整流电路原理 先对电路进行整流 整流电路:利用单向导电器件将交流电转换成脉动直流电路,再用电容进行滤波 滤波电路:利用储能元件(电感或电容)把脉动直流电转换成比较平坦的直流电,然后对电路进行稳压 ...
- 关于Css的垂直居中的一些方法
前两种方法称为大致居中,一般误差随高度的减小而减小,不过一般来说不怎么看得出来,除非你用javascript调用offsetTop来查看.不然没有强迫症的比较难看出来.但是兼容性很好,尤其是table ...
- 可想实现一个自己的简单jQuery库?(五)
Lesson-4 这个版本我们要增加一个用的非常多的方法! 那就是each! 我们知道each不仅能遍历数组,还能遍历对象. 首先我们需要一个对数组进行验证的方法 function isArray(o ...
- VISIO下载+安装+第一个数据流图
一. 下载地址 Visio2021 (64bit).zip_免费高速下载|百度网盘-分享无限制 (baidu.com) 码3333 二. 安装步骤 Visio2021安装教程 (qq.com) 三. ...
- Python简单文件读写
''' 用文件存储账户信息 使用列表存储多个账户信息,每个账户为一个字典对象 ''' users=[] #创建一个空列表 users.append({'id':'admin','pwd':'1235@ ...
- spring原始注解(value)-03
本博客依据是是spring原始注解-02的代码 注入普通数据类型:@Value注解的使用 1.添加driver属性,使用value注解 @Service("userService" ...
- linux lvm逻辑卷管理之lvdisplay命令
linux 磁盘管理分fdisk parted 和LVM三种方式,我们这里重点是说lvm 我们来看看LVM基本术语(lvm和传统fdisk分区方式有区别)由于传统的磁盘管理不能对磁盘进行磁盘管理,因此 ...