案例一效果:

布局文件:

<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_view_pager"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.jogger.demo.ViewPagerActivity"> <android.support.v4.view.ViewPager
android:id="@+id/vp_guide"
android:layout_width="match_parent"
android:layout_height="match_parent"></android.support.v4.view.ViewPager> <LinearLayout
android:id="@+id/ll_container"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_marginBottom="40dp"
android:gravity="center"
android:orientation="horizontal"></LinearLayout> </RelativeLayout> Activity:
public class ViewPagerActivity extends FragmentActivity {

    private ViewPager vp_guide;
private List<ImageView> mImgList;//导航图集合
private LinearLayout ll_container;//小圆点容器
private int mCurrentIndex = 0;//当前小圆点的位置
private int[] imgArray = {R.drawable.guidance1, R.drawable.guidance2, R.drawable.guidance3, R
.drawable.guidance4}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_view_pager);
vp_guide = (ViewPager) findViewById(R.id.vp_guide);
ll_container = (LinearLayout) findViewById(R.id.ll_container);
mImgList = new ArrayList<>();
for (int i = 0; i < imgArray.length; i++) {
ImageView imageView = new ImageView(this);//获取4个圆点
imageView.setImageResource(imgArray[i]);
mImgList.add(imageView);
ImageView dot = new ImageView(this);
if (i == mCurrentIndex) {
dot.setImageResource(R.drawable.page_now);//设置当前页的圆点
} else {
dot.setImageResource(R.drawable.page);//其余页的圆点
}
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout
.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
if (i > 0) {
params.leftMargin = 10;//设置圆点边距
}
dot.setLayoutParams(params);
ll_container.addView(dot);//将圆点添加到容器中
}
vp_guide.setAdapter(new MyAdapter(mImgList));
//添加监听
vp_guide.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int
positionOffsetPixels) { } @Override
public void onPageSelected(int position) {
//根据监听的页面改变当前页对应的小圆点
mCurrentIndex = position;
for (int i = 0; i < ll_container.getChildCount(); i++) {
ImageView imageView = (ImageView) ll_container.getChildAt(i);
if (i == position) {
imageView.setImageResource(R.drawable.page_now);
} else {
imageView.setImageResource(R.drawable.page);
}
}
} @Override
public void onPageScrollStateChanged(int state) { }
});
} public class MyAdapter extends PagerAdapter {
private List<ImageView> mViewList; public MyAdapter(List<ImageView> viewList) {
mViewList = viewList;
} @Override
public ImageView instantiateItem(ViewGroup container, int position) {
ImageView view = mViewList.get(position);
container.addView(view);
return view;
} @Override
public int getCount() {
return mViewList.size();
} @Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(mViewList.get(position));
}
}
} 案例二效果:

布局文件:
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/activity_view_pager"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="com.jogger.demo.ViewPagerActivity"> <android.support.v4.view.ViewPager
android:id="@+id/vp_guide"
android:layout_width="match_parent"
android:layout_height="match_parent"></android.support.v4.view.ViewPager> <RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_centerHorizontal="true"
android:layout_marginBottom="40dp"> <LinearLayout
android:id="@+id/ll_container"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal">
</LinearLayout> <ImageView
android:id="@+id/iv_dot_now"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/page_now"/>
</RelativeLayout> </RelativeLayout> Activity:
public class ViewPagerActivity extends FragmentActivity {

    private ViewPager vp_guide;
private List<ImageView> mImgList;//导航图集合
private LinearLayout ll_container;//小圆点容器
private int mCurrentIndex = 0;//当前小圆点的位置
private int mDotDis;//小圆点的距离
private ImageView iv_dot_now;//当前圆点
private int[] imgArray = {R.drawable.guidance1, R.drawable.guidance2, R.drawable.guidance3, R
.drawable.guidance4}; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_view_pager);
vp_guide = (ViewPager) findViewById(R.id.vp_guide);
ll_container = (LinearLayout) findViewById(R.id.ll_container);
iv_dot_now = (ImageView) findViewById(R.id.iv_dot_now);
mImgList = new ArrayList<>();
for (int i = 0; i < imgArray.length; i++) {
ImageView imageView = new ImageView(this);//获取4个圆点
imageView.setImageResource(imgArray[i]);
mImgList.add(imageView);
ImageView dot = new ImageView(this);
dot.setImageResource(R.drawable.page);
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(LinearLayout
.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);
if (i > 0) {
params.leftMargin = 10;//设置圆点边距
}
dot.setLayoutParams(params);
ll_container.addView(dot);//将圆点添加到容器中
}
vp_guide.setAdapter(new MyAdapter(mImgList));
//添加监听
vp_guide.addOnPageChangeListener(new ViewPager.OnPageChangeListener() {
@Override
public void onPageScrolled(int position, float positionOffset, int
positionOffsetPixels) {
// 滚动过程中
// 红色小圆点的移动距离=移动百分比*两个圆点的间距
// 更新小红点距离
int dis = (int) (mDotDis * positionOffset) + position * mDotDis;//
// 因为移动完一个界面后,百分比会归0,所以要加上移动过的单位position*mPointDis
//获取小圆点的布局属性,更新左边距
RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) iv_dot_now
.getLayoutParams();
params.leftMargin = dis;// 修改左边距
// 重新设置布局参数
iv_dot_now.setLayoutParams(params);
} @Override
public void onPageSelected(int position) { } @Override
public void onPageScrollStateChanged(int state) { }
});
// 监听layout方法结束的事件,位置确定之后获取圆点间距
// 视图树
iv_dot_now.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver
.OnGlobalLayoutListener() { @Override
public void onGlobalLayout() {
//视图树移除监听
iv_dot_now.getViewTreeObserver().removeOnGlobalLayoutListener(this);
//计算得到小圆点距离
mDotDis = ll_container.getChildAt(1).getLeft() - ll_container.getChildAt(0)
.getLeft();
}
});
} public class MyAdapter extends PagerAdapter {
private List<ImageView> mViewList; public MyAdapter(List<ImageView> viewList) {
mViewList = viewList;
} @Override
public ImageView instantiateItem(ViewGroup container, int position) {
ImageView view = mViewList.get(position);
container.addView(view);
return view;
} @Override
public int getCount() {
return mViewList.size();
} @Override
public boolean isViewFromObject(View view, Object object) {
return view == object;
} @Override
public void destroyItem(ViewGroup container, int position, Object object) {
container.removeView(mViewList.get(position));
}
}
}

