博客
关于我
iOS面试题:什么是离屏渲染?什么情况下会触发?该如何应对?
阅读量:518 次
发布时间:2019-03-07

本文共 1046 字,大约阅读时间需要 3 分钟。

离屏渲染(Off-Screen Rendering)是一种常见的图形处理技术,主要用于某些特定场景下的渲染工作。在整个渲染过程中,离屏渲染会在当前屏幕缓冲区之外开辟一个新的缓冲区进行操作。这种方式能有效支持一些需要复杂图形处理的场景,比如圆角处理、图层蒙版、阴影渲染以及光栅化操作。

为什么离屏渲染会被触发?

这些离屏渲染的触发通常与两个核心因素有关:

  • 图层属性触发

    • 圆角处理:如果设置了 masksToBounds = YEScornerRadius 大于0,那么这时候会触发离屏渲染。
    • 蒙层遮挡:如果图层设置了 layer.mask,也会触发离屏渲染。
    • 光栅化:在某些情况下,尤其是当需要进行深度的光栅化处理时,也会触发离屏渲染。
  • 阴影渲染

    阴影的处理虽然会触发离屏渲染,但如果使用了 shadowPath 属性,则可能不会引发离屏渲染。最终的效果是根据具体的实现方式决定的。

  • 需要注意的是,某些操作会强制使用离屏渲染以确保图形的正确显示。例如,当使用CoreGraphics绘制带有圆角的图形时,也会触发离屏渲染。这种机制确保了结果的准确性,但也可能带来性能开销。

    为什么要避免离屏渲染?

    离屏渲染虽然可以提高渲染质量,但同时也会导致显著的性能开销。以下是主要的原因:

  • 上下文切换开销

    离屏渲染需要切换图形上下文环境。首先从当前屏幕上下文切换到离屏渲染的上下文,完成后又要切换回当前屏幕上下文。这种切换操作会额外消耗资源。

  • 显示同步延迟

    由于垂直同步(VSync)的机制,每个帧之间的处理必须严格符合显示器的刷新率。如果CPU或GPU在HSync时间内未能完成内容提交,帧会被丢弃,导致界面卡顿。

  • 帧优化问题

    不是所有场景都需要离屏渲染。特别是当只需要简单的渲染操作时,直接在当前屏幕缓冲区进行渲染会更加高效。

  • 离屏渲染的效益

    离屏渲染主要因为以下原因被设计出来的:

  • 图形处理复杂性

    某些图形特效(如圆角、蒙层遮挡、阴影、光栅化等)无法在当前屏幕缓冲区内高效完成。

  • 图形质量和稳定性

    离屏渲染能提供更高的渲染质量,同时确保图像的完整性和稳定性。

  • 不过,以今天 GPUs 的性能来看,用户应该尽可能避免使用离屏渲染。为了避免触发离屏渲染,可以暂时不设置需要圆角处理的图形属性,或者在不需要阴影效果的时候,不设置阴影。对于遮层操作,可以使用合成效果来实现,以减少离屏渲染的开销。

    总体而言,离屏渲染是一种强大的工具,但在优化用户体验时需要谨慎使用,避免不必要的性能开销。

    转载地址:http://lfdcz.baihongyu.com/

    你可能感兴趣的文章
    NIFI大数据进阶_FlowFile拓扑_对FlowFile内容和属性的修改删除添加_介绍和描述_以及实际操作---大数据之Nifi工作笔记0023
    查看>>
    NIFI大数据进阶_NIFI的模板和组的使用-介绍和实际操作_创建组_嵌套组_模板创建下载_导入---大数据之Nifi工作笔记0022
    查看>>
    NIFI大数据进阶_NIFI监控的强大功能介绍_处理器面板_进程组面板_summary监控_data_provenance事件源---大数据之Nifi工作笔记0025
    查看>>
    NIFI大数据进阶_NIFI集群知识点_集群的断开_重连_退役_卸载_总结---大数据之Nifi工作笔记0018
    查看>>
    NIFI大数据进阶_内嵌ZK模式集群1_搭建过程说明---大数据之Nifi工作笔记0015
    查看>>
    NIFI大数据进阶_外部ZK模式集群1_实际操作搭建NIFI外部ZK模式集群---大数据之Nifi工作笔记0017
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_01_实际操作---大数据之Nifi工作笔记0029
    查看>>
    NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
    查看>>
    NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
    查看>>
    NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
    查看>>
    NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
    查看>>
    NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
    查看>>
    NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
    查看>>
    NIH发布包含10600张CT图像数据库 为AI算法测试铺路
    查看>>
    Nim教程【十二】
    查看>>
    Nim游戏
    查看>>
    NIO ByteBuffer实现原理
    查看>>
    Nio ByteBuffer组件读写指针切换原理与常用方法
    查看>>
    NIO Selector实现原理
    查看>>
    nio 中channel和buffer的基本使用
    查看>>