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

一、实现效果图

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

二、程序实现

介绍一下我实现的原理

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

-(void)viewWillAppear:(BOOL)animated
{
self.navigationController.navigationBar.hidden = YES;
}
-(void)viewWillDisappear:(BOOL)animated
{
self.navigationController.navigationBar.hidden = NO;
}

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

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

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

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

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

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

//lazy
-(UITableView *)tableview
{
if (!_tableview) {
_tableview = [[UITableView alloc]initWithFrame:CGRectMake(0, 0, kScreenW, kScreenH) style:UITableViewStylePlain];
CGFloat headImvH = kScreenW / 320 * 300;
//这句很重要
_tableview.contentInset = UIEdgeInsetsMake(headImvH-20, 0, 0, 0); _tableview.dataSource = self;
_tableview.delegate = self;
}
return _tableview;
} -(UIImageView *)headImv
{
if (!_headImv) {
_headImv = [[UIImageView alloc]init];
CGFloat headImvH = kScreenW / 320 * 300;
_headImv.frame = CGRectMake(0, 0, kScreenW, headImvH);
_headImv.image = [UIImage imageNamed:@"head"];
//一定记住模式
_headImv.contentMode = UIViewContentModeScaleAspectFill;
_headImv.clipsToBounds = YES;
}
return _headImv;
} -(UIView *)navView
{
if (!_navView) {
_navView = [[UIView alloc]initWithFrame:CGRectMake(0, 0, kScreenW, 64)];
_navView.backgroundColor = [[UIColor redColor] colorWithAlphaComponent:0.8];
_navView.clipsToBounds = YES; _titLab = [[UILabel alloc]init];
_titLab.centerX = kScreenW * 0.5;
_titLab.bounds = CGRectMake(0, 0, 150, 44);
_titLab.textAlignment = NSTextAlignmentCenter;
_titLab.font = [UIFont systemFontOfSize:12];
_titLab.textColor = [UIColor blueColor];
_titLab.numberOfLines = 0;
_titLab.text = @"CF\n明天休息了";
[_navView addSubview:_titLab];
}
return _navView;
}

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

- (void)viewDidLoad {
[super viewDidLoad];
self.view.backgroundColor = [UIColor whiteColor]; //添加顺序不能改变
[self.view addSubview:self.tableview];
[self.view addSubview:self.headImv];
[self.view addSubview:self.navView];
[self setupNavView];
} #pragma mark - 设置导航栏
-(void)setupNavView
{
UIButton *leftNavBtn = [UIButton buttonWithType:UIButtonTypeCustom];
leftNavBtn.frame = CGRectMake(0, 20, 64, 44);
[leftNavBtn setTitle:@"返回" forState:UIControlStateNormal];
[leftNavBtn addTarget:self action:@selector(leftNavClike) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:leftNavBtn]; UIButton *rightNavBtn = [UIButton buttonWithType:UIButtonTypeCustom];
rightNavBtn.frame = CGRectMake(kScreenW-64, 20, 64, 44);
[rightNavBtn setTitle:@"更多" forState:UIControlStateNormal];
[rightNavBtn addTarget:self action:@selector(rightNavClike) forControlEvents:UIControlEventTouchUpInside];
[self.view addSubview:rightNavBtn];
} -(void)leftNavClike
{
[self.navigationController popViewControllerAnimated:YES];
} -(void)rightNavClike
{ } #pragma mark - UITableViewDataSource
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
return 20;
} - (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
{
static NSString *cellID = @"cellID";
UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:cellID];
if (cell == nil) {
cell = [[UITableViewCell alloc]initWithStyle:UITableViewCellStyleDefault reuseIdentifier:cellID];
}
cell.textLabel.text = [NSString stringWithFormat:@"测试数据——%td",indexPath.row];
cell.detailTextLabel.text = [NSString stringWithFormat:@"测试数据——%td",indexPath.row]; return cell;
}

2、下面为核心代码

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

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

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

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

三、代码结构

代码包第一层目录

代码结构层目录

四、附上结构图

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. hdu5076

    好题,首先观察可得w[i][j]选择只有可能两种,一种比阀值大,一种比阀值小 比阀值大就一定选满足条件最大的w,比阀值小同样一定选满足条件最大的w 那么一个最小割模型就呼之欲出了,注意w可能是负数那么 ...

  2. 【cocos2d-js官方文档】十七、事件分发机制

    简介http://blog.csdn.net/qinning199/article/details/41951517 游戏开发中一个很重要的功能就是交互,如果没有与用户的交互,那么游戏将变成动画,而处 ...

  3. selenium 定位

    一 . chrome的调试工具 1)在chrome界面,按F12快捷键,弹出chrome的调试工具 2)找出登录按钮的id和username.password的id  二.XPath工具 安装 为了提 ...

  4. uestc1633

    uestc1633 题意 给你一个大小为 \(n\) 的集合 \(S\) ,集合里有 \(n\) 个互不相同正整数,有 \(q\) 个询问,每次询问是否能选择 \(S\) 中的一些数字 ( 同一个数字 ...

  5. 19、Django实战第19天:课程列表页

    从今天开始,我们将完成"公开课"课程的相关功能..... 1.把course-list.html复制到templates目录下 2.这个页面的头部.底部与之前定义的base.htm ...

  6. iOS 文字渐变色

    // 创建UILabel UILabel *label = [[UILabel alloc] init]; label.text = @"我是渐变的label"; [label s ...

  7. tcp状态-TIME_WAIT与CLOSE_WAIT带来的坑

    tcp状态: http://www.cnblogs.com/DengGao/p/tcp_state.html 1. tcp连接会占用系统资源(文件描述符), 有时候甚至会导致系统假死(不能发起或者处理 ...

  8. NHibernate官方文档中文版——持久化类(Persistent Classes)

    持久化类是一个应用程序中的类,主要用来实现业务逻辑(例如,在电商应用中的客户和订单类).持久化类,就像它的名字一样,生命周期短暂并且用来持久化的据库对象实例. 如果这些类的构造能够依照一些简单的原则, ...

  9. 【MyEcplise】导入项目报错:Errors running builder 'JavaScript Validator' on project '项目名'. java.lang.ClassCastException

    导入项目报错:Errors running builder 'JavaScript Validator' on project '项目名'. java.lang.ClassCastException ...

  10. php新浪云链接mysql与storage

    1.首先要有一个新浪云服务器 2.链接数据库获取数据 mysql CREATE TABLE Persons(FirstName varchar(255),LastName varchar(255)); ...