- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
编辑:原来的问题仍然包含在下面,但我决定重新命名为一种在各种情况下对开发人员更有用的表格,其中一些在我下面的回答中有所描述,作为解决原来的问题提供了更广泛的应用领域。
我有一组应用程序的灰度图标,并且要求用户可以更改图标颜色。
因此,显而易见的解决方案是使用 QtGraphicalEffects
中的常用 Colorize
元素。
效果本身有一个 cached
属性——它缓存那个特定效果的结果,这样它就不会被连续计算。然而,这仅适用于该效果的特定实例,这意味着如果有多个图标实例,并且每个图标实例都有着色效果,则此缓存将不会在不同实例之间共享。
显然,一个缓存就足够了,考虑到所有图标的大小和颜色都相同,来自 VRAM 的数据可以重复使用,从而节省 VRAM 和 GPU 时间。
所以最大的问题是如何重用单个效果的单个缓存并在没有任何开销的情况下多次显示它。
此外,上一个问题是关于我目前学习的图标着色类(class)。但是,我可能还缺少另一种方法。
当然,效率是关键,但也需要简单,我的意思是我可以想出几种低级的方法来非常有效地做到这一点,但它们都需要更复杂的低级实现,它们在 QML 中是不可能实现的。
最佳答案
事实证明,解决方案出乎意料地简单。
在这种情况下,特定于 OP - 即为图标着色,最有效的方法是简单地使用自定义 ShaderEffect
和 trivial 片段着色器 - 设置 gl_FragColor
到所需的颜色,作为 vec4
和来自源图像的 alpha 值传递。真的不需要缓存任何东西,因为着色器非常简单和快速,尽可能快。
只有一件事需要考虑——QML 场景图可能会在纹理图集中分配原始图像,默认实现会将纹理从图集中复制到另一个纹理。我们不希望这样做,因为它违背了目的——VRAM 的使用会增加,因为这将对每个“实例”完成,并且新分配的纹理也有可能比它们需要的更大是的,因为在某些平台上,纹理可以有多小是有限制的,在这种情况下我们谈论的是图标,所以它们不会那么大。
解决方案是将 supportsAtlasTextures
显式设置为 true。这意味着您还必须在图集中传递纹理的偏移量并计算偏移量——开销仍然很小。这将确保效率,来自图集的纹理不会在内存中重复,此外,渲染引擎实际上将允许使用来自同一图集的不同纹理的不同着色器效果在一次调用中一起批处理。
可以使用类似的方法来缓存几乎所有内容,并使用该缓存来显示“图像”——使用 ShaderEffectSource
来“捕获”所需的图像,然后使用 ShaderEffect
具有更简单的片段着色器 - 只需从源采样器输出数据。立即想到几个非常有用的用例:
ShaderEffectSource
和 ShaderEffect
可以按任意顺序链接它可以用作图像,由复杂的 QML Item
组合生成 - 这些实际上占用大量 RAM,想象一下您有 1000 个对象的场景,并且它们中的每一个都由 20 个不同的 QML 项目组成——矩形、文本、图像、上帝保佑动画,这是内存中的 20000 个对象——根据我的测试,这相当于 500 MB 的 RAM 使用,但如果它们相同,单个对象可以用于提供缓存,所有其他对象只能使用单个着色器效果来显示该缓存。它对 CPU 时间也有影响——比如你的设计必然会改变值——这是一个非常常见的场景,如果你在内存中有 20000 个对象,那就是 20000 个评估的绑定(bind)——即使是微不足道的表达式,这在移动设备上也可能需要几秒钟,在这段时间内卡住屏幕。将卡住时间减少 1000 倍的缓存,几乎不存在。
它也可以用来缓存和实例化动画,显着减少所需的 CPU 时间,它也可以处理视频
关于image - 使用任意 QML 项作为缓存图像源,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35025386/
语境 我正在将一个旧的 php 电子商务网站变成一个用 gatsby.js 构建的静态网站。 我将所有产品元数据放入单独的 .json 文件(每个产品一个),并且我能够使用 json 和文件转换器插件
我曾经能够使用三指向上滚动在源/标题之间切换。自从升级到 Lion 后,我只进行常规滚动。有没有办法恢复该功能? Aka,当我像以前那样向上/向下滚动时,它不会跳到对应的位置。 更新 Apple 在
我有一个包含复选框输入的克隆元素。当克隆的元素未被选中时,我需要也取消选中源元素。有没有办法在 jQuery 中做到这一点?或者我是否以错误的方式处理这个问题(即使用clone())?我应该提到我的问
我有一个类,其中有两个 JSpinner 对象,x 和 y。我有一个更改监听器,它已添加到两者中。有人可以告诉我如何实现我的更改监听器,以便监听器可以区分两个对象之间的区别。例如伪代码: if(sou
我正在编写涉及 for 循环的代码,该循环在每个索引处进行计算。 这些计算中的最小值存储在一个变量中,我在程序末尾使用 MPI_Allreduce 来确定所有进程的全局最小值。 但是,我需要一种方法来
我需要在一个 Android 项目中创建一个 map View ,我从服务器获取自定义 map 图 block PNG。有人知道实现此类功能的简单许可 API 吗? 最佳答案 我使用了 OsmDroi
因为我必须创建一个可以更改图像 (src/background-url) 的函数。我想知道如何识别标签以及它是使用 src 还是 url 来访问图像。 让我们说 早些时候我写了一个可以
当我使用源 map 浏览器 https://github.com/danvk/source-map-explorer要检查捆绑包中的内容,我得到以下输出: D:\projects\angular\mT
我正在为客户将 Windev 应用程序移植到 Objective-C。出于显而易见的原因,使用以前的源代码会更简单。 不幸的是,它是加密的,我需要 EDI 才能看到它;完整版的 Windev 太贵了(
我有一个简单的视频播放器,它使用 WPF MediaElement 播放一系列视频。这些视频一起形成一个围绕静止图像移动的连续电影。在每个视频结束时,运动会卡住在当前播放视频的最后一帧。当我按下一个按
我需要更改 openlayer 的图层源(使用 open weather api)。目前我正在使用以下代码但没有成功。 let layer = this.map.getLayers().getArra
我正在尝试在 /dev/random 的机器上运行代码不会很快填满,我正在尝试使用的 Java 程序因缺少随机数而挂起。/dev/urandom产生“不太好”的随机数,但不会阻塞,对于这种情况,我宁愿
我需要 Yocto 项目的源代码包。我已经拥有整个项目的所有资源,但它们还包括开发工具。 我想有一种方法来生成将为目标图像构建的所有包的(修补的)源。因此,例如,如果目标图像包含 busybox,我想
如何对入侵者隐藏 iFrame src 假设我正在流式传输我的网络摄像头或我的电脑屏幕,这是 iframe 代码: 并且我不希望它在大多数浏览器上显示页面源中的流 URL 和检查功能! 这意
是否可以进入 Qt 源,例如qmainwindow.cpp,在 Qt Creator 中?目前我正在看到反汇编,但最好能看到源代码。 最佳答案 当然!但您可能必须首先: 转到 $QT_HOME/qt
我正在尝试创建一个包含很少动漫剧集的简单网站。我有一个关于 javascript 的问题。如何通过单击我的链接之一来更改视频源?我明白,我必须使用事件监听器,只需更改 取决于我点击的链接,但我不太擅长
我有一个带有 BindingSouce 的 DevExpress GridControl。我想清除 BindingSource 并用新数据填充它。我这样做: var list = new List()
当单击提交输入按钮时,我尝试将其他参数(选定复选框的列表)传递到服务器处理的 DataTables 表#my_table: 这可能意味着我必须将 my_table.sAjaxSource 设置为后端脚
(好吧,别对我大喊大叫,这里已经很晚了:)) 我正在研究 delta diff 工具(命令行工具或组件,只要我可以从 Delphi 2010 调用它们就可以了) 我有这个项目,我将文件上传到服务器,我
我需要解析 Yahoo Weather RSS feed 中的某个位置,例如 http://weather.yahooapis.com/forecastrss?w=44418&u=c例如,获取最高、最
我是一名优秀的程序员,十分优秀!