Android利用ViewPager实现滑动广告板实例源码

•android-support-v4.jar,这是谷歌官方给我们提供的一个兼容低版本Android设备的软件包,里面包囊了只有在Android3.0以上可以使用的api。而ViewPager就是其中之一,利用它我们可以做很多事情,从最简单的导航,到页面切换菜单等等。

•ViewPager的功能就是可以使视图滑动,就像Lanucher左右滑动那样。

•本Demo向大家演示ViewPager的使用,并在用户未滑动View时,每隔5s钟自动切换到下一个View(循环切换),而当用户有Touch到View时取消5s自动切换功能。并有指示器指示当前处于哪一个View。

下面是运行的截图:

 

这个是非常常见的应用

下面给出实现的代码:

1.源文件

复制代码 代码如下:

package com.eyeandroid.viewpager;

import java.util.ArrayList;

import java.util.List;

import java.util.concurrent.atomic.AtomicInteger;

import android.annotation.SuppressLint;

import android.app.Activity;

import android.os.Bundle;

import android.os.Handler;

import android.os.Message;

import android.os.Parcelable;

import android.support.v4.view.PagerAdapter;

import android.support.v4.view.ViewPager;

import android.support.v4.view.ViewPager.OnPageChangeListener;

import android.view.MotionEvent;

import android.view.View;

import android.view.View.OnTouchListener;

import android.view.ViewGroup;

import android.view.ViewGroup.LayoutParams;

import android.widget.ImageView;

@SuppressLint("HandlerLeak")

public class MainActivity extends Activity {

private ImageView[] imageViews = null;

private ImageView imageView = null;

private ViewPager advPager = null;

private AtomicInteger what = new AtomicInteger(0);

private boolean isContinue = true;

@Override

public void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.main);

initViewPager();

}

private void initViewPager() {

advPager = (ViewPager) findViewById(R.id.adv_pager);

ViewGroup group = (ViewGroup) findViewById(R.id.viewGroup);

// 这里存放的是四张广告背景

List<View> advPics = new ArrayList<View>();

ImageView img1 = new ImageView(this);

img1.setBackgroundResource(R.drawable.advertising_default_1);

advPics.add(img1);

ImageView img2 = new ImageView(this);

img2.setBackgroundResource(R.drawable.advertising_default_2);

advPics.add(img2);

ImageView img3 = new ImageView(this);

img3.setBackgroundResource(R.drawable.advertising_default_3);

advPics.add(img3);

ImageView img4 = new ImageView(this);

img4.setBackgroundResource(R.drawable.advertising_default);

advPics.add(img4);

// 对imageviews进行填充

imageViews = new ImageView[advPics.size()];

//小图标

for (int i = 0; i < advPics.size(); i++) {

imageView = new ImageView(this);

imageView.setLayoutParams(new LayoutParams(20, 20));

imageView.setPadding(5, 5, 5, 5);

imageViews[i] = imageView;

if (i == 0) {

imageViews[i]

.setBackgroundResource(R.drawable.banner_dian_focus);

} else {

imageViews[i]

.setBackgroundResource(R.drawable.banner_dian_blur);

}

group.addView(imageViews[i]);

}

advPager.setAdapter(new AdvAdapter(advPics));

advPager.setOnPageChangeListener(new GuidePageChangeListener());

advPager.setOnTouchListener(new OnTouchListener() {

@Override

public boolean onTouch(View v, MotionEvent event) {

switch (event.getAction()) {

case MotionEvent.ACTION_DOWN:

case MotionEvent.ACTION_MOVE:

isContinue = false;

break;

case MotionEvent.ACTION_UP:

isContinue = true;

break;

default:

isContinue = true;

break;

}

return false;

}

});

new Thread(new Runnable() {

@Override

public void run() {

while (true) {

if (isContinue) {

viewHandler.sendEmptyMessage(what.get());

whatOption();

}

}

}

}).start();

}

private void whatOption() {

what.incrementAndGet();

if (what.get() > imageViews.length - 1) {

what.getAndAdd(-4);

}

try {

Thread.sleep(5000);

} catch (InterruptedException e) {

}

}

private final Handler viewHandler = new Handler() {

@Override

public void handleMessage(Message msg) {

advPager.setCurrentItem(msg.what);

super.handleMessage(msg);

}

};

private final class GuidePageChangeListener implements OnPageChangeListener {

@Override

public void onPageScrollStateChanged(int arg0) {

}

@Override

public void onPageScrolled(int arg0, float arg1, int arg2) {

}

@Override

public void onPageSelected(int arg0) {

what.getAndSet(arg0);

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

imageViews[arg0]

.setBackgroundResource(R.drawable.banner_dian_focus);

if (arg0 != i) {

imageViews[i]

.setBackgroundResource(R.drawable.banner_dian_blur);

}

}

}

}

private final class AdvAdapter extends PagerAdapter {

private List<View> views = null;

public AdvAdapter(List<View> views) {

this.views = views;

}

@Override

public void destroyItem(View arg0, int arg1, Object arg2) {

((ViewPager) arg0).removeView(views.get(arg1));

}

@Override

public void finishUpdate(View arg0) {

}

@Override

public int getCount() {

return views.size();

}

@Override

public Object instantiateItem(View arg0, int arg1) {

((ViewPager) arg0).addView(views.get(arg1), 0);

return views.get(arg1);

}

@Override

public boolean isViewFromObject(View arg0, Object arg1) {

return arg0 == arg1;

}

@Override

public void restoreState(Parcelable arg0, ClassLoader arg1) {

}

@Override

public Parcelable saveState() {

return null;

}

@Override

public void startUpdate(View arg0) {

}

}

}

2.布局文件

这个文件在屏幕上的图片显示具有至关重要的作用

