动态ViewPager导航页面
今天新学知识总计,个人信息,仅供参考:
item设置:
viewpager页面设置:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v4.view.ViewPager
android:id="@+id/viewpager1220"
android:layout_width="match_parent"
android:layout_height="200dp">
</android.support.v4.view.ViewPager>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:layout_alignBottom="@id/viewpager1220"
android:padding="10dp"
>
<LinearLayout
android:id="@+id/point1220"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:gravity="center"
android:orientation="horizontal">
</LinearLayout>
</LinearLayout>
</RelativeLayout>
adapter设置
package com.example.administrator.test_1216.adapter;
public class PagerAdapter1220 extends PagerAdapter {
private List<ImageModel1220> list;
private Context context;
public PagerAdapter1220(List<ImageModel1220> list, Context context) {
this.list = list;
this.context = context;
}
@Override
public int getCount() {
return Integer.MAX_VALUE;
}
/**
* 判断是否由对象生成页面
* @param view
* @param object
* @return
*/
@Override
public boolean isViewFromObject(View view, Object object) {
return view==object;
}
/**
* 添加页面
* @param container 将要显示的页面
* @param position 将要显示页面的位置
* @return
*/
@Override
public Object instantiateItem(ViewGroup container, int position) {
//添加子布局
View view=View.inflate(context, R.layout.img1220_item,null);
//声明控件并绑定id
ImageView img1220= (ImageView) view.findViewById(R.id.img1220);
//获取图片
img1220.setBackgroundResource(list.get(position%list.size()).getImages());
//将子布局添加到视图
container.addView(view);
return view;
}
/**
* 销毁页面
* @param container 将要销毁的页面
* @param position 将要销毁的页面的位置
* @param object
*/
@Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView((View) object);
}
}
activity设置:
package com.example.administrator.test_1216;
/**
* Created by Administrator on 2016/12/20.
*/
public class PagerActivity1220 extends Activity implements ViewPager.OnPageChangeListener {
private ViewPager viewPager;
private LinearLayout point;
private PagerAdapter adapter;
private List<ImageModel1220> list;
//图片数组
private int[] imgs = {R.mipmap.main_page1, R.mipmap.main_page2, R.mipmap.main_page3, R.mipmap.main_page4, R.mipmap.main_page5};
//handdle机制处理定时任务
Handler handler=new Handler(){
@Override
public void handleMessage(Message msg) {
viewPager.setCurrentItem(viewPager.getCurrentItem()+1);
handler.sendEmptyMessageDelayed(0,3000); //设置时间间隔
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.viewpager1220_activity);
viewPager = (ViewPager) findViewById(R.id.viewpager1220);
point = (LinearLayout) findViewById(R.id.point1220);
//设置图片滑动监听
viewPager.setOnPageChangeListener(this);
//初始化集合
list = new ArrayList<ImageModel1220>();
//遍历图片数组
for (int i = 0; i < imgs.length; i++) {
ImageModel1220 model = new ImageModel1220();
model.setImages(imgs[i]);
list.add(model);
}
//初始化小圆点
for (int i = 0; i < list.size(); i++) {
//新建视图
View v = new View(this);
//新建一个布局参数,设置小圆点宽,高
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(10, 10);
//设置小圆点的间距
if (i != 0) {
params.leftMargin = 10;
}
//设置小圆点视图
v.setLayoutParams(params);
//给小圆点设置背景颜色
v.setBackgroundResource(R.drawable.points);
//将设置好的小圆点添加到布局文件里
point.addView(v);
}
//初始化适配器
adapter = new PagerAdapter1220(list, this);
//设置适配器
viewPager.setAdapter(adapter);
//设置当前的图片位置
//将有用的View放到所有view中间,并将有用的View的第一个视图放到第一个位置
viewPager.setCurrentItem(Integer.MAX_VALUE/2-(Integer.MAX_VALUE/2)%list.size());
changePoint();//动态改变小圆点
//设置自动时间为3秒
handler.sendEmptyMessageDelayed(0,3000);
}
//动态改变小圆点
private void changePoint() {
//获取当前页面的位置
int currentPager = viewPager.getCurrentItem() % list.size();
//遍历小圆点
for (int i = 0; i < point.getChildCount(); i++) {
//设置Enabled,获取小圆点的焦点,当i==currentPager,小圆点是白色
point.getChildAt(i).setEnabled(i == currentPager);
}
}
/**
* 页面滑动结束调用
*
* @param position 选中页面的位置
*/
@Override
public void onPageSelected(int position) {
changePoint();
}
/**
* 此方法在页面滑动的时候调用
*
* @param position:当前页面的位置
* @param positionOffset:页面偏移的百分比
* @param positionOffsetPixels:页面偏移的像素
*/
@Override
public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {
}
/**
* 此方法在页面状态改变的时候调用
*
* @param state:state==0:什么也没做 state==1:正在滑动
* state==2:滑动结束
*/
@Override
public void onPageScrollStateChanged(int state) {
}
}
效果图:
动态ViewPager导航页面的更多相关文章
- 爬虫再探实战(三)———爬取动态加载页面——selenium
自学python爬虫也快半年了,在目前看来,我面临着三个待解决的爬虫技术方面的问题:动态加载,多线程并发抓取,模拟登陆.目前正在不断学习相关知识.下面简单写一下用selenium处理动态加载页面相关的 ...
- 7、网页制作Dreamweaver(悬浮动态分层导航)
悬浮动态分层导航的制作: 1.首先在<head>里面引用一个JQUERY的文件以用来制作鼠标点击动画效果(从网站上下载即可) <script language="javas ...
- jQuery ui背景色动态渐变导航菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- ios 导航页面
// AppDelegate.m#import "AppDelegate.h"#import "ViewController.h" @interface Ap ...
- Javascript动态生成的页面信息爬取和openpyxl包FAQ小记
最近,笔者在使用Requests模拟浏览器发送Post请求时,发现程序返回的html与浏览器F12观察到的略有不同,经过观察返回的response.text,cookies确认有效,因为我们可以看到返 ...
- EntityFramework4.5使用Expression类创建动态查询及动态查询导航属性
创建动态查询 想在项目中实现一个灵活的动态查询类,参考http://www.cnblogs.com/lyj/archive/2008/03/25/1122157.html和http://www.cnb ...
- Android开发之利用ViewPager实现页面的切换(仿微信、QQ)
这里利用ViewPager实现页面的滑动,下面直接上代码: 1.首先写一个Activity,然后将要滑动的Fragment镶嵌到写好的Activity中. Activity的布局文件:activity ...
- Python+Selenium爬取动态加载页面(2)
注: 上一篇<Python+Selenium爬取动态加载页面(1)>讲了基本地如何获取动态页面的数据,这里再讲一个稍微复杂一点的数据获取全国水雨情网.数据的获取过程跟人手动获取过程类似,所 ...
- Python+Selenium爬取动态加载页面(1)
注: 最近有一小任务,需要收集水质和水雨信息,找了两个网站:国家地表水水质自动监测实时数据发布系统和全国水雨情网.由于这两个网站的数据都是动态加载出来的,所以我用了Selenium来完成我的数据获取. ...
随机推荐
- my Js
1. __doPostBack是.net自动生成的(当页面中有LinkButton.DropDownList(AutoPostBack)等时:Button和ImageButton不会生成它,也不会调用 ...
- 什么是JavaEE
Java技术不仅是一门编程语言而且是一个平台.同时Java语言是一门有着特定语法和风格的高级的面向对象的语言,Java平台是Java语言编写的特定应用程序运行的环境.Java平台有很多种,很多的Jav ...
- h4和h5的区别
h4和h5的区别 相关文章 微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻[▄ (页底留言开放,欢迎来吐槽) ●●● 1.HTML5为什么只需要写<!DOCTYPEHTML&g ...
- 《统计推断(Statistical Inference)》读书笔记——第1章 概率论
第一章介绍了基本的概率论知识,以下是这一章的思维导图
- Updatepanel 注册javascript 方法
ScriptManager.RegisterStartupScript(this.UpdatePanel1, this.GetType(), "test", "alert ...
- go_databasetest
go_databasetest go语言的数据库测试: go get github.com/Go-SQL-Driver/MySQL package main import ( _"githu ...
- [转]win7下apache2.4响应很慢解决方法
win7下apache2.4响应很慢解决方法 PS.按照以下方法测试了以下,似乎确实快了一点[skysowe] 转载自: http://blog.sina.com.cn/s/blog_75ad1010 ...
- json_encode和json_decode
<?php $json = '{"a":1,"b":2,"c":3,"d":4,"e":5}' ...
- angularjs jquery thinkPHP3.2.3 相结合小实例
angular1.5 与 jquery想结合一个小应用 index.html <html> <head> <meta charset="utf-8"& ...
- 相机标定:关于用Levenberg-Marquardt算法在相机标定中应用
LM算法在相机标定的应用共有三处. (1)单目标定或双目标定中,在内参固定的情况下,计算最佳外参.OpenCV中对应的函数为findExtrinsicCameraParams2. (2)单目标定中,在 ...