首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

iOS AutoLayout全解

AutoLayout简介 Autolayout是一种全新的布局技术,专门用来布局UI界面的,用来取代Frame布局在遇见屏幕尺寸多重多样的问题。...接着创建一个UITableViewCell的子类,命名为C1类。然后在C1.xib中,将与C1类进行关联。只需要在Class那里写入关联的类名C1即可。 ?...接着我们在UITableView中来使用我们自定义的UITableViewCell C1。...当非IB创建时,属性默认为YES;当IB创建View时,属性默认为NO。 案例2 在水平方向上放4张图片,图片等分。 1,首先在页面上拖拽1个imageView,将它的宽高都设置成50。...StackView属性 在理解StackView时,有几个属性需要理解: Axis: 这个属性是改变UIStackView中的排布方式的属性,其中有水平排布与垂直排布 Alignment:这个属性是其中子视图的位置摆布方式默认是填充摆布

4.6K60

UITableView图文混排自动布局滑动优化实战

AutoLayout和手动计算高度 毫无疑问,使用AutoLayout会明显的比手动计算高度慢,那么我为什么要用AutoLayout呢,因为实在太方便了,而且视图太复杂,产品改的太频繁,手动计算实在工作量太大...方案 1.缓存高度 既然手动计算高度更快,那就在Reuse的时候用AutoLayout帮我们算过后的高度就行了,缓存一个高度字典(或者数组),在算完渲染出来的时候取高度,在取高度的时候做个判断就行。...和endDisplay里做些特殊的处理,对于UIImageView就可以 -(void)endDisplay{ [imageView setImage:nil]; [imageView...4.GIF特殊处理 如果GIF太多了,做完以上优化,会发现滑动到GIF的时候还是很卡,原来是因为SDWebImage直接把下载完的GIF内容直接填充给UIImageView,会直接按帧把动画渲染出来,边滑动边渲染图片到...UIImageView上,就会导致UI线程阻塞,用户就感觉到卡顿了。

1.3K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    iOS_UITableView性能优化

    // 提前计算并缓存好高度 // 滑动时按需加载, 防止卡顿 配合SDWebImage https://github.com/johnil/VVeboTableViewDemo dispatch_async...自适应高度   -------- // 尽量提高计算效率, 已计算过的高度需要进行缓存, 没必要进行第二次运算 // 必须满足3个条件 // 1. cell.contentView 四边与内部元素有约束关系(Autolayout...UITableViewAutomaticDimension; // --------   离屏渲染: 圆角/阴影   -------- // 离屏渲染: 圆角/阴影, 另外开辟渲染缓冲区, 消耗性能 (多: 缓冲区频繁合并 上下文频繁切换, 导致掉帧) UIImageView...*imgV = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"placeholder"]]; imgV.frame = CGRectMake...*)cell forRowAtIndexPath:(NSIndexPath *)indexPath { } - (UITableViewCell *)tableView:(UITableView *)

    64420

    AutoLayout自动布局在线课程

    AutoLayout是一种基于约束的,描述性的布局系统。AutoLayout为开发者提供了一种不同于以往UI元素位置指定的布局方法。以前布局是通过frame属性来定义其在当前view中的位置和尺寸。...使用AutoLayout则变为使用约束条件来定义view的位置和尺寸,最大好处是解决了不同分辨率和屏幕尺寸下view的适配问题,也简化了旋转时view的位置的定义。...本人录制的《AutoLayout自动布局》课程,在腾讯课堂上线了,欢迎感兴趣的同学前来围观、学习、批评、指正。...[AutoLayout.png] 本课程内容如下: AutoLayout概念 Xcode AutoLayout界面介绍 AutoLayout简单案例 AutoLayout进阶案例 UIStackView...AutoLayout与UIScrollView UITableView行高自动计算 VFL介绍 SnapKit介绍 SnapKit使用

    61130

    用MyLayout实现布局性能的提升以及对阿拉伯国家的支持

    多说无益,图表最具说服力 下面的图表是在iPhone6真机设备上用MyLayout和frame以及AutoLayout进行构建和布局的时间对比表格,里面的数据是每个视图的构建时间和布局时间,单位都是毫秒...视图的构建和布局时间 构建时间 Frame MyLayout AutoLayout Masonry UIStackView TGLinearLayout 0.08 0.164 0.219 0.304 0.131...当用AutoLayout进行布局时每个子视图的平均构建时长约为0.189ms,而Masonry因为是对AutoLayout的封装所以平均构建时长约为0.289ms。...在布局时则因为都是使用了AutoLayout所以是相等的,大概花费0.255ms左右。...通过这个新定义的概念您就不需要担心在进行国际化布局时指定方向了。下面是MyLayout中对RTL支持的一些效果。 ?

    69460

    iOS 图片加载框架SDWebImage详解

    目的 在使用SDWebImage加载图片时,尤其是加载gif等大图时,SDWebImage会将图片缓存在内存中,这样是非常吃内存的,这时我们就需要在适当的时候去释放一下SDWebImage的内存缓存,才不至于造成...使用回调 blocks 在 block 中得到图片下载进度和图片加载完成(下载完成或者读取缓存)的回调,如果你在图片加载完成前取消了请求操作,就不会收到成功或失败的回调 [cell.imageView...中的 imageView 加载不同尺寸的网络图片时会出现尺寸缩放问题。...问题 2:图片刷新问题:SDWebImage 在进行缓存时忽略了所有服务器返回的 caching control 设置,并且在缓存时没有做时间限制,这也就意味着图片 URL 必须是静态的了,要求服务器上一个...解决方案:在调用 sd_setImageWithURL: placeholderImage: options:方法时设置 options 参数为 SDWebImageRefreshCached,这样虽然会降低性能

    2.6K10

    iOS9新特性——堆叠视图UIStackView

    iOS9新特性——堆叠视图UIStackView 一、引言         随着autolayout的推广开来,更多的app开始使用自动布局的方式来构建自己的UI系统,autolayout配合storyBoard...二、在storyBoard上初识StackView         UIStackView是一个管理一组堆叠视图的控制器类视图,所谓堆叠视图时一种平铺式的线性布局方式,不可重叠,布局方向也不可交错,如果你做过...watchOS的开发,你会发现,其实StackView与watchOS中的group十分能相似。...首先,我们在ViewController中拉入一个stackView: ? 将一些属性设置如下: ? Axis是设置布局的方向,有水平和垂直两种方式,一个StackView只能选择一种布局模式。...技巧:因为StackView继承于UIView,因此在布局改变的时候,我们可以使用UIView层的动画,如下:         //在添加view的时候会有动画效果,移除的时候没有         [stackView

    2K10

    浅汇-iOS UI布局

    如果父试图使用的是 Frame  , 子试图使用 AutoLayout  不会有问题, 使用Frame 来布局UI是开始的做法,现在也有很多人仍然钟情与这种方法,这种方法很直观,使用起来也很简单,但是他的简单决定了他在屏幕适配和内容自适应上的局限性...                       NEWX #define RECT(a,b,c,d)            CGRectMake(a*NEWX, b, c*NEWX, d)  这里我们以宽度缩放比为整体缩放比...AutoLayout(动画中使用是个弱点)      使用SDAutoLayout  不光是为了横竖屏的适配(通过判断屏幕方向,重置 Frame  也可以做到),是为了TablevIew中cell  ...我们可以在XIB、StoryBoard中通过拉线的形式给控件视图添加布局约束,通过苹果强大的可视化界 IB(Interface Builder)我们能够轻松的使用AutoLayout完成界面视图的布局。...UIImageView *imageV = [UIImageView new]; [self.view addSubview:imageV]; imageV.image = [UIImage imageNamed

    2.1K20

    MyLayout&TangramKit 的重大升级!

    系统内部的实现中如果布局引擎在布局时发现某个视图没有设置高度或者宽度约束那么就会去调用这个视图的intrinsicContentSize方法,如果这个方法返回了正常的尺寸则视图就按这个尺寸来进行渲染和展示...然后在UITableViewCell的派生类的视图代码布局处或者在-(UITableViewCell*)tableView:(UITableView *)tableView cellForRowAtIndexPath...然后在UITableViewCell的派生类中建立一个根布局视图,这个根布局视图作为子视图添加到contentView中代码如下: //假设根布局视图是一个垂直线性布局视图。...然后在UITableViewCell的派生类中重载视图的方法: - (CGSize)systemLayoutSizeFittingSize:(CGSize)targetSize withHorizontalFittingPriority...因此要将一个布局视图添加到采用AutoLayout约束的布局体系时,就像为普通视图一样给布局视图设置约束依赖即可。

    2.1K20

    iOS 高性能图片架构与设计

    在显示之前图片需要进行解码,缩放,显示这样的步骤。 为了优化内存,加快速度。框架提供了图片预处理的功能,根据实际的显示大小对图片进行解压、缩放处理,也就是后台线程预绘制。...支持autolayout、storyboard和代码布局 同时支持使用代码布局、autolayout布局、放入storyboard等多种操作方式,适应性强。 4 ....图片显示Qzimageview QZImageView继承自UIView聚合UIImageView,实现对上层UIImageView的委托,对外提供操作的接口。...在layoutSubviews时,对QZImageManager发起图片请求。收到QZImageManager传回的图片后显示在屏幕上。...当收到一个新的请求时。QZImageManager首先进行重复请求判断,对于多个不同QZImageView发来的相同的请求进行合并,加入TaskQueue中,在请求完成之后一同回调,防止重复请求。

    4.3K00

    Texture

    在之前的文章iOS的性能优化中我详细介绍了卡顿产生的原因,这里不做赘述,总结成一句话就是:GPU或者CPU的消耗过大,导致在一次同步信号之间没有准备完成,没有内容提交,导致掉帧。...而Texture的最大特点就是能够极大地优化卡顿问题,其优化原理如下: 布局:iOS的Autolayout在性能上是存在瓶颈的,并且只能在主线程进行计算,因此Texture弃用了AutoLayout,自己设计了一套布局方式...ASCellNode 作用等同于UITableViewCell或者UICollectionViewCell,自带indexPath属性,有些时候很有用。...在堆叠布局中,以垂直或水平堆叠对齐item,堆叠布局可以是另一堆叠布局的子布局,这使得可以使用ASStackLayoutSpec来创建任何布局。...alignItems,交叉轴上的排列方式 flexWrap alignContent lineSpacing Flexbox在ASDK中的工作方式与CSS在Web中的工作方式是相同的。

    2.4K61

    有了Auto Layout,为什么你还是害怕写UITabelView的自适应布局?

    关于这个话题,比较易犯的错误是,竟然有开发者在 tableView:heightForRowAtIndexPath: 中调用 tableView:cellForRowAtIndexPath: 来获取cell...1.使用AutoLayout 布局你的cell 坦白说,咱都是刚入行的人,使用AutoLayout布局,写一个自适应的Cell,大家估计也都会.可以用xib,也可以用纯代码写.如果准备用纯代码写,建议你先好好研究下...坦白说,我原来也是: 虽然cell用着AutoLayout,但是计算cell高度时,也是看着设计图返回一个适合的值--想想都虐心.前天,一个热心的开发者在我博客留言说: 他用 Masonry 进行Cell...然后,他提到了一个第三方UITableView-FDTemplateLayoutCell,好像是国内的大神写的,具体介绍可以看这里: 优化UITableViewCell高度计算的那些事.这篇文章的博主关于...model; }]; return height; } /** * 初始化视图. */ - (void) setupView { self.imgView = [[UIImageView

    92260

    iOS多设备适配简史以及相应的API支撑实现

    NSLayoutConstraint约束以及iOS9上的封装改进 在iOS6时代苹果推出了AutoLayout的技术解决方案,这是一套采用以相对约束来替代硬编码的解决方法,然而糟糕的方法名和使用方式导致使用成本和代码量的急剧增加...在iOS9中还提供了一个UIStackView的类来简化那些视图需要从上往下或者从左往右依次添加排列的场景,通过UIStackView容器视图的使用就不再需要为每个子视图添加冗余的依赖约束关系了。...在大量的实践中很多应用的各板块其实都是按顺序从上到下排列或者从左到右排列的。所以如果您的应用最低支持到iOS9的话就可以大量的应用这个类来构建你的程序了。...SizeClasses多屏幕适配 当我们的程序可能需要同时在横屏和竖屏下运行并且横屏和竖屏下的布局还不一致时,而且希望我们的应用在小屏幕上和大屏幕上(比如iPhone8 Plus 以及iPhoneX S...但是在实际的实践中我们很少有看到使用SizeClasses的例子和场景以及在我们开发中很少有使用到这方面的技术,所以我认为这应该是苹果的一个多屏幕适配的失败解决的方案。

    1.1K30

    iOS开发中行高灵活可变的UITableView的性能优化

    iOS开发中行高灵活可变的UITableView的性能优化 一、UITableView的构建原理         在新闻类,电商类等应用中,应用着大量的图文混排视图,在表视图UITableView中,...当执行TableView的reloadData方法进行界面刷新时,系统先会把所有行的行高数据拉取一遍,之后和UITableViewCell配置部分的场景一直,会拉取即将出现在屏幕上的cell的行高数据。...heightForRowAtIndexPath方法拉取行高时,直接返回已经计算过的行高数据,具体如何操作比较灵活,可以对应一个数组属性,将计算后的行高放入数组中,每次取行高时,检查数组中是否已经有计算过的行高数据...在iOS7系统之后,UITableView类中增加了一个estimatedRowHeight属性,顾名思义,这个属性是设置UITableViewCell中的大约行高值。...所谓足够压力,是指UITableViewCell的contentView的上、下、左、右必须被内部控件的约束所撑满,需要注意,cell上的视图必须添加在contentView上,否则计算会出现问题。

    2K20

    iOS小技能: 解决UITableViewCell兼容问题(iOS14适配)

    前言 问题:升级最新IDE Xcode,发现app首页的cell中按钮也无法点击了。...cell.addSubView(tempView1) 这种方式添加的,通过Xcode自带的DebugViewHierarchy视图分析发现问题的原因是:被系统自带的UITableViewCellContentView遮挡在底部了...API _printHierarchy 和recursiveDescription 关于视图层级分析你也可以使用私有API _printHierarchy 和recursiveDescription 在lldb...获取要交换的方法 Method alternateMethod = class_getInstanceMethod(self, alternateSEL); // 当要交换的方法不存在时,...3.2 iOS 恢复调用栈(适配iOS14) 原理:objective-c 函数信息除了保存在符号表中,还保存在其他段中 https://github.com/zhangkn/restore-symbol4iOS14

    1.5K30
    领券