复制代码 代码如下:

<?xml version="1.0" encoding="utf-8"?>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:layout_width="fill_parent"

android:layout_height="fill_parent"

android:orientation="vertical" >

<RelativeLayout

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:orientation="vertical" >

<!-- ViewPager是一个控件 -->

<android.support.v4.view.ViewPager

android:id="@+id/adv_pager"

android:layout_width="fill_parent"

android:layout_height="160dp" >

</android.support.v4.view.ViewPager>

<LinearLayout

android:id="@+id/viewGroup"

android:layout_below="@id/adv_pager"

android:layout_width="fill_parent"

android:layout_height="wrap_content"

android:layout_marginTop="-25px"

android:gravity="right"

android:orientation="horizontal" >

</LinearLayout>

</RelativeLayout>

</LinearLayout>

时间: 2024-08-29 06:19:39

Android利用ViewPager实现滑动广告板实例源码的相关文章

Android利用ViewPager实现滑动广告板实例源码_Android

•android-support-v4.jar,这是谷歌官方给我们提供的一个兼容低版本Android设备的软件包,里面包囊了只有在Android3.0以上可以使用的api.而ViewPager就是其中之一,利用它我们可以做很多事情,从最简单的导航,到页面切换菜单等等. •ViewPager的功能就是可以使视图滑动,就像Lanucher左右滑动那样. •本Demo向大家演示ViewPager的使用,并在用户未滑动View时,每隔5s钟自动切换到下一个View(循环切换),而当用户有Touch到Vi

Android管理与操作Wifi简单实例源码_Android

因为需要一直在弄网络的问题,今天看了一下Wifi的操作,经过整理,做出来了一个类,可能不全,但是个人感觉已经完全能够满足需要了,当然,里面的方法也有可能是错误的或者是不全的,这个类我没有进行完整的测试,只测试了其中的一些方法. 其实操作Wifi也是很简单的,主要使用以下几个对象或变量: private WifiManager wifiManager;// 声明管理对象OpenWifi private WifiInfo wifiInfo;// Wifi信息 private List<ScanRes

Android管理与操作Wifi简单实例源码

因为需要一直在弄网络的问题,今天看了一下Wifi的操作,经过整理,做出来了一个类,可能不全,但是个人感觉已经完全能够满足需要了,当然,里面的方法也有可能是错误的或者是不全的,这个类我没有进行完整的测试,只测试了其中的一些方法. 其实操作Wifi也是很简单的,主要使用以下几个对象或变量: private WifiManager wifiManager;// 声明管理对象OpenWifi private WifiInfo wifiInfo;// Wifi信息 private List<ScanRes

Android 利用ViewPager实现图片可以左右循环滑动效果附代码下载_Android

首先给大家展示靓照,对效果图感兴趣的朋友可以继续往下阅读哦. ViewPager这个小demo实现的是可以左右循环滑动图片,下面带索引,滑到最后一页在往右滑动就要第一页,第一页往左滑动就到最后一页,上面是效果图,用美女图片是我一贯的作风,呵呵  1.    首先看一些layout下的xml <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width=&qu

Android利用ViewPager实现用户引导界面效果的方法_Android

本文实例讲述了Android利用ViewPager实现用户引导界面效果.分享给大家供大家参考,具体如下: 我相信有很多朋友在装完软件首次打开时,有很多软件都有一个软件功能介绍, 例如刚装完微信打开它,有很多介绍微信功能的图片,并且在屏幕下方有很多小圆点提示你当前图片的位置. 今天我就来实现这么个功能 所实现的功能: 1.可以左右滑动功能图片. 2.图片的索引 看出当前图片所在的位置. 3.可循环滑动. 4.图片的索引带有动画效果. 本次学习主要是利用ViewPager实现用户引导界面 在这里,我

Android利用ViewPager实现用户引导界面效果的方法

本文实例讲述了Android利用ViewPager实现用户引导界面效果.分享给大家供大家参考,具体如下: 我相信有很多朋友在装完软件首次打开时,有很多软件都有一个软件功能介绍, 例如刚装完微信打开它,有很多介绍微信功能的图片,并且在屏幕下方有很多小圆点提示你当前图片的位置. 今天我就来实现这么个功能 所实现的功能: 1.可以左右滑动功能图片. 2.图片的索引 看出当前图片所在的位置. 3.可循环滑动. 4.图片的索引带有动画效果. 本次学习主要是利用ViewPager实现用户引导界面 在这里,我

Android 实现ViewPager边界回弹效果实例代码

废话不多说了,直接给大家贴代码了,具体代码如下所示: public class BounceBackViewPager extends ViewPager { private int currentPosition = 0; private Rect mRect = new Rect();//用来记录初始位置 private boolean handleDefault = true; private float preX = 0f; private static final float RATI

Android仿腾讯QQ实现滑动删除 附源码下载_Android

看了很多大神们的文章,感觉受益良多,也非常欣赏大家的分享态度,所以决定开始写Blog,给大家分享自己的心得. 先看看效果图: 本来准备在ListView的每个Item的布局上设置一个隐藏的Button,当滑动的时候显示.但是因为每次只要存在一个Button,发现每个Item上的Button相互间不好控制.所以决定继承ListView然后结合PopupWindow. 首先是布局文件: delete_btn.xml:这里只需要一个Button <?xml version="1.0"

Android解决viewpager嵌套滑动冲突并保留侧滑菜单功能

重写子pagerview的dispatchTouchEvent方法,在返回前添加一句getParent().requestDisallowInterceptTouchEvent(true)中断掉事件的传递,类如下 public class SupperViewPager extends ViewPager { private int screenWidth;//屏幕宽度 public SupperViewPager(Context context) { super(context); } pub