代码地址如下:
http://www.demodashi.com/demo/11623.html

一、实现效果图

现在越来越多的APP中存在下拉放大图片的效果,今天贡献一下我的实现这种方法的原理,和我遇到的坑。效果图

二、程序实现

介绍一下我实现的原理

一进入界面的时候隐藏掉导航栏,因为操作系统的导航栏较麻烦,不如自己写一个导航栏来的简单,在界面要消失的时候在把导航栏显示出来即可,(也可以自己写一个pop动画)

  1. -(void)viewWillAppear:(BOOL)animated
  2. {
  3. self.navigationController.navigationBar.hidden = YES;
  4. }
  5. -(void)viewWillDisappear:(BOOL)animated
  6. {
  7. self.navigationController.navigationBar.hidden = NO;
  8. }

使用懒加载的方法把假的导航栏,图片和表格创建出来

1、这里有几点注意事项:

1.图片不能添加到UITabview的HeaderView中,因为如果添加到HeaderView中,那图片就是表格的一部分了,会跟随表格的移动和移动。

2.表格要设置contentInset来显示出图片,不然会有覆盖问题

3.图片的填充模式很重要,一定要是UIViewContentModeScaleAspectFill这样可以节省很多代码

4.图片和假导航栏要设置clipsToBounds为YES,不然会有Bug

  1. //lazy
  2. -(UITableView *)tableview
  3. {
  4. if (!_tableview) {
  5. _tableview = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, kScreenW, kScreenH) style:UITableViewStylePlain];
  6. CGFloat headImvH = kScreenW / 320 * 300;
  7. //这句很重要
  8. _tableview.contentInset = UIEdgeInsetsMake(headImvH-20, 0, 0, 0);
  9. _tableview.dataSource = self;
  10. _tableview.delegate = self;
  11. }
  12. return _tableview;
  13. }
  14. -(UIImageView *)headImv
  15. {
  16. if (!_headImv) {
  17. _headImv = [[UIImageView alloc]init];
  18. CGFloat headImvH = kScreenW / 320 * 300;
  19. _headImv.frame = CGRectMake(0, 0, kScreenW, headImvH);
  20. _headImv.image = [UIImage imageNamed:@"head"];
  21. //一定记住模式
  22. _headImv.contentMode = UIViewContentModeScaleAspectFill;
  23. _headImv.clipsToBounds = YES;
  24. }
  25. return _headImv;
  26. }
  27. -(UIView *)navView
  28. {
  29. if (!_navView) {
  30. _navView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, kScreenW, 64)];
  31. _navView.backgroundColor = [[UIColor redColor] colorWithAlphaComponent:0.8];
  32. _navView.clipsToBounds = YES;
  33. _titLab = [[UILabel alloc]init];
  34. _titLab.centerX = kScreenW * 0.5;
  35. _titLab.bounds = CGRectMake(0, 0, 150, 44);
  36. _titLab.textAlignment = NSTextAlignmentCenter;
  37. _titLab.font = [UIFont systemFontOfSize:12];
  38. _titLab.textColor = [UIColor blueColor];
  39. _titLab.numberOfLines = 0;
  40. _titLab.text = @"CF\n明天休息了";
  41. [_navView addSubview:_titLab];
  42. }
  43. return _navView;
  44. }

这些代码很好理解,不做解释

  1. - (void)viewDidLoad {
  2. [super viewDidLoad];
  3. self.view.backgroundColor = [UIColor whiteColor];
  4. //添加顺序不能改变
  5. [self.view addSubview:self.tableview];
  6. [self.view addSubview:self.headImv];
  7. [self.view addSubview:self.navView];
  8. [self setupNavView];
  9. }
  10. #pragma mark - 设置导航栏
  11. -(void)setupNavView
  12. {
  13. UIButton *leftNavBtn = [UIButton buttonWithType:UIButtonTypeCustom];
  14. leftNavBtn.frame = CGRectMake(0, 20, 64, 44);
  15. [leftNavBtn setTitle:@"返回" forState:UIControlStateNormal];
  16. [leftNavBtn addTarget:self action:@selector(leftNavClike) forControlEvents:UIControlEventTouchUpInside];
  17. [self.view addSubview:leftNavBtn];
  18. UIButton *rightNavBtn = [UIButton buttonWithType:UIButtonTypeCustom];
  19. rightNavBtn.frame = CGRectMake(kScreenW-64, 20, 64, 44);
  20. [rightNavBtn setTitle:@"更多" forState:UIControlStateNormal];
  21. [rightNavBtn addTarget:self action:@selector(rightNavClike) forControlEvents:UIControlEventTouchUpInside];
  22. [self.view addSubview:rightNavBtn];
  23. }
  24. -(void)leftNavClike
  25. {
  26. [self.navigationController popViewControllerAnimated:YES];
  27. }
  28. -(void)rightNavClike
  29. {
  30. }
  31. #pragma mark - UITableViewDataSource
  32. - (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
  33. {
  34. return 20;
  35. }
  36. - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
  37. {
  38. static NSString *cellID = @"cellID";
  39. UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellID];
  40. if (cell == nil) {
  41. cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellID];
  42. }
  43. cell.textLabel.text = [NSString stringWithFormat:@"测试数据——%td",indexPath.row];
  44. cell.detailTextLabel.text = [NSString stringWithFormat:@"测试数据——%td",indexPath.row];
  45. return cell;
  46. }

2、下面为核心代码

通过表格的代理方法来改变整体的Frame

这里我发现一个问题,如果表格滑动的特别快,那么这个代理方法会存在来不及执行的效果,或者说偏移量不是线性改变的,从而导致根据偏移量来计算的Frame出现问题,所以有些控件建议在设置Frame的时候,建议用一个参照来改变(我这里假导航栏里面的文字用偏移出现了问题,所以改用假导航栏的透明度)

