`

AdobeMax: Deep Dive into Flash Player Rendering

 
阅读更多

from http://www.developria.com/2010/10/adobemax-deep-dive-into-flash.html

 

AdobeMax: Deep Dive into Flash Player Rendering

Introduction

For those unable to attend, my first session is the Deep Dive into Flash Player Rendering. This seems to be an extremely misunderstood topic and likely will be a great thing to have a deeper understanding in. This is a very complex process and is worth taking some of the concepts mentioned below and doing some further research in. There apparently is a lighter IP ruling by Adobe behind their FlashPlayer and they are exposing more information about how their FlashPlayer code works.

The presenter is Lee Thomason and is a Flash Player Architect at Adobe. He is also a principle scientist at Adobe and architect for the Flash Player.

Topics of this class

Four stages of rendering for Flash Player

  1. Computation
  2. Edge and Color Creation
  3. Rasterization
  4. Presentation
Computation

During computation the display list has a retained renderer. The invalidated objects are walked to determine which ones are dirty. All objects are considered "SObjects" to the flash player and mutate based on the contents of the object. For example a object with a timeline will have more memory consumed than an object without a timeline.

Performance advice

  1. Balance
  2. Size - minimize the number of SObjects in memory
  3. Shape vs Sprite - Favor Shapes over Sprites
  4. Show Redraw Regions - Check the redraw regions regularly to check to make sure you are expecting what you see redrawing.


Edge and Color Creation

All edges in the player are represented as Bezier curves. There are some performance concerns around Edges. Edge to pixel ratio is the major concern when art is shrunken to a small pinhead or automatic conversion of art via a tool. The bottleneck in the player for edges is not in the Edge and Color creation, but during the Rasterization step.

After the computation step occurs but before the edge and color creation occurs there is a stroke that occurs as a seperate layer in the SObject. Stroke generation is extremely complicated and he is more or less sidestepping this portion of the explanation.

Color and Fill are represented as the same thing, they are defined on the same plane. Transforms are applied to edges and the fill independently of each other during a transform/animation.

The following are examples of color types

  1. Solid
  2. Bitmap
  3. 2.5D Bitmap
  4. Video
  5. Causes special timing
  6. Gradients
  7. Text
  8. PixelBender 2d
  9. Mask
  10. Special Color that clips other colors

Scale 9 is the Scale 9 Grid on Display object. It is a non-linear edge transformation. It can not be defined in a single Matrix to define its transformation, it is actually represented as 9 separate matrices. Color fills are represented as one matrix transformation.

All of the examples of Scale 9 will be posted by Lee and I will follow up with a comment later.

Rasterization

Rasterization is a back buffer operation and occurs once per dirty rectangle per scan line (or horizontal row of pixels). The best takeaway from this according to Lee is that the render occurs top to bottom left to right pixel by pixel.

Rasterization in general excludes hidden objects and each pixel is touched only once. Spans (which are the runs of pixels that have no change since the last resterization) are solid colors or opaque objects. There are occasions where sub pixel computations occur when edges are started/ended in the same pixel. There is nothing that can be done to optimize for this behavior as it is deep within the Flash Player. Basically the comment here seems to be that transparent bitmaps can significantly cause render problems since you are causing the rasterization step to do computation when it doesn't even display anything for the transparent pixels.

More pixels is of course more rasterization, however fullScreenSourceRect can improve performance by reducing quality due to the hardware scaling.

Presentation

The presentation approach is changing, because dirty rectangle calculation is changing. WMode is the setting that impacts presentation. There are three modes, normal where our own version software surface. WMode = transparent or opaque defeats dirty rectangles and forces full redraws. WMode = direct uses hardware surface and can dramatically increase performance. This seems like something worth trying, but one of the edge cases could be applications with lots of changing text that will not be impacted positively by this mode.

Tearing is primarily presentation sync. There are subtle cases, video updates and split blits. Tearing is going away with hardware compositing. As modern browsers expose the GPU stack of video cards a lot of these problems go away.

Surface Rendering

Surface happens when you use cacheAsBitmap, Filters, 2.5D and scroll rect with opaque backgrounds. This causes a different set of computations to occur during the presentation phase of the process. It adds a composition phase that occurs before presentation when pixels are written to the back buffer.

New Stuff

StageVideo and Stage3D are new features of the Flash Player that run behind the DisplayList. They have their own hardware surfaces and independent rendering planes. This allows the FlashPlayer to not impact DisplayList objects with 3d objects in either StageVideo or Stage3D. The StageVideo is the lowest level stage and the Stage3d sits atop it. The DisplayList we all know and love is on top of both of those.

GPU Rendering obeys all the rendering rules and does draw hidden objects and follows a different appraoch.

In conclusion here is a cheat sheet

Fundamental=Computation->Edges & colors -> Rasterization -> Presentation

  • Show redraw regison gives insights into display list
  • Edges and colors are primitives of rendering
  • Beware alpha and per pixel comutation
  • Presentation is changing
  • Surface=... -> Rasterization -> Processing -> Compositing
  • Remeber the cache!
  • Direct Mode Planes are fast but separate
  • GPU Rendering: same rules, different approach
  • These guys blog here http://www.bytearray.org/
  • Please follow me on twitter here: http://twitter.com/neosavvy
  • Check out my company's website here http:///www.neosavvy.com
分享到:
评论

相关推荐

    Programming iOS 12: Dive Deep into Views, View Controllers, and Frameworks

    《Programming iOS 12: Dive Deep into Views, View Controllers, and Frameworks》是一本专为进阶学习者设计的书籍,旨在深入探索苹果iOS 12操作系统中的视图、视图控制器以及各种框架的编程技术。这本书涵盖了iOS...

    Programming iOS 10 Dive Deep into Views epub 0分

    Programming iOS 10 Dive Deep into Views View Controllers and Frameworks 英文epub

    Transformers for Machine Learning A Deep Dive

    Transformers for Machine Learning A Deep Dive

    Deep Dive into Android IPC-Binder Framework

    Android是一个广泛使用的开源操作系统,用于智能手机和平板电脑等移动设备。它由Google领导开发,并且基于Linux内核。在Android系统中,各种应用程序和系统服务之间进行交互和通信的方式,称为进程间通信(IPC)。...

    Deep Dive into Android IPC & Binder.pdf

    Deep Dive into Android IPC & Binder.pdf Deep Dive into Android IPC/Binder Framework at Android Builders Summit 2013 Binder Overview IPC Advantages of Binder Binder vs Intent/ContentProvider/...

    Deepdive教程1.pdf

    根据提供的文件信息,下面是关于Deepdive使用方法和编程方法的详细知识点介绍。 知识点一:Deepdive概述 Deepdive是一个开源的自然语言增强数据库,它支持大规模地进行数据抽取和知识库构建。通过将数据抽取、特征...

    building-data-streaming-applications-apache-kafka

    Chapter 3: Deep Dive into Kafka Producers Chapter 4: Deep Dive into Kafka Consumers Chapter 5: Building Spark Streaming Applications with Kafka Chapter 6: Building Storm Applications with Kafka ...

    A Deep Dive into Stateful Stream Processing in Structured Streaming

    A Deep Dive into Stateful Stream Processing in Structured Streaming A Deep Dive into Stateful Stream Processing in Structured Streaming

    Programming iOS 10: Dive Deep into Views, View Controllers, and Frameworks

    "Programming iOS 10: Dive Deep into Views, View Controllers, and Frameworks" English | 2016 | ISBN: 1491970162 | [Early Release] If you’re grounded in the basics of Swift, Xcode, and the Cocoa ...

    信息安全_数据安全_Safari Adventure:A Dive into App.pdf

    本文以“Safari Adventure:A Dive into App安全体系”为背景,深入探讨了网络环境中的安全挑战、漏洞挖掘、安全对抗和安全分析策略,以及如何构建有效的安全防御系统。 首先,我们要理解App安全体系的核心是保护...

    CNdeepdive:DeepDive 中文教程

    支持中文的deepdive:斯坦福大学的开源知识抽取工具(三元组抽取) deepdive是由斯坦福大学InfoLab实验室开发的一个开源知识抽取系统。它通过弱监督学习,从非结构化的文本中抽取结构化的关系数据 。本项目修改了...

    DeepDive教程2.pdf

    DeepDive是一款用于数据密集型知识发现的系统,它可以从大规模文本数据中抽取结构化信息,并在此过程中提供自然语言处理的实体及关系抽取功能。本教程主要涵盖了DeepDive的使用和编程方法,其中详细讲解了DeepDive的...

    Dive into Deep Learning

    deep learning has taken the world by surprise, driving rapid progress in fields as diverse as computer vision, natural language processing, automatic speech recognition, reinforcement learning, and ...

    Kubernetes : Up and Running: Dive into the Future of Infrastructure

    《Kubernetes: Up and Running: Dive into the Future of Infrastructure》这本书深入浅出地介绍了Kubernetes这一引领基础设施未来的强大容器编排系统。Kubernetes,通常简称为K8s,是Google开源的一个容器管理系统...

    deepdive_tutorial

    本篇文档将详细介绍DeepDive的安装、配置和使用,以及在构建公司实体间股权交易关系知识图谱的项目中如何运用DeepDive进行数据抽取和处理。 首先,进行环境准备工作。DeepDive的安装包括下载CNDeepDive,并运行安装...

    Deep Dive into Neutron

    标题:“深入剖析Neutron”,描述:“OpenStack Summit HK 2013 @UnitedStack 龚永生的分享,深入剖析Neutron。”,标签:OpenStack Neutron Networking,这些信息表明本篇文档的主要内容是关于Neutron——OpenStack...

    deep-dive:Deep Dive的源代码

    "Deep Dive: 深入理解JavaScript源代码分析" 在编程世界中,深入探究源代码是提升技术能力的重要途径,特别是在像JavaScript这样的广泛使用的语言中。"Deep Dive"项目提供了一个绝佳的机会,让我们能够深入了解...

Global site tag (gtag.js) - Google Analytics