【移动应用开发技术】怎么在Android中使用ViewPager实现一个滚动广告效果_第1页
【移动应用开发技术】怎么在Android中使用ViewPager实现一个滚动广告效果_第2页
【移动应用开发技术】怎么在Android中使用ViewPager实现一个滚动广告效果_第3页
【移动应用开发技术】怎么在Android中使用ViewPager实现一个滚动广告效果_第4页
【移动应用开发技术】怎么在Android中使用ViewPager实现一个滚动广告效果_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

【移动应用开发技术】怎么在Android中使用ViewPager实现一个滚动广告效果

这篇文章给大家介绍怎么在Android中使用ViewPager实现一个滚动广告效果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。文件结构:布局文件:<?xml

version="1.0"

encoding="utf-8"?>

<RelativeLayout

xmlns:android="/apk/res/android"

xmlns:tools="/tools"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:paddingBottom="@dimen/activity_vertical_margin"

android:paddingLeft="@dimen/activity_horizontal_margin"

android:paddingRight="@dimen/activity_horizontal_margin"

android:paddingTop="@dimen/activity_vertical_margin"

tools:context="yuxin.ad.MainActivity">

<android.support.v4.view.ViewPager

android:id="@+id/viewPager"

android:layout_width="wrap_content"

android:layout_height="200dp"

android:adjustViewBounds="true"

/>

<LinearLayout

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:layout_alignBottom="@id/viewPager"

android:background="#33000000"

android:orientation="vertical"

android:padding="5dp">

<LinearLayout

android:id="@+id/show_point"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center_horizontal"

android:orientation="horizontal"

/>

</LinearLayout>

</RelativeLayout>最上面是一个ViewPager,用来展示需要滚动播放的图片;下面是一个线性布局,用来放最下面的几个小圆点,也可以在里面放一些TextView等,小圆点的数量是根据图片数量动态添加的。MainActivity.javapublic

class

MainActivity

extends

AppCompatActivity

{

private

ViewPager

viewPager;

//

存放图片

private

List<ImageView>

imageViewList;

private

ImageView

imageView;

//

存放小圆点布局文件

private

LinearLayout

layoutPointGroup;

//

线程开关,当activity销毁后,线程也应该停止运行

private

boolean

isStop

=

false;

private

int

previousPoint

=

0;

@Override

protected

void

onCreate(Bundle

savedInstanceState)

{

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

//

初始化

init();

//设置图片自动滚动

new

Thread(new

Runnable()

{

@Override

public

void

run()

{

//如果activity未销毁则一直执行

while

(!isStop)

{

//先休息3秒钟

try

{

Thread.sleep(3000);

}

catch

(InterruptedException

e)

{

e.printStackTrace();

}

//以下代码发送到主线程中执行

runOnUiThread(new

Runnable()

{

@Override

public

void

run()

{

viewPager.setCurrentItem(viewPager.getCurrentItem()

+

1);

}

});

}

}

}).start();

}

private

void

init()

{

viewPager

=

(ViewPager)

findViewById(R.id.viewPager);

layoutPointGroup

=

(LinearLayout)

findViewById(R.id.show_point);

imageViewList

=

new

ArrayList<ImageView>();

//

TODO:获取图片ID

int[]

imageIDs

=

{R.drawable.a,

R.drawable.b,

R.drawable.c,

R.drawable.d,

R.drawable.e};

for

(int

id

:

imageIDs)

{

//

构造新的图片对象,并根据id

设置图片背景

imageView

=

new

ImageView(this);

imageView.setImageResource(id);

//

所有图片都存放在

imageViewList

里面

imageViewList.add(imageView);

//

构造小点

View

v

=

new

View(this);

//

设置小点的宽和高

LinearLayout.LayoutParams

params

=

new

LinearLayout.LayoutParams(8,

8);

//

设置小点的左边距

params.leftMargin

=

12;

v.setLayoutParams(params);

//

设置小点是否可用,默认都不可用,当不可用时,小点是透明的,否则是白色的

v.setEnabled(false);

//

设置小点的背景,这个背景是使用xml文件画的一个小圆点

v.setBackgroundResource(R.drawable.pointer_selector);

//

把小点添加到它的布局文件中

layoutPointGroup.addView(v);

}

//

计算应用打开时显示的第一项

Integer.MAX_VALUE

/2

-

3=0

int

index

=

Integer.MAX_VALUE

/

2

-

3;

//

给mViewPager设置数据

viewPager.setAdapter(new

MyPagerAdapter());

//

给mViewPager设置页面滑动事件

viewPager.setOnPageChangeListener(new

MyOnPageChangeListener());

//

设置应用打开时显示的第一项,index的值为0

//

使用这种方式得到的0,和直接写0有什么区别呢?

//

直接写0,应用打开后不能直接向右滑动,因为viewpager中存image位置不能为负值,只能先向左滑动

//

这种方式得到的0,可以实现应用一打开,就可以向右滑动

viewPager.setCurrentItem(index);

}

private

class

MyPagerAdapter

extends

PagerAdapter

{

@Override

public

int

getCount()

{

return

Integer.MAX_VALUE;

}

@Override

public

boolean

isViewFromObject(View

view,

Object

object)

{

return

view

==

object;

}

//

当一页滑出去的时候将它销毁

@Override

public

void

destroyItem(ViewGroup

container,

int

position,

Object

object)

{

container.removeView(imageViewList.get(position

%

imageViewList.size()));

}

//

向容器中添加图片,由于我们要实现循环滑动的效果,所以要对position取模

@Override

public

Object

instantiateItem(ViewGroup

container,

int

position)

{

container.addView(imageViewList.get(position

%

imageViewList.size()));

return

imageViewList.get(position

%

imageViewList.size());

}

}

private

class

MyOnPageChangeListener

implements

ViewPager.OnPageChangeListener

{

//

开始

@Override

public

void

onPageScrolled(int

position,

float

positionOffset,

int

positionOffsetPixels)

{

}

//

进行时

@Override

public

void

onPageSelected(int

position)

{

//

当页面滑动结束时,先对页面位置取模

position

=

position

%

imageViewList.size();

//

将上一个点的可用性设置为false

layoutPointGroup.getChildAt(previousPoint).setEnabled(false);

//

把当前点的可用性设置为true

layoutPointGroup.getChildAt(position).setEnabled(true);

//

把当前位置值赋值给previousPoint

previousPoint

=

position;

}

//

结束

@Override

public

void

onPageScrollStateChanged(int

state)

{

}

}

//

当activity销毁时,让线程停止

@Override

public

void

onDestroy()

{

isStop

=

true;

super.onDestroy();

}

}具体功能实现可以看代码里的注释,写的十分详细了。未选中的小圆点pointer_disable.xml:<?xml

version="1.0"

encoding="utf-8"?>

<shape

xmlns:android="/apk/res/android"

android:shape="oval"

>

<!--

设置圆角半径

-->

<corners

android:radius="0.5dip"

/>

<!--

设置填充的颜色

-->

<solid

android:color="#55000000"

/>

</shape>选中时的小圆点pointer_focus.xml:<?xml

version="1.0"

encoding="utf-8"?>

<shape

xmlns:android="/apk/res/android"

android:shape="oval"

>

<corners

android:radius="0.5dip"

/>

<solid

android:color="#aaFFFFFF"

/>

</shape>小圆点选择器:<?xml

version="1.0"

encoding="utf-8"?>

<selector

xmlns:android="/apk/res/android">

<!--

选中时,小点为白色

-->

<item

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论