当前位置: 首页 > news >正文

轻量封装WebGPU渲染系统示例<24>- Rendering Pass Graph基本用法(源码)

当前示例源码github地址:

https://github.com/vilyLei/voxwebgpu/blob/feature/rendering/src/voxgpu/sample/PassNodeGraphTest.ts

此示例基于此渲染系统实现,当前示例TypeScript源码如下:

class PassGraph extends WGRPassNodeGraph {constructor() { super(); }runBegin(): void {super.runBegin();}run(): void {let pass = this.passes[0];for (let i = 0; i < 16; ++i) {pass.colorAttachments[0].clearEnabled = i < 1;pass.render();}}
}export class PassNodeGraphTest {private mRscene = new RendererScene();initialize(): void {let multisampleEnabled = true;let depthTestEnabled = false;let rpassparam = { multisampleEnabled, depthTestEnabled };this.mRscene.initialize({ rpassparam });this.initEvent();this.initScene();}private applyNewRPass(texUUID: string, entities: FixScreenPlaneEntity[], clearColor: ColorDataType, extent = [0.4, 0.3, 0.5, 0.5]): void {let rs = this.mRscene;let rttTex = { diffuse: { uuid: texUUID, rttTexture: {} } };let colorAttachments = [{texture: rttTex,clearValue: clearColor,loadOp: "clear",storeOp: "store"}];let rPass = rs.renderer.appendRenderPass({ separate: true, colorAttachments });for (let i = 0; i < entities.length; ++i) {rPass.addEntity(entities[i]);}let graph = new PassGraph();graph.passes = [rPass];rs.setPassNodeGraph(graph);let entity = new FixScreenPlaneEntity({ extent, flipY: true, textures: [rttTex] });rs.addEntity(entity);}private initEvent(): void {const rs = this.mRscene;new MouseInteraction().initialize(rs, 0, false).setAutoRunning(true);}private initScene(): void {const rs = this.mRscene;let entity: FixScreenPlaneEntity;const diffuseTex = { diffuse: { url: "static/assets/guangyun_40.png", flipY: true } };let blendModes = ['add'];let entities: FixScreenPlaneEntity[] = [];entity = new FixScreenPlaneEntity({ extent: [-0.8, -0.8, 0.8, 0.8], textures: [diffuseTex], blendModes });entity.setColor([0.9, 0.3, 0.9]);rs.addEntity(entity);entities.push(entity);this.applyNewRPass('rtt0', entities, [0.2, 0.2, 0.2, 1.0], [-0.2, 0.1, 0.8, 0.8]);}run(): void {this.mRscene.run();}
}

http://www.lryc.cn/news/227646.html

相关文章:

  • 开设自己的网站系类01购买服务器
  • FTP、NFS、SAMBA系统服务一
  • transfomer模型——简介,代码实现,重要模块解读,源码,官方
  • 队列(Queue):先进先出(FIFO)的数据结构
  • 吃透 Spring 系列—AOP部分
  • redis 问题解决 2
  • Spring Boot 校验用户上传的图片文件
  • 【springboot配置项动态刷新】与【yaml文件转换为java对象】
  • JS移动端触屏事件
  • C语言——打印1000年到2000年之间的闰年
  • 【Linux】【驱动】设备树下的paltform总线
  • 洛谷 NOIP 2023 模拟赛-汪了个汪-题解
  • 洛谷 NOIP 2023 模拟赛 P9836 种树
  • 链表经典OJ题(链表回文结构,链表带环,链表的深拷贝)
  • AD教程 (十三)常见CHIP封装的创建
  • 从0到1实现一个前端监控系统(附源码)
  • 第7章-使用统计方法进行变量有效性测试-7.2-方差分析
  • 【MongoDB】索引 – 文本索引(用权重控制搜索结果)
  • Git 入门使用
  • 如何写好接口自动化测试脚本
  • openEuler编译安装nmon性能监控工具及可视化分析工具
  • 96 前缀树Trie
  • “第六十六天”
  • MYSQL5.7和MYSQL8配置主从
  • springboot苍穹外卖实战:九、小程序微信登录代码开发+商品浏览
  • 【MySQL系列】 第二章 · SQL(下)
  • SpringBoot_01
  • 【OS】AUTOSAR架构下多核通信
  • 从Docker Hub获取镜像和创建容器
  • 江西开放大学引领学习新时代:电大搜题助力学子迈向成功