设置头部图片的Frame要注意,origin值不要改变一旦改变不好调整。

  1. #pragma mark - UIScrollViewDelegate
  2. - (void)scrollViewDidScroll:(UIScrollView *)scrollView
  3. {
  4. //拿到偏移量
  5. CGFloat offsetY = scrollView.contentOffset.y;
  6. NSInteger headImvH = kScreenW / 320 * 300 ;
  7. CGFloat offset = headImvH + offsetY;//计算偏移量
  8. //设置导航栏
  9. self.navView.alpha = (offset / 250);
  10. if (self.navView.alpha >=1) {
  11. self.navView.alpha = 1;
  12. }
  13. //设置标题文字 设置距离
  14. //alpha 0-->1 y 64-->20
  15. self.titLab.y = 64 - 44 * self.navView.alpha;
  16. //设置头部图片大小
  17. self.headImv.frame = CGRectMake(0, 0, kScreenW, headImvH-offset);
  18. }

三、代码结构

代码包第一层目录

代码结构层目录

四、附上结构图

IOS下拉放大图片

代码地址如下:
http://www.demodashi.com/demo/11623.html

注:本文著作权归作者,由demo大师代发,拒绝转载,转载需要作者授权

IOS下拉放大图片的更多相关文章

  1. AJ学IOS 之tableView的下拉放大图片的方法

    AJ分享,必须精品 一:效果 tableview下拉的时候上部分图片放大会 二:代码 直接上代码,自己研究吧 #import "NYViewController.h" //图片的高 ...

  2. iOS开发-UITableView顶部图片下拉放大

    关于顶部图片下拉放大,在用户展示的个人中心显示用户个人头像信息,设置UITableView的headerView实现,UITableView继承自UIScrollView,同样的设置UIScrollV ...

  3. iOS实现下拉放大的功能

    #import "HMViewController.h" ; @interface HMViewController () @property (nonatomic, weak) ...

  4. iOS之下拉放大,上推缩小,一个方法搞定

    先来看看效果吧. 讲讲大概的实现思路:1、创建头部的视图和tableview,需要注意的是tableview要设置contentInset,contentInsent 的顶部要和头部视图的背景图的高度 ...

  5. android一个下拉放大库bug的解决过程及思考

    android一个下拉放大库bug的解决过程及思考 起因 项目中要做一个下拉缩放图片的效果,搜索了下github上面,找到了两个方案. https://github.com/Frank-Zhu/Pul ...

  6. 如何在webapp中做出原生的ios下拉菜单效果

    github:https://github.com/zhoushengmufc/iosselect webapp模仿ios下拉菜单 html下拉菜单select在安卓和IOS下表现不一样,iossel ...

  7. [RN] React Native 下拉放大动画

    React Native 下拉放大动画 经测试,无法运行 https://www.jianshu.com/p/1c960ad75020

  8. iOS下拉图片放大

    效果图 开始简单的代码过程 其实思路很简单 就是 让tableView偏移 一图片的高度,然后在把图片添加到tableView中,然后再监听didScrollView,在里面改变图片的frame - ...

  9. 两种图片下拉放大效果实现(自定义CoordinatorLayout以及自定义Recylerview)

    一.自定义CoordinatorLayout实现图片放大功能 本文是基于折叠布局实现的图片上拉滑动,下拉图片放大,松手放大的效果,先看下效果图. 实现原理: 1.使用CoordinatorLayout ...

随机推荐

  1. axis2

    下载axis2-1.5.4-bin.zip文件并解压. 设置axis2的环境变量,如下图所示: 利用axis2中的wsdl2java.bat生成客户端程序. 先启动Tomcat7并在IE里运行http ...

  2. 统计mysql库中每张表的行数据

    修改数据库配置文件:vim /etc/my.cnf [client] user=username password=password 使用shell脚本统计表中的行数据:count.sh #!/bin ...

  3. 【cocos2d-js官方文档】九、cc.loader

    概述 原来的cc.Loader被改造为一个单例cc.loader,采用了插件机制设计,让loader做更纯粹的事. 各种资源类型的loader可以在外部注册进来,而不是直接将所有的代码杂揉在cc.Lo ...

  4. Codeforces 626 B. Cards (8VC Venture Cup 2016-Elimination Round)

      B. Cards   time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  5. HDU 多校1.12

  6. struts2 action 字段问题

    struts2最多只能解释两级字段,比如user.username,像user.info.age在类中属性类的三段字符不能识别,只能先用user,info 然后在user.setInfo(info);

  7. [Codeforces 28D] Do not fear,DravDe is kind

    Brief Intro: 对于四元组(v,c,l,r),求其子序列中v最大的和,并使其满足: 1.Ci+Li+Ri相同 2.L1=0,Rn=0 3.Li=Sigma(C1...Ci-1) Soluti ...

  8. POJ 1466 Girls and Boys(二分图匹配)

    [题目链接] http://poj.org/problem?id=1466 [题目大意] 给出一些人和他们所喜欢的人,两个人相互喜欢就能配成一对, 问最后没有配对的人的最少数量 [题解] 求最少数量, ...

  9. 【分块】bzoj1858 [Scoi2010]序列操作

    分块 Or 线段树 分块的登峰造极之题 每块维护8个值: 包括左端点在内的最长1段: 包括右端点在内的最长1段: 该块内的最长1段: 该块内1的个数: 包括左端点在内的最长0段://这四个是因为可能有 ...

  10. 敏捷开发中的sprint是什么意思_百度知道

    敏捷开发中的sprint是什么意思_百度知道     敏捷开发中的sprint是什么意思    未成年RB21 | 浏览 4208 次    推荐于2016-02-27 15:19:02     最佳 ...