- 使用 Spring Initializr 创建 Spring Boot 应用程序
- 在Spring Boot中配置Cassandra
- 在 Spring Boot 上配置 Tomcat 连接池
- 将Camel消息路由到嵌入WildFly的Artemis上
ThreeJS 会淘汰吗?
ThreeJS、BabylonJS 两个应用级 3D 库一直在设计 WebGPU 为底层的新渲染器,后者尤为积极。
什么是应用级?这两个库都屏蔽了 WebGL 的底层调用细节,大多数时候,你编写的代码更专注于“场景”中的“三维物体”的位置,加载“模型文件”,高级点的会写漂亮的“材质”。这些带引号的概念,在 WebGL 底层接口都是没有的,是实时渲染技术的一些概念在 JavaScript 中的实现。
如果你是应用级别的开发者,不关心这些库如何封装底层图形 API,那现在大可不必入场,等正式发布再了解也不迟,毕竟这两个受众这么广的库,为了保持稳定性,在上层封装上不会短时间内进行激进改动。
WebGL 会淘汰吗?WebGL 是不是过时了?
短时间内不会,至少 10 年内。不信你看看 Java8?(开个玩笑)
WebGL 1.0 发布至今已有 10 年,完全落实 WebGL 2.0 的实现也才一年(截至发文),有很多作品、程序依旧在用基于 WebGL 技术族运行着,发光发热。借用马克思主义哲学的一个原理,是说“旧事物在它的作用没有完全发挥出来之前是绝不会自行消亡的,旧事物当中除了消极因素,依然存在积极因素”。
WebGL 的“全局状态”机制继承自 OpenGL,有大量的资料可供查询,大量的案例仍存于互联网中。
WebGPU 的性能是不是比 WebGL 强?
有一部分人被 WebGPU 吸引过来的原因是“跨平台 + 性能”这对组合。
诚然,WebGL 对比 Canvas2D 绘图技术的性能,是直接碾压的,在这十年中给 Web 前端带来了高性能的可能,但是长时间的实践下来,有的人发现了“WebGL 程序有时候,并不是那么快,甚至卡的要死”,他们 也许不会深究底层原因,直接寄希望于一个他们认为的新的王:WebGPU,这其实是一种很不唯物主义的、非常唯心主观的看法。
WebGPU 从设计上来看,确实有不少特征是优于 WebGL 的,列举如下:
但是这些仅仅是在底层的对话基础上比 WebGL 强,这些底层解决的问题,不一定是有的朋友的“性能问题”。譬如,在应用层、代码逻辑层可能会有这些原因导致了“性能问题”:
所以说,一味寄希望于新的王,而不从实际出发审视问题,是解决不了问题的。
WebGPU 什么时候能用?
WebGPU 标准是多个大技术团体相互制衡、妥协的产物,包括但不限于微软、苹果、谷歌等。官方一直在拖延 1.0 版本的发布时间,保守估计 2022 年第四季度上线三大浏览器正式版是最快的结果了,不保守估计可能还要到 2023 年上半年。
怎么才能用 WebGPU?
当前,推荐在以下 PC 端浏览器试用 WebGPU 及其着色器语言 WGSL:
虽然正式频道也能用,但是在没发布 1.0 版本之前,都要去申请一个 Origin Trial Token 写在 HTML 代码中,笔者觉得麻烦,当然读者也可以选择配置这个在正式版浏览器中使用。
移动端、Linux 系统恐怕还要等好久(5年后?)。
我学习 WebGPU 需要什么条件?
学习 WebGPU,你要有这样的硬件储备:
你还需要这样的编程知识储备:
const/let
、箭头函数、类、反引号字符串、PromiseAPI,最好能用到 ES7 的异步语法 async/await
;你可能不需要掌握,但是会了如虎添翼的技能:
WebGPU 有什么用?
WebGPU 是一个跨平台的图形 API 规范,目前能提供的功能有:
前文提及的“计算管线”对应这里的第二点,而沿袭自 WebGL —— 准确的说 GPU 从 CPU 分离之初的首要目的,即“渲染绘图”功能,则是对应了 WebGPU 的“渲染管线”。
我认为,WebGPU 最大的作用可能并不体现在渲染管线上,毕竟它只是对三大原生图形 API 的封装,渲染这方面由 WebGL 实践了这些年,在浏览器上的表现可能已经没有特别惊艳的效果提升了,解决的应该只是 1.1 小节中的各种底层问题;
最大的作用反而应该是较之于 WebGL 更易用的 GPU 并行计算功能,也就是计算管线的新设计。
补充 1.1 小节中 WebGPU 比 WebGL 更先进的 2 个点:
第一点就是 WebGPU 计算管线的底气。
当下,使用 GPU 进行深度学习、机器学习的应用有不少,以往想通过 JavaScript 来完成 GPGPU 实在是太麻烦了。WebGPU 允许更好地摆脱浏览器环境 —— 当然,在浏览器环境中,我也可以不参与绘图,使用计算管线就可以做出很多有趣的事情来,不仅仅是 DL、ML。
读者可能知道,如果不知道就当听故事,除了浏览器、NodeJS,有一个叫 Deno 的工具也是 JavaScript 的运行时,它内置了 Firefox 浏览器的 WebGPU 实现成果,也就是 Wgpu 库,Wgpu 使用 Rust 语言实现 WebGPU 规范。
也就是说,Deno 是可以运行 WebGPU 的,虽然它不具备浏览器的多数功能,但是它就是能调起 WebGPU,调用计算管线,完成并行计算。
WebGPU 的实现还有几个,Chrome 和 Edge 在用的是 Google 的 Dawn 项目,使用 C++ 实现 WebGPU 规范,苹果 Safari 是自己家的内核更新实现 —— 这些就是浏览器能调用三大图形 API 的底层原因。
如果你愿意,你也可以把 Dawn 或者 Wgpu 拉下来,直接使用 C++ 或 Rust 来调用这些实现,而不是要经过 JavaScript 运行环境。
它解决了什么问题?
在 1.1 小节和本小节已做出解释,它解决的是 WebGL 长期以来的底层技术问题,把各大厂商安顿好了,在图形技术上达成了一致,建立起新的技术垄断(不是
这个问题和“会用厨具能不能做出一桌好菜”一样。
WebGPU 和 WebGL,甚至底层的 D3D、Metal、Vulkan 乃至 OpenGL 一样,只是一套调用 GPU 的接口。想要从机械的 GPU 绘图动作,枯燥的 Buffer、纹理贴图、状态值中实现光彩夺目、栩栩如生的渲染效果,还需要结合实时渲染(RealTimeRendering)、图像处理、光线追踪等众多技术。
有一个分享着色器特效的网站,叫 Shadertoy,上面有很多使用片元着色器实现的好看效果,这就是一个典型的例子,它就没有让开发者写什么 WebGL、WebGPU、ThreeJS,你只需要遵守它的规则,就可以实现很多好看的东西 —— 前提是,这些实现,都是基于上面说的非 API 技术的。
例如,下面几个入门、进阶“效果”,严格来说与 WebGL、WebGPU 这些图形 API 无关:
虽然无关,但是实现起来或多或少离不开这些图形 API —— 我想说的是看待的时候应该界限分明,学的时候又不应该孤立看待。WebGPU 作为一种跨平台标准,一种 API,它是工具属性,并不是“好看效果”的招牌、核心。
当然有。
所以,可预见的估计,哪怕今年年底能发布 1.0 版本,想要广泛应用这套标准于绘图渲染,保守估计都要等 3 年以上,用户的浏览器可能更新得并没有那么勤快。
这部分结合了唯物辩证法。
图形 API 应与实时渲染、图像处理等技术分开看待,但是不能忽略它们的紧密联系。
大多数人不缺综合的能力,而是缺少系统的分析的能力,不喜欢把事物细致剖析成各个具体的细小环节来研究。
就举两个例子:
分析和综合的功力,区别在于深浅、逻辑、科不科学、系不系统上。
简单的说,就是在合适的范围,说对应的语言。笔者曾经在讨论时遇到很多技术水平不对等的交流,举个例子:
轻量化三维模型以提高性能。
这句话是一句浓缩了很多技术细节的话:“轻量化”是一个可以由多阶段、多目的构成的技术栈,“性能”也有诸多因素构成,可以说是“抽象”。
但是很多工作执行时,虽然以抽象概念为引领,但是我们必须结合具体的条目、具体的细节、技术,才能完成抽象概念想达成的目的。
用机关枪式的提问方法:轻量化三维模型的什么?轻量化是压缩数据文件的体积吗?是减少三维模型的三角面,还是压缩贴图,还是使用更高效的信息编码技术?
“性能”如何定义?是帧速率、网络请求并发量、内存占用量、网络传输时间?
总而言之,抽象的概念就应该在大的领域定向,而在小的范围内应该定量、具体地沟通与交流。
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界. 这篇CFSDN的博客文章dede会员列表调用适用于企业、个人由作者收集整理,如果你对这篇文章有兴
如何在 MySQL 中创建个人组消息传递的消息对话架构。是否有可能创建以下场景。 已读/未读 如果用户删除对话不影响其他对话。(例如用户 A 和 B 有消息对话 A 清除消息,则 B 消息不应影响)
是否可以将一些数据存储在您的个人 github 页面的某个位置? 例如触发计数器的按钮。当您单击该按钮时,计数器会加 1。当其他用户访问该页面并单击该按钮时,计数器会再次加 1。 因此它将是页面上显示
我正在编写一个守护程序应用程序来使用 Outlook Mail REST API ( https://learn.microsoft.com/en-us/previous-versions/offic
我的电脑有两个外置声卡和一个在带有 windows vista 的主板上。在 Vista 中,它看到同一个声卡的两个实体,一个数字输出和一个模拟输出。 当我尝试播放带有数字音频的视频文件时,比如 dv
我有一个个人 Apple 开发者计划,我希望我的 friend 帮助我开发我的应用程序。我的 friend ,他自己有一个个人 Apple 开发者计划,所以他创建了一个新的 Apple ID,我将他的
我知道您可以编辑在 tumblr 博客上呈现所有帖子博客主页的 html/AngularJS。但是,有没有办法添加自定义 ...到个别职位?我想在逐个帖子的基础上做一些 javascript 的事情,
首先,我想提前感谢您在此问题上提供的任何帮助。 Valgrind下面粘贴的输出源自以下单行 C 代码。 for( j=i;jsize-1;j++ ) s3->delete_tail( s3 ); 但是
我有几个服务器在测试环境中运行我有一个 CA 并且可以认证一个页面。 是否可以为从我收到的 CA 派生的测试环境创建我自己的 CA? 最佳答案 您可以使用 java 开发工具 keytool 在将要运
我正在尝试实现 custom UITabbar . 我发现的任何东西都涉及在 tabbarItem 上覆盖一个矩形。那么有什么直接的方法可以做到这一点吗? 最佳答案 要更改单个 tabBar 项目的色
我读了git book但不知何故忘记了rule上面写着: Do not rebase commits that you have pushed to a public repository. If y
我在工作中使用 BitKeeper,我想在家里为自己做一个基本的代码备份(考虑到我很少备份) //我以前从未使用过 git,所以我需要很多帮助 我认为在我的家庭服务器上有一个 git 存储库可能是个好
我必须处理大量扫描的 ID,我需要从中提取照片以进行进一步处理。这是一个虚构的例子: 问题是扫描没有完全对齐(最多旋转 10 度)。所以我需要找到它们的位置,旋转它们并剪出照片。事实证明,这比我原先想
在下面的代码块中,有几个(故意的)错误,我的任务是找到它们并解释这些错误是否会导致编译代码时出现问题,或者至少会导致一些逻辑问题。 public class Person { private St
一个 friend 给了我这个问题作为挑战,我试图在 LeetCode 上找到这样的问题,但很遗憾没有找到。 问题 Given a line of people numbered from 1 to
我有一个绑定(bind)到 VSTS 的公司帐户,以及一个绑定(bind)到同一电子邮件地址但作为个人帐户的 Azure 帐户。 VSTS 帐户:[email protected] (公司账户) Az
我刚刚创建了一个新的 MVC 项目并创建了一个空 View 。我在尝试声明 View 的模型时编写了第一行代码,如下所示: @model Personal; 其中,personal 是实际存在的模型
我是Kotlin的新手,我尝试理解所示的交换两个变量值的简短代码。 我不明白为什么它和b在Also函数中具有不同的值。他们不使用十进制值2引用相同的内存地址吗? 谢谢。 var a = 1 var b
我正在尝试查询与类/个人相关的所有 AnnotationAssertion。 下面是我的来源片段: #Car
我们目前正在使用威瑞信的时间戳服务,但时间戳服务器时常变得不可用 - 主要是由于我们的 ISP 故障。 我们现在为我们构建的所有内容添加时间戳,甚至是简单的开发构建,因为我们在 Vista 中遇到了很
我是一名优秀的程序员,十分优秀!