iOS放大镜效果的滚动视图

前言:最近开始一波整理,准备把最近遇到的一些难题和解决方法整理一下,用来留念。还有希望能小小帮助到同学们。
开始主题,先来一波演示吧。

ZPScrollView.gif

看过之后 估计大部分筒子们都有一些想法。其实这确实不难,主要就是滑动到中间的时候小球变大和变小的效果。这比较绕一点。

其他地方就不多说了 不懂得可以看我的demo 在这里就着重说一下关键的一个代理方法

-(void)scrollViewDidScroll:(UIScrollView *)scrollView

变化效果主要就在这个方法里边实现的。
先看下图

屏幕快照 2017-08-01 15.08.28.png

在这里上边那个代理里边主要实现的效果是:
1.向左滑动的时候 4 滚到5的位置 并且从小球变化成大球 ,5滚动到6的位置 并且从大球变化成小球。说到这里 ,童鞋们是不是有思路了😜。
2。想右滑动的时候 6滚动到5的位置 从小球变打球, 5滚动到4的位置 从打球变小球。
实现以上这两种设想,就行了 接下来就是具体实现了


-(void)scrollViewDidScroll:(UIScrollView *)scrollView{
    
//    NSLog(@"%f",scrollView.contentOffset.x);
     CGFloat one_with = scrollView.frame.size.width/5.0f;//每一个小球所占的大小
     CGFloat offSet_x = scrollView.contentOffset.x;//滚动视图现在的偏移量
     NSInteger Number = offSet_x/one_with;//第几个区域
     CGFloat  surplus_x = offSet_x-Number*one_with;//在某个小球区间里的偏移量
  //    NSLog(@"第几个区域%ld",Number);
  //    算出每一像素 小球的变化值 (小球的frame的变化量)
     CGFloat sub_x = aScaleH(16.5)/one_with*surplus_x;
     CGFloat sub_y = aScaleH(6)/one_with*surplus_x;
     CGFloat sub_w = aScaleH(33)/one_with*surplus_x;
     CGFloat sub_h = aScaleH(33)/one_with*surplus_x;
//    selectBtn.frame =kRect(Label_W*2+20+i*Label_W, 6, 35, 35);

    //在左边
     UIButton *rightBtn = (UIButton *)[self viewWithTag:153400+Number+1];
    rightBtn.frame = CGRectMake(one_with*2+aScaleW(20)+one_with*(Number+1)-sub_x, aScaleH(6)-sub_y, aScaleW(35)+sub_w, aScaleH(35)+sub_h);
 
    //在右边
    UIButton *leftBtn = (UIButton *)[self viewWithTag:153400+Number];
    leftBtn.frame = CGRectMake(one_with*2+aScaleW(20)+one_with*(Number)-(aScaleH(16.5)-sub_x), aScaleH(6)-(aScaleH(6)-sub_y), aScaleW(35)+( aScaleH(33)-sub_w), aScaleH(35)+(aScaleH(33)-sub_h));
   
    //其他小球回复原大小(防止快速滑动的时候回复不过来)(完美!)
    UIButton *atherRightBtn = (UIButton *)[self viewWithTag:153400+Number+2];
    atherRightBtn.frame =CGRectMake(one_with*2+aScaleW(20)+one_with*(Number+2), aScaleH(6), aScaleW(35), aScaleW(35));
    UIButton *atherleftBtn = (UIButton *)[self viewWithTag:153400+Number-1];
    atherleftBtn.frame =CGRectMake(one_with*2+aScaleW(20)+one_with*(Number-1), aScaleH(6), aScaleW(35), aScaleW(35));
    //滚动的时候拖拽按钮在滚动的时候影藏
    self.moveBtn.hidden = YES;
    [self.moveBtn setTitle:@"" forState:(UIControlStateNormal)];
    
}

有些童鞋估计 只看这里会有点蒙 没关系 demo在这里 可以结合着看https://github.com/ZPCoder/ZPScrollView

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

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,837评论 25 707
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,066评论 4 62
  • 在使用第三方库Masonry的时候,有时候可能会出现物体位置并没有出现在我们想要让它出现的位置。最主要的原因还是我...
    valiant_xin阅读 795评论 0 0
  • 在人言上看到一只小泰迪的照片,那眼神,那卷毛,那丑丑的、赖赖的,想看你却又表现的很不屑,斜着眼睛瞄你的样子几乎跟我...
    安心的离歌阅读 800评论 5 3
  • 直到那一天,我才知道,她是孤儿——爸爸去世,妈妈离家出走,已多年不知去向,一直跟着年迈又体弱多病的爷爷生活。 家长...
    明媚的念子阅读 482评论 0 3