当前位置: 首页 > 编程笔记 >

iOS布局渲染之UIView方法的调用时机详解

霍鸣
2023-03-14
本文向大家介绍iOS布局渲染之UIViewhtml" target="_blank">方法的调用时机详解,包括了iOS布局渲染之UIView方法的调用时机详解的使用技巧和注意事项,需要的朋友参考一下

前言

APP页面优化对小编来说一直是难题,最近一直在不断的学习和总结 ,发现APP页面优化说到底离不开view的绘制和渲染机制。本文将详细给大家介绍关于iOS布局渲染之UIView方法调用时机的相关内容,下面话不多说了,来一起看看详细的介绍吧。

一、约束

- (void)updateConstraints NS_AVAILABLE_IOS(6_0) NS_REQUIRES_SUPER;

何时触发如下所示:

1、initWithFrame时候调用,但是要求重写以下方法,并返回YES。

+ (BOOL)requiresConstraintBasedLayout NS_AVAILABLE_IOS(6_0);

2、标记为需要更新,下次drawing cycle自动调用。当约束改变时,下次render loop还会自动调用layoutSubviews(布局)

- (void)setNeedsUpdateConstraints NS_AVAILABLE_IOS(6_0);

3、如果有需要更新的标记,立即调用。当约束改变时,下次render loop还会自动调用layoutSubviews(布局)

- (void)updateConstraintsIfNeeded NS_AVAILABLE_IOS(6_0);

二、布局

- (void)layoutSubviews;

1、何时触发如下所示:

initWithFrame时候调用,但是rect的值不能为CGRectZero。

- (instancetype)initWithFrame:(CGRect)frame NS_DESIGNATED_INITIALIZER;

2、标记为需要布局,下次drawing cycle自动调用。

- (void)setNeedsLayout;

3、如果有需要布局的标记,立即调用。

- (void)layoutIfNeeded;

4、自己的frame发生改变时,约束也会导致frame改变。

@property(nonatomic) CGRect frame;

5、添加子视图或者子视图frame改变时,约束也会导致frame改变。

6、视图被添加到UIScrollView,滚动UIScrollView。

三、显示

- (void)drawRect:(CGRect)rect;

何时触发如下所示:

1、initWithFrame时候调用,但是rect的值不能为CGRectZero。

- (instancetype)initWithFrame:(CGRect)frame NS_DESIGNATED_INITIALIZER;

2、标记为需要显示,下次drawing cycle自动调用。

- (void)setNeedsDisplay;

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对小牛知识库的支持。

 类似资料:
  • 我已经启动了一个新的android studio项目,在打开主活动时,design视图显示了这个错误,并且没有显示模拟器上的布局: org.jetbrains.android.uipreview.renderingException:在org.jetbrains.android.uipreview.layoutLibraryLoader.load(LayoutLibraryLoader.java:

  • Rails 布局和视图渲染 本文介绍 Action Controller 和 Action View 中布局的基本功能。 读完本文,你将学到: 如何使用 Rails 内建的各种渲染方法; 如何创建具有多个内容区域的布局; 如何使用局部视图去除重复; 如何使用嵌套布局(子模板); 1 概览:各组件之间的协作 本文关注 MVC 架构中控制器和视图之间的交互。你可能已经知道,控制器的作用是处理请求,但经

  • 我有最新的SDK构建工具(21.0.2)以及完整的API21下载和安装。我的targetSDKVersion在gradle文件中设置为21。如果我把预览改为用API20渲染,一切似乎都很好。下面提供了异常详细信息。 谢了! 异常详细信息java.lang.ClassNotFoundException:Android.support.v4.content.contextCompatapi21 · 在

  • 我有一个带有对象数组的组件,其中我正在根据字符串进行过滤。问题是当我尝试将此过滤器的返回设置为本地状态时,它会抛出错误,我不太理解原因。 所以,因为我希望这个数组处于我的状态,所以我决定这样做: 插入这一行后发生的事情是这样的: 它开始多次渲染。我假设,每次状态改变时,它都会重新渲染组件(如果我错了,请纠正我)。不过,我不知道它为什么要多次这样做。 因此,我想过使用 useEffect 来实现此处

  • 问题内容: 我正在尝试使用setState()方法将容器中的React状态变量重置为默认值。但是出现以下错误 最后:超出最大调用堆栈大小。 我的代码如下: 当Redux状态的变量为true时,我正在调用resetMsg()。 我在其中调用resetMsg的代码(resetMessages的值最初为false,当它为true时,我需要重置React状态): 问题答案: 您可能要研究功能。根据官方文档

  • 本文向大家介绍Android布局之表格布局TableLayout详解,包括了Android布局之表格布局TableLayout详解的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android表格布局TableLayout的具体代码,供大家参考,具体内容如下 1.TableLayout TableLayout表格布局模型以行列的形式管理子控件,每一行为一个TableRow的对象, 当