四.自定义View之ViewPager指示器

最近一个项目中有这样一个需求,就是一个ViewPager,下面带有几个指示器的小圆点,这样的需求很容易实现,网上也有很多的开源框架都可以满足这个需求,但是最近已经不太想用开源框架了,比较简单的功能都自己写代码实现。今天就来记录一下ViewPager指示器的实现。

效果图:


就是这样一个需求,布局分析如下:


三个小圆点是根据填充ViewPager集合的size动态添加到线性布局中的。

小圆点使用ImageView画出来,背景使用shape文件来定义

未选中时的白色:


选中时的黄色:


定义好了小圆点,需要给小圆点设置宽高,Margin等参数,此时就需要设置小圆点的布局参数。从第二个小圆点开始设置左侧Margin值

for(int i =0;i<data.size();i++){

ImageView imageView = new ImageView(mActivity);

imageView.setBackgroundResource(R.drawable.home_point_white);

//布局参数,父控件是什么布局就创建什么布局的布局参数

LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(

LinearLayout.LayoutParams.WRAP_CONTENT, LinearLayout.LayoutParams.WRAP_CONTENT);

if(i>0){

params.leftMargin = 20;//从第二个小圆点开始设置左侧边距

}

imageView.setLayoutParams(params);

ll_home_point.addView(imageView);}

小黄点是跟着ViewPager走的,给ViewPager添加一个页面切换的监听setOnPageChangeListener,其中方法onPageScrolled是在ViewPager滑动过程中调用的,其中的参数positionOffset是指滑动的百分比。

那么我们计算滑动距离是,用两个圆点之间的间距*滑动百分比,就可以时时得到滑动的距离。那么两个圆点之间的间距怎么求呢


如上图所示,两个圆点之间的距离就是两个圆点左侧的距离,用第二个圆点getLeft - 第一个圆点getLeft就可以得到。

但这样写是无法获取到两者间距的,如果在Activity中,控件的绘制是在onCreate()方法之后,那么此时控件还未绘制,当然拿不到getLeft的值,我们需要对ImageView设置一个监听,onLayout方法执行完成之后再获取点之间的间距。

代码如下:

//计算两个圆点之间的距离

iv_home_point_yellow.getViewTreeObserver().addOnGlobalLayoutListener(

new ViewTreeObserver.OnGlobalLayoutListener() {

@RequiresApi(api = Build.VERSION_CODES.JELLY_BEAN)

@Override

public void onGlobalLayout() {

iv_home_point_yellow.getViewTreeObserver().removeOnGlobalLayoutListener(this);

//ll_home_point.getChildAt(1),获取线性布局中的第二个小圆点

//ll_home_point.getChildAt(0),获取线性布局中的第一个小圆点

int pointDis = ll_home_point.getChildAt(1).getLeft() - ll_home_point.getChildAt(0).getLeft();

Log.i("圆点间距", "showButtomDialog: "+pointDis);

}});

得到了两个点之间的间距,得到了滑动百分比,那么现在就得到了小黄点随ViewPager滑动的时时距离。

那么现在就开始修改小黄点的布局参数,更新其左侧边距即可。但是这里要注意的是,当滑动到新的页面是,滑动距离百分比会变为0,因此需要加上一段距离,这段距离可以用position*pointsDis,两个圆点之间的距离*页面位置position。第一个页面的position为0

代码如下:

home_bottom_vp.setOnPageChangeListener(new ViewPager.OnPageChangeListener() {

@Override

public void onPageScrolled(int position, float positionOffset, int positionOffsetPixels) {

//更新小黄点的移动的距离

float leftMargin = positionOffset * pointDis + position * pointDis;

Log.i("小黄点移动的距离", "onPageScrolled: "+leftMargin +"-------"+positionOffset);

RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams)iv_home_point_yellow.getLayoutParams(); layoutParams.leftMargin =(int) leftMargin;

iv_home_point_yellow.setLayoutParams(layoutParams);

}

@Override

public void onPageSelected(int position) { }

@Override

public void onPageScrollStateChanged(int state) { }});

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,189评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,577评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,857评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,703评论 1 276
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,705评论 5 366
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,620评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,995评论 3 396
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,656评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,898评论 1 298
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,639评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,720评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,395评论 4 319
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,982评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,953评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,195评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 44,907评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,472评论 2 342