Android之圆点导航的两个案例(ViewPager)的更多相关文章

  1. Android应用底部导航栏(选项卡)实例

    现在很多android的应用都采用底部导航栏的功能,这样可以使得用户在使用过程中随意切换不同的页面,现在我采用TabHost组件来自定义一个底部的导航栏的功能. 我们先看下该demo实例的框架图: 其 ...

  2. android MIPI屏 导航栏丢失

    /**************************************************************************** * android MIPI屏 导航栏丢失 ...

  3. Android 修改底部导航栏navigationbar的颜色

    Android 修改底部导航栏navigationbar的颜色 getWindow().setNavigationBarColor(Color.BLUE); //写法一 getWindow().set ...

  4. Android两种为ViewPager+Fragment添加Tab的方式

    在Android开发中ViewPager的使用是非常广泛的,而它不仅仅能够实现简单的开始引导页,还可以结合Fragment并添加Tab作为选项卡或为显示大批量页面实现强大的顺畅滑动 下面介绍两种为Vi ...

  5. Android Project和app中两个build.gradle配置的区别

    Android 开发也挺长时间了,从开始就使用的AndroidStudio开发,但是说下来其实自己对AS(AndroidStudio简称)还真的是不了解不深入.好吧,其实我只知道AS是一个相当强大的工 ...

  6. Android 博客导航

    Android 博客导航 一. 基础知识 Android 常用知识点 Android 常见问题解决 Android 常用控件 控件常用属性 Material Design 常用控件 二.常用知识点 动 ...

  7. Android Studio的project中两个build.gradle配置的区别

    一般创建一个android项目后回出现两个gradle: build.gradle(Project):用来配置整个工程的 build.gradle(app):一个是用来配置app的 对compile和 ...

  8. Android Studio 代码导航快捷键总结

    Android Studio 代码导航快捷键总结 这篇文章主要介绍了Android Studio 代码导航快捷键的相关资料,需要的朋友可以参考下   简评:作为一位 Android 开发者,Andro ...

  9. Android自定义组件系列【10】——随ViewPager滑动的导航条

    昨天在用到ViewPager实现滑动导航的时候发现微信的导航条效果是跟随ViewPager的滑动而动的,刚开始想了一下,感觉可以使用动画实现,但是这个滑动是随手指时时变化的,貌似不可行,后来再网上搜了 ...

随机推荐

  1. 将Java Web项目部署到远程主机上

    这里讲的是Java Web项目 第一步:购买主机,如果是大学生可以购买学生机,一个月9.9元,阿里云ECS服务器,自己选择不同的操作系统和镜像 ,我的选择 得到用户名和密码,可以进行ssh远程登录,登 ...

  2. vuex所有核心概念完整解析State Getters Mutations Actions

    vuex是解决vue组件和组件件相互通信而存在的,vue理解起来稍微复杂但一旦看懂择即为好用 安装: npm install --save vuex 引入 import Vuex from 'vuex ...

  3. 一个想法照进现实-《IT连》创业项目:直觉型面试招聘的漏洞

    前言: 创业转眼又过去了一个月,是时候抽时间写写文向大伙继续汇报进度了. 还记得上一篇创业文章,我还在说:创业时该不该用新手程序员. 嗯,然后,然后,报应就来了:所以这篇要写写自己在新人招聘上出现的问 ...

  4. JavaSE教程-03Java中分支语句与四种进制转换

    一.分支语句 计算机源于生活,程序模拟现实生活,从而服务生活 行为模式 1,起床,刷牙,洗脸,吃早餐,上课,回家,睡觉(顺序性) 2,如果时间不太够,打个滴滴快车,如果时间够,坐个地铁(选择性) 3, ...

  5. 《物联网框架ServerSuperIO教程》-20.网络通讯控制器分组,提高交互的负载平衡能力。v3.6.6 版本发布

    20.1     概述 ServerSuperIO原来在网络通讯模式下,只有一个网络控制器,在自控模式.并发模式和单例模式下时都是异步处理返回的数据,并不会出现性能问题.但是在轮询模式下,一个网络控制 ...

  6. SQL Server 在Alwayson上使用内存表"踩坑"

    200 ? "200px" : this.width)!important;} --> 介绍 因为线上alwayson环境的一个数据库上使用内存表.经过大概一个星期监控程序发 ...

  7. 在Visual Studio for Mac中使用fastlane管理iOS的provision

    Xamarin开发中,最烦的就是provision的管理了. 全手工的话,要先创建一个key,上传后生成cert文件,再创建provision.如果在手机上调试,还要把手机加到provision中去. ...

  8. [Leetcode] Binary search--436. Find Right Interval

      Given a set of intervals, for each of the interval i, check if there exists an interval j whose st ...

  9. Mac OS中使用VScode配置C语言开发环境

    个人博客 chinazt.cc 闲话少叙,直奔主题 下载VSCode https://code.visualstudio.com/download 安装C/C++插件 需要两个插件: 1. cppto ...

  10. 美丽的CSS图形和HTML5

    1.HTML5基础 文档类型 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "htt ...