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的滑动而动的,刚开始想了一下,感觉可以使用动画实现,但是这个滑动是随手指时时变化的,貌似不可行,后来再网上搜了 ...
随机推荐
- Tomcat 连接池详解
(转) JDBC 连接池 org.apache.tomcat.jdbc.pool 是Apache-Commons DBCP连接池的一种替换或备选方案. 那究竟为何需要一个新的连接池? 原因如下: Co ...
- 拥抱Node.js 8.0,N-API入门极简例子
本文摘录自<Nodejs学习笔记>,更多章节及更新,请访问 github主页地址.欢迎加群交流,群号 197339705. N-API简介 Node.js 8.0 在2017年6月份发布, ...
- (计蒜客)UCloud 的安全秘钥
UCloud 的安全秘钥 题意 给出一个数组 s 串,和数组 t 串,那么如果两者长度相同且两者所含的数字全部相同,则说这两个串相似. 给定原始串 S ,以及 m 个询问 T 串,问 S 串有多少个连 ...
- [python标准库]XML模块
1.什么是XML XML是可扩展标记语言(Extensible Markup Language)的缩写,其中的 标记(markup)是关键部分.您可以创建内容,然后使用限定标记标记它,从而使每个单词. ...
- Android 图片加载框架Glide4.0源码完全解析(一)
写在之前 上一篇博文写的是Picasso基本使用和源码完全解析,Picasso的源码阅读起来还是很顺畅的,然后就想到Glide框架,网上大家也都推荐使用这个框架用来加载图片,正好我目前的写作目标也是分 ...
- python socketserver监听多端口多进程
多进程监听多端口 # 多线程socket # 程序监听两个端口,端口逻辑相同其中一个端口放在子进程下 # 每次请求会在产生一个进程处理请求 import SocketServer from multi ...
- 添加OpenStack Mitaka源
sudo apt-get install ubuntu-cloud-keyring sudo add-apt-repository cloud-archive:mitaka 同理,可以添加其它版本,如 ...
- mysql 发生系统错误 1067
最近要搞一个免安装版的mysql,原来的配置在d盘的my.ini如下 [client]port=3306default-character-set=utf8 [mysqld]port=3306char ...
- android的drawable资源
1.android中可以通过xml文件配置资源,比如字符串啦,整数拉.浮点数等等,当然也可以配置图片资源和选择器,下面我们就看看几种图片资源的配置. @1矩形方框,带渐变色的配置代码 <?xml ...
- markdown基础
介绍: markdown是一种可以使用普通文本编译器编写的标记语言,通过简单的标记语法,它可以使普通文本具有一定的格式.说的简单一点,markdown其实就是一种简单的文本,与普通的文本文件(txt文 ...