- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是一道理解二维矢量图GPU加速渲染原理的题。
使用 Skia 或 Direct2D,您可以绘制例如圆角矩形,贝塞尔曲线,多边形,还有一些效果,比如模糊。
Skia/Direct2D 提供基于 CPU 和 GPU 的渲染。
对于 CPU 渲染,我或多或少可以想象呈现一个圆角矩形。我已经见过很多不同的线条渲染算法。
但是对于 GPU,我没有太多线索。
是否有一些基本示例可以向我展示这些东西如何工作的基本原理?
(可能,解决方案也可以在 Skia 的源代码中找到,但我担心它会太复杂/通用,以至于像我这样的菜鸟不会理解任何东西。)
最佳答案
在 direct2d 的情况下,没有源代码,但由于它在引擎盖下使用 d3d10/11,所以很容易看到它在幕后使用 Renderdoc 做了什么。
基本上,d2d 倾向于通过尝试将任何几何类型放入单个缓冲区来最小化绘制调用,而 skia 则根据形状类型具有一些专用着色器集。
因此,例如,如果您绘制一条贝塞尔曲线路径,Skia 将在可能的情况下尝试使用曲面分割着色器(如果您之前渲染的元素是矩形,则需要一个新的绘制调用),因为您更改了管道状态。
另一方面,D2D 倾向于在 CPU 上分割,并推送到某个顶点缓冲区,并且仅当您更改画笔类型时才切换绘制调用(如果您从一种纯色画笔更改为另一种,它可以保持相同的着色器,所以它不会切换),或者当缓冲区已满,或者如果您从形状切换到文本(因为它随后需要发送纹理图集)。
请注意,当分割贝塞尔曲线路径时,D2D 在使生成的几何体非自相交方面做了非常出色的工作(因此即使在一些复杂的自相交路径上,alpha 混合也能正常工作)。
在圆角矩形的情况下,它做同样的事情,只是镶嵌成三角形。
这允许它在很大程度上减少绘制调用,并允许在非 msaa 表面上进行抗锯齿(这是在网格级别完成的,带有一些带 alpha 的小三角形)。它的缺点是它没有使用太多的硬件功能,并且发出的几何图形可能非常高,即使对于看似简单的形状也是如此。
由于 d2d 更喜欢使用三角形带或三角形列表,因此在绘制简单的三角形列表时它可以做一些非常有趣的事情。
对于文本,d2d 使用实例化并为每个字符绘制一个实例化的四边形,它也擅长对这些进行批处理,因此如果您连续多次调用某些绘制文本函数,它会尝试将其合并为一个调用,如下所示好吧。
关于graphics - Skia 或 Direct2D 如何使用 GPU 渲染线或多边形?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69329652/
我想知道如何在 OCaml 中设置文本大小。我尝试了 Graphics.set_text_size,我猜这应该可以解决问题。 但是无论我输入 set_text_size 200 还是 set_text
我想使用mathematica 为我正在写的书绘制图表。我想在mathematica中画一个图,将其保存为图片,然后将其导入到quarkxpress中,最后将其导出为pdf。 我的问题是最好使用哪种格
在顶层加载 Graphics 模块时,我收到一条错误消息“找不到 graphics.cma”。 我使用的是 OS X,而且我很确定我已经正确安装了 OCaml,因为我已经使用了大约一个月了。所以看起来
我知道 DDS 文件的存在,允许在 as/400 上对显示图形进行编程,但是还有其他方法吗? 具体来说,我想要做的是直接操作终端缓冲区,以便能够显示除文本之外的任何其他内容。例如,终端如下所示: 假设
Graphics.Save 与 Graphics.BeginContainer 有何不同? 最佳答案 看看here : The documentation does not differentiate
由于 Gdiplus::Graphics::DrawGraphics(Graphics*, x, y) 不存在,执行此类操作的最佳方法是什么? 例如,创建一个 Graphics 对象,使用各种 Dra
你能看出这有什么问题吗: (define (box d x1 y1 x2 y2) ( (graphics-draw-line d x1 y
我想编写一个 2D 游戏引擎。我遇到的问题(我不使用opengl之类的东西,所以我用cpu渲染)是,我通过graphics.drawImage()只得到7fps;您有任何加快速度的建议或其他替代方案吗
我在某些代码中发现了渲染错误,并找到了解决方法,但我想知道为什么我会得到不同的行为。在旧代码中,背景(有时)会呈现为白色,尽管在调试时 getBackground() 会返回正确的颜色。 旧代码: @
有谁知道是否有办法(也许通过外部API)将图形绘图/转换为多个图形?这个想法是同时保存 PNG 和 PDF(使用 Java IText 库)。 最佳答案 您可以将 Graphics 对象写入(java
我试图了解如何在英特尔芯片组上以 x86 保护模式绘制简单图形。我已经(有点)知道如何使用 VGA 接口(interface)来做到这一点,并且我正在尝试了解如何使用 G35 Express 来做到这
在我的应用程序中,我生成了一个条形码图像,该图像是根据用户使用 OpenFileDialog 上传的文件中的数据生成的。我的目标是允许用户在屏幕上查看条形码数据和图像本身,打印并使他们能够将两者保存为
我是 Java 新手,我只是想得到一些简单的东西,可能类似于 Zelle's graphics对于Python。 最佳答案 Java 类 Graphics和 Graphics2D应该包含 Zelle
如何将 FMX.Graphics.TBitmap 转换为 VCL.Graphics.TBitmap 或 Vcl.Imaging.PngImage.TPngImage? 我的项目中有FMX表单和VCL表
我需要找到用于间距目的的字体大小,发现这很有帮助:https://docs.oracle.com/javase/tutorial/2d/text/measuringtext.html 但是,我不确定如
我有一点奇怪的错误是由一个看似简单的问题引起的。 在我的源代码中,我尝试使用 QQuickPaintedItem 来呈现 QWidget 派生类 (QPushButton) 的整体外观,然后将其绘制到
我正在尝试通过具有以下规范的设备来解决 Android 应用程序崩溃的问题: Device PAP3400DUO 1 Manufacturer — Android version Android 4.
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 9 年前。 Improve this ques
我有这行代码: mBgTransition = (TransitionDrawable) mSwitchBg.getBackground(); 背景曾经是一个常规的可绘制对象, 但现在是 9 个补丁
当我的应用程序在启动时崩溃时尝试实现自适应图标时出现此错误。 我无法想象为什么会收到此错误,因为在下面错误日志中提到的文件(MainActivity 和 BaseActivity)中,我没有使用Ada
我是一名优秀的程序员,十分优秀!