所谓的轮番切换广告栏,指的是下面这个东西,笔主不知道该怎么确切描述这货...

笔主没有百度研究过其他大牛是怎么实现这个功能的,在这里笔主充分发挥DIY精神,利用ViewFlipper闭门土制了一个,下面尽笔主所能,将整个仿造过程所需的全部技能一次性放送出来,先上效果图!

(不保证以上广告真实性...)

素材:请自行百度图片,美女尤佳

圆点:1:  2:

ViewFlipper

android自带的ViewFlipper类提供了定时自动轮放内置View对象的功能,基本上这个博文所需要的大部分功能其实都已经现成实现了。。

但是有一个缺陷,原生的ViewFlipper并不提供自动播放时切换回调的监听器,就是说,图片广告切换的时候,你并不知道什么时候切换的,也不知道切换到了哪一张图,笔主通过研究源代码,继承派生了一个新的 NotifiableViewFlipper ,目的就是为了提供上述回调所需的监听器,代码如下

 import android.content.Context;
import android.util.AttributeSet;
import android.widget.ViewFlipper; /**
*
* @author wavky.wand
*
*/
public class NotifiableViewFlipper extends ViewFlipper { private OnFlipListener onFlipListener; public static interface OnFlipListener {
public void onShowPrevious(NotifiableViewFlipper flipper); public void onShowNext(NotifiableViewFlipper flipper);
} public void setOnFlipListener(
OnFlipListener onFlipListener) {
this.onFlipListener = onFlipListener;
} public NotifiableViewFlipper(Context context) {
super(context);
} public NotifiableViewFlipper(Context context, AttributeSet attrs) {
super(context, attrs);
} @Override
public void showPrevious() {
super.showPrevious();
if(hasFlipListener()){
onFlipListener.onShowPrevious(this);
}
} @Override
public void showNext() {
super.showNext();
if(hasFlipListener()){
onFlipListener.onShowNext(this);
}
} private boolean hasFlipListener() {
return onFlipListener != null;
}
}

布局文件:

笔主使用 RadioButton组 作为标记显示播放进度的那排小圆点,关于 RadioButton 的布局参数,如果遇到问题,请先参考博文 Android中使用RadioButton代替ImageButton

 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="#333"
android:orientation="vertical" > <wavky.wand.NotifiableViewFlipper
android:id="@+id/viewFlipper_AD"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:animateFirstView="true"
android:autoStart="true"
android:flipInterval="2000"
android:inAnimation="@anim/left_in"
android:minHeight="100dp"
android:outAnimation="@anim/left_out" /> <RadioGroup
android:id="@+id/radioGroup_flipperPoints"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBottom="@+id/viewFlipper_AD"
android:layout_centerHorizontal="true"
android:layout_marginBottom="10dp"
android:orientation="horizontal" > <RadioButton
android:id="@+id/radioButton_flipperPoint0"
style="@style/radioStyle_ADPoint"
android:checked="true" /> <RadioButton
android:id="@+id/radioButton_flipperPoint1"
style="@style/radioStyle_ADPoint" /> <RadioButton
android:id="@+id/radioButton_flipperPoint2"
style="@style/radioStyle_ADPoint" /> <RadioButton
android:id="@+id/radioButton_flipperPoint3"
style="@style/radioStyle_ADPoint" /> <RadioButton
android:id="@+id/radioButton_flipperPoint4"
style="@style/radioStyle_ADPoint" /> <RadioButton
android:id="@+id/radioButton_flipperPoint5"
style="@style/radioStyle_ADPoint" />
</RadioGroup> </RelativeLayout>

RadioButton的style脚本(截取):

     <style name="radioStyle_ADPoint">
<item name="android:gravity">center</item>
<item name="android:layout_width">wrap_content</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:layout_gravity">center</item>
<item name="android:button">@null</item>
<item name="android:background">@null</item>
<item name="android:clickable">false</item>
<item name="android:drawableLeft">@drawable/radio_adpoint</item>
<item name="android:layout_marginLeft">8dp</item>
</style>

