UIScroView 3倍的contentSize,左右Scroll时,懒惰加载View
UIScroView 3倍的contentSize,左右Scroll时,懒惰添加左右的View
用途:分段加载数据
定义枚举:
typedefenum { ViewPositionLeft = , ViewPositionCenter, ViewPositionRight } ViewPosition;
变量定义:
NSInteger _currnetPage; CGRect _leftFrame; CGRect _centerFrame; CGRect _rightFrame; UIScrollView *_sv;
初始化变量:
-(void)createView { _currnetPage = ; _sv = [[UIScrollView alloc] init]; _sv.frame = CGRectMake(, , , ); _sv.pagingEnabled = YES; _sv.backgroundColor = [UIColorwhiteColor]; _sv.contentSize = CGSizeMake(_sv.frame.size.width*, _sv.frame.size.height); _sv.showsHorizontalScrollIndicator = YES; _sv.showsVerticalScrollIndicator = NO; for (int i = ; i > -; i--) { CGRect frame; frame.origin.x = _sv.frame.size.width * ( - i); frame.origin.y = ; frame.size = _sv.frame.size; UIView *lbl = [selfcreateLabeViewWithCurrentPage:i]; lbl.frame = frame; if (i == ) { _leftFrame = frame; lbl.tag = ViewPositionLeft; } if (i == ) { _centerFrame = frame; lbl.tag = ViewPositionCenter; } if (i == ) { _rightFrame = frame; lbl.tag = ViewPositionRight; } [_sv addSubview:lbl]; } _sv.delegate = self; [_svscrollRectToVisible:_rightFrameanimated:NO]; [self.view addSubview:_sv]; }
创建新View的方法(selfcreateLabeViewWithCurrentPage):
- (UIView *)createLabeViewWithCurrentPage:(int)Page { UILabel *textView = [[UILabel alloc] init]; textView.text = [NSString stringWithFormat:@"Page %d",Page]; textView.font = [UIFont systemFontOfSize:]; textView.textColor = [UIColor blackColor]; textView.backgroundColor = [UIColorwhiteColor]; textView.textAlignment = UITextAlignmentCenter; [_sv addSubview:textView]; return textView; } UIScrollViewDelegate方法: - (void)scrollViewDidEndDecelerating:(UIScrollView *)sv { BOOL towardsToLeft = NO; CGFloat width = _sv.frame.size.width; if (_sv.contentOffset.x == width) { if (_currnetPage == ) { _currnetPage++; } return; } if (_sv.contentOffset.x > width) { towardsToLeft = YES; if(_currnetPage == ){ // NSLog(@"currentPage = 0; 向左"); return; } // NSLog(@"向左"); } else{ // NSLog(@"向右"); } // _previousPage = _currnetPage; if (towardsToLeft == YES) { _currnetPage--; } else{ _currnetPage++; } if (_currnetPage == ) { } else { [sv scrollRectToVisible:_centerFrameanimated:NO]; UIView *view = [_sv viewWithTag:_currnetPage]; view.frame = _centerFrame; if (towardsToLeft == YES) { UIView *viewRLeft = [_sv viewWithTag:ViewPositionLeft]; [viewRLeft removeFromSuperview]; UIView *viewRCenter = [_sv viewWithTag:ViewPositionCenter]; viewRCenter.frame = _leftFrame; viewRCenter.tag = ViewPositionLeft; UIView *viewRRight = [_sv viewWithTag:ViewPositionRight]; viewRRight.frame = _centerFrame; viewRRight.tag = ViewPositionCenter; UIView *viewRight = [self createLabeViewWithCurrentPage:_currnetPage - ]; viewRight.frame = _rightFrame; viewRight.tag = ViewPositionRight; [sv addSubview:viewRight]; } else{ UIView *viewRRight = [_sv viewWithTag:ViewPositionRight]; [viewRRight removeFromSuperview]; UIView *viewRCenter = [_sv viewWithTag:ViewPositionCenter]; viewRCenter.frame = _rightFrame; viewRCenter.tag = ViewPositionRight; UIView *viewRLeft = [_sv viewWithTag:ViewPositionLeft]; viewRLeft.frame = _centerFrame; viewRLeft.tag = ViewPositionCenter; UIView *viewLeft = [self createLabeViewWithCurrentPage:_currnetPage + ]; viewLeft.frame = _leftFrame; viewLeft.tag = ViewPositionLeft; [sv addSubview:viewLeft]; } } }
希望对用到的朋友有用。
UIScroView 3倍的contentSize,左右Scroll时,懒惰加载View的更多相关文章
- mui scroll和上拉加载/下拉刷新
mui中 scroll和上拉加载/下拉刷新同时存在会出现两个滚动条 把/* */ /* //mui页面鼠标拖动代码: mui('.mui-scroll-wrapper').scroll({ dec ...
- js 鼠标滚动到某屏时,加载那一屏的数据,仿京东首页楼层异步加载模式
js用处:在做商城时,首页图片太多,严重影响首页打开速度,所以我们需要用到异步加载楼层.js名称:鼠标滚动到某屏时,加载那一屏的数据,仿京东首页楼层模式js解释:1.用于商城的楼层内容异步加载,滚动条 ...
- 基于JQuery实现滚动到页面底端时自动加载更多信息
基于JQuery实现滚动到页面底端时自动加载更多信息 关键代码: 代码如下: var stop=true; $(window).scroll(function(){ totalheight = par ...
- jQuery实现滚动时动态加载页面内容
有些网站的网页内容不是一次性加载完毕的,而是在鼠标向下滚动时动态加载的,这是怎么做到的呢?看下面代码: 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 ...
- Tomcat启动时自动加载Servlet
1.想做一个服务启动时自动启动一不停止的获取订阅功能 2.之前是做一个Jsp页面请求servlet来触发方法 3.现在实现Tomcat启动时自动加载Servlet 1.Tomcat中启动Servlet ...
- 如何让openvpn在windows启动时自动加载
在非常需要vpn的人群中,他们几乎一整天都连接着vpn,但是每次开机都要连接vpn的过程有时候比较繁琐对于新手而言.这篇文章主要是说明如何在windows启动时自动加载openvpn自动连接,该教程适 ...
- selenium启动Chrome时,加载用户配置文件
selenium启动Chrome时,加载用户配置文件 Selenium操作浏览器是不加载任何配置的,网上找了半天,关于Firefox加载配置的多点,Chrome资料很少,下面是关于加载Chrome ...
- jquery mobile 请求数据方法执行时显示加载中提示框
在jquery mobile开发中,经常需要调用ajax方法,异步获取数据,如果异步获取数据方法由于网速等等的原因,会有一个反应时间,如果能在点击按钮后数据处理期间,给一个正在加载的提示,客户体验会更 ...
- 测试img在不显示时是否加载?
一直搞不明白,隐藏的元素的背景图,在页面加载时,是否自动加载? img隐藏时,图片会加载吗? 测试代码如下: <!DOCTYPE html> <html> <head&g ...
随机推荐
- Python之路 day1 用户登录多次被锁定
编写登陆接口: 输入用户名密码 认证成功后显示欢迎信息 输错三次后锁定 #Author:ersa import getpass,os,sys #读取账户信息到内存中 try: accounts_fil ...
- 向JS对象添加和删除事件
this.removeEventListener = function (obj, ename, func) { var store = obj[this.addEventListener.pre + ...
- 并发编程 13—— 线程池的使用 之 配置ThreadPoolExecutor 和 饱和策略
Java并发编程实践 目录 并发编程 01—— ThreadLocal 并发编程 02—— ConcurrentHashMap 并发编程 03—— 阻塞队列和生产者-消费者模式 并发编程 04—— 闭 ...
- 3d加速的一些问题
笔记本一般有双显卡,默认可以切换,但是使用浏览器打开的要合适的浏览器 打开WEBGL程序,包括驱动,浏览器,有时候需要手工设置独立显卡 一般来说价钱四五千以上的笔记本电脑都是支持WEBGL的,而且可以 ...
- 读<jquery 权威指南>[7]-性能优化与最佳实践
一.优化选择器执行速度 1. 优先使用ID选择器和标记选择器 使用选择器时应该首选ID选择器($("#id")),其次是标记选择器($("div")),最后再选 ...
- Cisco IOS IP Service Level Agreementv (IP SLA)
Responder and Control Protocol 1.Responder内嵌在思科目标路由器中的一个组件,用来对IP SLA请求包做应答,通过对应达包添加时间戳属性,以提高测量计算的准确性 ...
- Python高效编程的19个技巧
初识Python语言,觉得python满足了我上学时候对编程语言的所有要求.python语言的高效编程技巧让我们这些大学曾经苦逼学了四年c或者c++的人,兴奋的不行不行的,终于解脱了.高级语言,如果做 ...
- F2工作流引擎模型
工作流引擎(Workflow Engine ) [编辑] 工作流引擎概述 工作流引擎是指workflow(工作流)作为应用系统的一部分,并为之提供对各应用系统有决定作用的根据角色.分工和条件的不同决定 ...
- appcan.windw.open appcan.frame.open appcan.window.openPopOver evaluateScript
在模拟器上,几种发方式产生的窗口,其实都是iframe. 在根窗口(app打开的第一个)执行JS: try{ appcan.window.evaluateScript( { name: 'root', ...
- IT行业的斗争
有朋友和我说,她希望做一名IT工作者,原因是可以对着机器工作,不需要再面对人与人之间的是是非非. 我真心不想打破她的憧憬,因为无论干任何行业,有人,就有矛盾,就有斗争. 我是那名失败者,仅仅想安安稳稳 ...