Android之圆点导航的两个案例(ViewPager)
案例一效果:

布局文件:
<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)的更多相关文章
- Android应用底部导航栏(选项卡)实例
现在很多android的应用都采用底部导航栏的功能,这样可以使得用户在使用过程中随意切换不同的页面,现在我采用TabHost组件来自定义一个底部的导航栏的功能. 我们先看下该demo实例的框架图: 其 ...
- android MIPI屏 导航栏丢失
/**************************************************************************** * android MIPI屏 导航栏丢失 ...
- Android 修改底部导航栏navigationbar的颜色
Android 修改底部导航栏navigationbar的颜色 getWindow().setNavigationBarColor(Color.BLUE); //写法一 getWindow().set ...
- Android两种为ViewPager+Fragment添加Tab的方式
在Android开发中ViewPager的使用是非常广泛的,而它不仅仅能够实现简单的开始引导页,还可以结合Fragment并添加Tab作为选项卡或为显示大批量页面实现强大的顺畅滑动 下面介绍两种为Vi ...
- Android Project和app中两个build.gradle配置的区别
Android 开发也挺长时间了,从开始就使用的AndroidStudio开发,但是说下来其实自己对AS(AndroidStudio简称)还真的是不了解不深入.好吧,其实我只知道AS是一个相当强大的工 ...
- Android 博客导航
Android 博客导航 一. 基础知识 Android 常用知识点 Android 常见问题解决 Android 常用控件 控件常用属性 Material Design 常用控件 二.常用知识点 动 ...
- Android Studio的project中两个build.gradle配置的区别
一般创建一个android项目后回出现两个gradle: build.gradle(Project):用来配置整个工程的 build.gradle(app):一个是用来配置app的 对compile和 ...
- Android Studio 代码导航快捷键总结
Android Studio 代码导航快捷键总结 这篇文章主要介绍了Android Studio 代码导航快捷键的相关资料,需要的朋友可以参考下 简评:作为一位 Android 开发者,Andro ...
- Android自定义组件系列【10】——随ViewPager滑动的导航条
昨天在用到ViewPager实现滑动导航的时候发现微信的导航条效果是跟随ViewPager的滑动而动的,刚开始想了一下,感觉可以使用动画实现,但是这个滑动是随手指时时变化的,貌似不可行,后来再网上搜了 ...
随机推荐
- 图解Git命令
上面的四条命令在工作目录.暂存目录(也叫做索引)和仓库之间复制文件. ·git add files把当前文件放入暂存区域. ·git commit 给暂存区域生成快照并提交. ·git reset - ...
- 一天搞定CSS: 标签样式初始化(CSS reset)及淘宝样式初始化代码--09
样式初始化:是指对HTML中某些标签的默认样式进行清除 样式初始化目的: 不同浏览器的默认样式不一样,若不清理,会导致相同的代码在浏览器中解析结果不一样,为了避免这种情况,所以需要进行样式初始化. 代 ...
- JavaScript 扫描枪使用(一)
JavaScript 扫描枪应用(一)com.js为主要的代码实现,test.html文件为测试的页面,其中包括了com.js文件中方法的调用.以下为测试成功代码:com.js //com.js /* ...
- Javascript事件模型(三):JavaScript事件绑定方法总结(及Jquery)
JavaScript中绑定事件的方法主要有三种: 1 在DOM元素中直接绑定 2 JavaScript代码中直接绑定 3 绑定事件监听函数 JQuery中绑定事件的几种方法 主要有on().bind( ...
- SVN·最新使用教程总结
SVN简介: 为什么要使用SVN? 程序员在编写程序的过程中,每个程序员都会生成很多不同的版本,这就需要程序员有效的管理代码,在需要的时候可以迅速,准确取出相应的版本. Subversion是什么? ...
- oracle中的function的简单语法定义
1. create or replace 函数名 (参数名 in 类型) return 返回值类型 as 定义变量 begin 函数体 end;
- Chapter 9:Noise-Estimation Algorithms
作者:桂. 时间:2017-06-14 12:08:57 链接:http://www.cnblogs.com/xingshansi/p/6956556.html 主要是<Speech enha ...
- android下的名词/片段解释
关于建项目时候SDK解释 minimum required SDK: 又为miniSdk, 是你程序最低支持的SDK版本,这个现在一般miniSDK设定一般为8或者10 Target SDK:是你程序 ...
- Wowza 部署 安装 配置 测试 直播
下载,最好用快的IP下好后传到需要的节点上,下面链接不能下载的情况下百度谷歌必应找资源,jdk旧版在oracle需登录方可下载 JDK1.6 wget -c http://dl.download.cs ...
- 写代码中遇到的问题(php接收不到传过来的json数据,php使用utf8的用法)
今天写代码用python处理完数据,传给php服务器后,发现接收不到数据,因为是跨域,所以加了消息头:header('Access-Control-Allow-Origin:*');但是并没有什么卵用 ...