Activity实现类:

 package wavky.wand.activity;

 import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.ImageView;
import android.widget.RadioGroup;
import android.widget.Toast; import wavky.wand.R;
import wavky.wand.activity.base.NotifiableViewFlipper;
import wavky.wand.activity.base.NotifiableViewFlipper.OnFlipListener; /**
*
* @author wavky.wand
*
*/
public class HomeActivity extends Activity{ // 轮番广告Flipper
private NotifiableViewFlipper adViewFlipper; // Flipper内的ImageView数组,保留引用,目前没什么用
private ImageView[] adFlipperImageViews; // 这里放六个具体广告图片的id
private int[] adIds = { R.drawable.home_ad_banner,
R.drawable.home_ad_banner, R.drawable.home_ad_banner,
R.drawable.home_ad_banner, R.drawable.home_ad_banner,
R.drawable.home_ad_banner }; // 轮番广告进度锚点(小圆点)
private RadioGroup adPointRadioGroup; // 六个小圆点的id
private static final int[] AD_POINT_IDS = { R.id.radioButton_flipperPoint0,
R.id.radioButton_flipperPoint1, R.id.radioButton_flipperPoint2,
R.id.radioButton_flipperPoint3, R.id.radioButton_flipperPoint4,
R.id.radioButton_flipperPoint5 }; // 广告数量
private static final int AD_FLIPPER_COUNT = AD_POINT_IDS.length; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_home);
adViewFlipper = (NotifiableViewFlipper) findViewById(R.id.viewFlipper_AD);
adPointRadioGroup = (RadioGroup) findViewById(R.id.radioGroup_flipperPoints);
adViewFlipper.setOnFlipListener(adFlipListener);
addAdFlipperImageViews();
} /**
* 初始化插入轮番广告
*/
private void addAdFlipperImageViews() {
adFlipperImageViews = new ImageView[AD_FLIPPER_COUNT];
for (int i = 0; i < AD_FLIPPER_COUNT; i++) {
ImageView imageView = makeAdFlipperImageView();
imageView.setImageResource(adIds[i]);
imageView.setOnClickListener(adFlipperImageViewListener);
adFlipperImageViews[i] = imageView;
adViewFlipper.addView(imageView);
}
} /**
* 工厂生产轮番广告容器ImageView对象
* @return
*/
private ImageView makeAdFlipperImageView() {
ImageView i = new ImageView(this);
i.setBackgroundColor(0xFF000000);
i.setScaleType(ImageView.ScaleType.FIT_CENTER);
i.setLayoutParams(new NotifiableViewFlipper.LayoutParams(
NotifiableViewFlipper.LayoutParams.MATCH_PARENT,
NotifiableViewFlipper.LayoutParams.MATCH_PARENT));
return i;
} /**
* 每个广告的点击事件监听器
*/
private OnClickListener adFlipperImageViewListener = new OnClickListener() { @Override
public void onClick(View v) {
Toast.makeText(HomeActivity.this, "广告 " + adViewFlipper.getDisplayedChild(), Toast.LENGTH_SHORT).show();
}
}; /**
* 轮番广告切换监听器,更新进度标记锚点的显示
*/
private OnFlipListener adFlipListener = new OnFlipListener() { @Override
public void onShowPrevious(NotifiableViewFlipper flipper) {
adPointRadioGroup.check(AD_POINT_IDS[flipper.getDisplayedChild()]);
} @Override
public void onShowNext(NotifiableViewFlipper flipper) {
adPointRadioGroup.check(AD_POINT_IDS[flipper.getDisplayedChild()]);
}
};
}

上述代码或存在引用包缺少、错误,缺少package指向,style文件头不完整等小问题,包括监听器具体功能的实现,请各位批判性自行调整修改。

完毕。

