pageControl页码实时更新的实现

iOS开发过程中会经常遇到scrollView与pageControl混合使用的情况。scrollView与pageControl的配合逻辑代码一般是写在以下代理函数中的:

-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView

即在scrollView滚动结束时pageControl才会更新代码,这样可以防止pageControl页码的逻辑混乱。但这同样会出现一个问题,那就是在用户快速滑动scrollView的时候,pageControl的页码无法更新,在用户看来就是scrollVIew在滑动,而页码无变化。其实解决的方法很简单,原理就是将pageControl的页码更新放到以下代理函数中即可:

- (void)scrollViewDidScroll:(UIScrollView *)scrollView

这个函数会在scrollView滑动过程中不断被调用,将pageControl的页码更新操作放在这个函数里执行即可获得页码实时更新的效果。代码如下:

//scrollView滑动结束时调用
-(void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{
    if(_imageScrollView.contentOffset.x >= (totalPage-1.5)*_imageScrollView.width){
        [_imageScrollView setContentOffset:CGPointMake(_imageScrollView.width, 0) animated:NO];
    }else if(_imageScrollView.contentOffset.x<0.5*_imageScrollView.width){
        [_imageScrollView setContentOffset:CGPointMake((totalPage-2)*_imageScrollView.width, 0) animated:NO];
    }
    NSInteger currentPage = roundf((_imageScrollView.contentOffset.x-_imageScrollView.width) / [self getWidth]);
    _pageControl.currentPage = currentPage;
}

//scrollView滑动过程中多次调用
- (void)scrollViewDidScroll:(UIScrollView *)scrollView{
    NSInteger currentPage;
    if(_imageScrollView.contentOffset.x >= (totalPage-1.5)*_imageScrollView.width) {
        currentPage = roundf((_imageScrollView.contentOffset.x-_imageScrollView.width) / [self getWidth]) - (totalPage-2);
    }else if(_imageScrollView.contentOffset.x<0.5*_imageScrollView.width){
        // 设置当前页
        currentPage = roundf((_imageScrollView.contentOffset.x-_imageScrollView.width) / [self getWidth]) + (totalPage-2);
    }else{
        currentPage = roundf((_imageScrollView.contentOffset.x -_imageScrollView.width) / [self getWidth]);
    }
    _pageControl.currentPage = currentPage;
}

需要说明的几点:

1、这个scrollView是根据需求“banner需要能够循环滑动”而设置的,原理如下:

(1)有三个主要的数据view,分别为view1,view2,view3,这三个是真正要显示的数据view。为了实现“循环效果”,另外定义了两个辅助view(view1_fz和view3_fz),在scrollView中的排列顺序如下图所示:

(2)在右滑至View1_fz的位置时,通过setContentOffset将_imageScrollView移到View1的位置,并关闭动画效果。在左滑至View3_fz的位置时,通过setContentOffset将_imageScrollView移到View3的位置,并关闭动画效果。

这样就实现了循环的效果。

2、这里的totalPage指的是所有的view个数,包括辅助的view,即totalPage=5。

3、通过contentOffset的值计算当前页码currentPage。

4、这里的“翻页”是以view的一半宽度为标准的,即scrollView翻页超过了下一页的一半时currentPage显示为下一页。

5、为了实现pageControl的实时更新效果,在scrollViewDidScroll中对currentPage实时进行计算。

6、为了防止页码的错误,在scrollViewDidEndDecelerating函数中依然保留一次对currentPage的最终计算。

时间: 2024-10-26 20:10:22

pageControl页码实时更新的实现的相关文章

【性能优化】懒、懒加载、懒动画 --- 基于window滚动事件来实时更新DOM的视图状态,以表明是否在规定的可视区,并作有change回调

/* * * 扩展jq原型: 懒.懒加载.懒动画 * --- 基于window滚动事件来实时更新DOM的视图状态,以表明是否在规定的可视区,并作有change回调 * * $jq.viewChange( {top:100,bottom:100,change:function(status){}} ) --- status: 'in'/'out' * $jq.viewChange('off') * * $jq[n].viewChange.status = 'in'/'out' ----- 状态为'

C语言实现文件实时更新

一.简介 在linux或者unix操作系统中在系统引导的时候会开启很多服务,这些服务就叫做守护进程. 守护进程脱离了终端并且在后台运行:守护进程脱离于终端是为了避免进程在执行过程中的信息在任何终端上显示并且进程也不会被任何终端所产生的终端信息所打断. 本文介绍使用守护进程实现文件实时更新的方法步骤. 二.源码 文件1:Realtime_Update.c #include <stdio.h> #include <stdlib.h> #include <unistd.h>

关于unity3D异步加载进度条实时更新的方法

在其他地方看到所谓的实时更新就是 让slider的当前value等于异步对象的进度值而已,太坑了,这个正常来理解的意思不就是从0开始递增到100嘛,不管怎么我已经完成这个功能了,代码贴上,以免日后忘记, 找到这篇博客的朋友算你好运,直接搬走吧(NGUI版)~ 需要重点提醒的:异步对象AsyncOperation的值到90%后不会再增长,剩下的10%要让AsyncOperation.allowSceneActivation(意思是场景加载完毕后自动跳转场景)为true时才会自动完成~ 完整代码下方

基于server broker 的数据实时更新

Service Broker介绍:SQL Server Service Broker 为消息和队列应用程序提供 SQL Server 数据库引擎本机支持.这使开发人员可以轻松地创建使用数据库引擎组件在完全不同的数据库之间进行通信的复杂应用程序.开发人员可以使用 Service Broker 轻松生成可靠的分布式应用程序.使用 Service Broker 的应用程序开发人员无需编写复杂的内部通信和消息,即可跨多个数据库分发数据工作负荷.因为 Service Broker 会处理会话上下文中的通信

8086汇编学习小结———实时更新

初学IBM-PC 8086,对INT指令不是很理解.现从网上总计如下: 表:DOS系统功能调INT 21H AH 功能 调用参数 返回参数 00 程序终止(同INT 20H) CS=程序段前缀 01 键盘输入并回显 AL=输入字符 02 显示输出 DL=输出字符 03 异步通迅输入 AL=输入数据 04 异步通迅输出 DL=输出数据 05 打印机输出 DL=输出字符 06 直接控制台I/O DL=FF(输入)DL=字符(输出) AL=输入字符 07 键盘输入(无回显) AL=输入字符 08 键盘

使用php+swoole对client数据实时更新(二) (转)

上一篇提到了swoole的基本使用,现在通过几行基本的语句来实现比较复杂的逻辑操作: 先说一下业务场景.我们目前的大多数应用都是以服务端+接口+客户端的方式去协调工作的,这样的好处在于不论是处在何种终端的情况下,都可以完美的和服务端兼容.这样就轻松实现了MVC各个部分的真正解耦.但是提高程序的友好性还是有很多路要走,其中一个大家都会遇到的就是数据实时更新的问题.比如一个用户在手机上做了添加操作,这时候其他的终端也应该及时显示数据的变化情况.这个对于手机来说还算好办,因为现在的各种推送服务完全可以

Qt之模型/视图(实时更新数据)

上两节简单介绍了Qt中对于模型/视图的编程,大部分助手里说的很清楚了,现在就开始实战部分吧! 在实际应用中,视图展示的数据往往并非一成不变的,那么如何实时更新成了一个很重要的问题!功能:(1)添加委托(进度条)(2)显示文件名称.大小.进度.速度.剩余时间.状态等.(3)可进行添加.更新.删除.清空等操作.(4)实时更新数据先看一个效果图:委托(进度条):ProgressBarDelegate::ProgressBarDelegate(QObject *parent): QItemDelegat

iOS 8:【转】iOS UITextView 输入内容实时更新 cell 的高度

源地址:http://vit0.com/blog/2014/12/25/ios-textview-in-cell/ 这篇文章介绍了在一个动态数据的 table view 中,cell 根据 text view 内容的输入实时改变 cell 和 table view 的高度.自动计算 cell 高度的功能使用 iOS 8 才支持的自适应 cell,如果你还不知道 iOS 8 自适应 cell,可以参看这篇文章:iOS 8 自适应 Cell 先上图,我们最终要实现的效果是这样的: 图 1:实时更新

SPHINX 增量索引 实现近实时更新

一.sphinx增量索引的设置   数据库中的已有数据很大,又不断有新数据加入到数据库中,也希望能够检索到.全部重新建立索引很消耗资源,因为我们需要更新的数据相比较而言很少.例如.原来的数据有几百万条,而新增的只是几千条.这样就可以使用“主索引+增量索引”的模式来实现近乎实时更新的功能. 这个模式实现的基本原理是设置两个数据源和两个索引,为那些基本不更新的数据建立主索引,而对于那些新 增的数据建立增量索引.主索引的更新频率可以设置的长一些(例如设置在每天的午夜进行),而增量索引的更新频率,我们可