Android-使用ViewFlipper实现轮番切换广告栏的更多相关文章

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

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

  2. Android利用ViewFlipper实现屏幕切换动画效果

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

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

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

  4. Android 中利用ViewFlipper 滑动屏幕切换页面,ListView展示数据

    首先新建一个Android项目,命名为ViewFlipperTest 如图:项目机构,本项目主要操作图中红色箭头标注的文件 1.HgroupAdapter.java文件代码↓主要实现listview数 ...

  5. Android使用ViewFlipper实现左右滑动效果面

    在我的博客中,上次是使用ViewPager实现左右滑动的效果的,请看文章:Android使用ViewPager实现左右滑动效果. 这次我来使用ViewFlipper实现这种效果,好了,先看看效果吧: ...

  6. android listview的HeadView左右切换图片(仿新浪,网易,百度等切换图片)

    首先我们还是看一些示例:(网易,新浪,百度) 显示效果都不错,可是手感就不一样了,百度最棒,网易还行,新浪就操作很不好,这里我说的是滑动切换图片.自己可以测试一下.不得不说牛叉的公司确实有哦牛叉的道理 ...

  7. 【转】Android android listview的HeadView左右切换图片(仿新浪,网易,百度等切换图片)

    首先我们还是看一些示例:(网易,新浪,百度)      下面我简单的介绍下实现方法:其实就是listview addHeaderView.只不过这个view是一个可以切换图片的view,至于这个vie ...

  8. 【转】android ViewPager,ViewFlipper,ViewFlow实现左右滑动

    转自:http://blog.csdn.net/zhouyuanjing/article/details/8290454 开篇 首页只是作为ViewPager,ViewFlipper,ViewFlow ...

  9. android之ViewFlipper

    xml文件 activity-main.xml <ViewFlipper xmlns:android="http://schemas.android.com/apk/res/andro ...

随机推荐

  1. 使用SQLite删除Mac OS X 中launchpad里的快捷方式

    一般情况下,从App Store安装的应用程序,如果应用删除,那么launchpad里对应的图标会一起删除了. 而对于不是通过App Store安装的应用程序,删除应用程序,Launchpad中很可能 ...

  2. ruby 类库组成

    一. 核心类库: 二.标准类库: 文本 base64.rb 处理Base64编码的模块     csv.rb CSV(Comma Separated Values)库 ruby 1.8 特性     ...

  3. stm32f103 time2配置,转载

    //----------------------------main()-------------------- //stm32f103c8t6有3个普通1个高级定时器 //每次进入中断服务程序间隔时 ...

  4. 对bluebird的理解

    前言 Promise:把原来的回调写法分离出来,在异步操作执行完后,用链式调用的方式执行回调函数. 在公众号的开发里面用的const Promise = require('bluebird');con ...

  5. poj 2393 奶牛场生产成本问题 贪心算法

    题意:有一个奶牛场,第i周的生产成本为c,需要数量为 y,每周的存储成本为s.问怎么安排使得成本最低? 思路: 成本最低是吧?求出每周的最低成本*该周需要的数量就是成本最低 每周的成本有两个:自己本周 ...

  6. [Cracking the Coding Interview] 4.3 List of Depths

    Given a binary tree, design an algorithm which creates a linked list of all the nodes at each depth. ...

  7. 从0开始 java 网站开发(jsp)【1】

    前提:安装java 并配置环境变量 java下载地址: http://www.java.com/zh_CN/ 环境变量配置 本地PC路径: 电脑--属性--高级--环境变量 在系统变量中: 新建 名: ...

  8. 利用JS调取电脑摄像头,实现拍照功能

    1.调取电脑摄像头非常简单,看代码一幕了然 window.addEventListener("DOMContentLoaded", function() { var canvas ...

  9. C#的委托Delegate

    一.委托基础 1.什么是委托 委托(Delegate) 是存有对某个方法的引用的一种引用类型变量,用关键字delegate申明,实现相同返回值和参数的函数的动态调用,提供了对方法的抽象. 委托(Del ...

  10. (转) Sqoop使用实例讲解

    原博客地址:http://blog.csdn.net/evankaka 摘要:本文主要讲了笔者在使用sqoop过程中的一些实例 一.概述与基本原理 Apache Sqoop(SQL-to-Hadoop ...