深圳市宝安区住房和建设局网站,招聘网站销售怎么做,2022最新时事新闻及点评,wordpress metakey对应的教程文章:  
https://codelabs.developers.google.com/your-first-webgpu-app?hlzh-cn#5 
对应的源码执行效果: 对应的教程源码:  
此处源码和教程本身提供的部分代码可能存在一点差异。运行的时候#xff0c;点击画面可以切换效果。 
class Color4 {r: number;g: numb…对应的教程文章:  
https://codelabs.developers.google.com/your-first-webgpu-app?hlzh-cn#5 
对应的源码执行效果: 对应的教程源码:  
此处源码和教程本身提供的部分代码可能存在一点差异。运行的时候点击画面可以切换效果。 
class Color4 {r: number;g: number;b: number;a: number;constructor(pr  1.0, pg  1.0, pb  1.0, pa  1.0) {this.r  pr;this.g  pg;this.b  pb;this.a  pa;}
}export class WGPURStorage2 {private mRVertices: Float32Array  null;private mRPipeline: any | null  null;private mVtxBuffer: any | null  null;private mCanvasFormat: any | null  null;private mWGPUDevice: any | null  null;private mWGPUContext: any | null  null;private mUniformBindGroups: any | null  null;private mGridSize  32;constructor() {}initialize(): void {const canvas  document.createElement(canvas);canvas.width  512;canvas.height  512;document.body.appendChild(canvas);console.log(ready init webgpu ...);this.initWebGPU(canvas).then(()  {console.log(webgpu initialization finish ...);this.updateWGPUCanvas();});document.onmousedown  (evt):void  {this.updateWGPUCanvas( new Color4(0.05, 0.05, 0.1) );}}private mUniformObj: any  {uniformArray: null, uniformBuffer: null};private createStorage(device: any): any {// Create an array representing the active state of each cell.const cellStateArray  new Uint32Array(this.mGridSize * this.mGridSize);// Create two storage buffers to hold the cell state.const cellStateStorage  [device.createBuffer({label: Cell State A,size: cellStateArray.byteLength,usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_DST,}),device.createBuffer({label: Cell State B,size: cellStateArray.byteLength,usage: GPUBufferUsage.STORAGE | GPUBufferUsage.COPY_DST,})];// Mark every third cell of the first grid as active.for (let i  0; i  cellStateArray.length; i3) {cellStateArray[i]  1;}device.queue.writeBuffer(cellStateStorage[0], 0, cellStateArray);// Mark every other cell of the second grid as active.for (let i  0; i  cellStateArray.length; i) {cellStateArray[i]  i % 2;}device.queue.writeBuffer(cellStateStorage[1], 0, cellStateArray);return cellStateStorage;}private createUniform(device: any, pipeline: any): void {// Create a uniform buffer that describes the grid.const uniformArray  new Float32Array([this.mGridSize, this.mGridSize]);const uniformBuffer  device.createBuffer({label: Grid Uniforms,size: uniformArray.byteLength,usage: GPUBufferUsage.UNIFORM | GPUBufferUsage.COPY_DST,});device.queue.writeBuffer(uniformBuffer, 0, uniformArray);const cellStateStorage  this.createStorage(device);const bindGroups  [device.createBindGroup({label: Cell renderer bind group A,layout: pipeline.getBindGroupLayout(0),entries: [{binding: 0,resource: { buffer: uniformBuffer }}, {binding: 1,resource: { buffer: cellStateStorage[0] }}],}),device.createBindGroup({label: Cell renderer bind group B,layout: pipeline.getBindGroupLayout(0),entries: [{binding: 0,resource: { buffer: uniformBuffer }}, {binding: 1,resource: { buffer: cellStateStorage[1] }}],})];this.mUniformBindGroups  bindGroups;const obj  this.mUniformObj;obj.uniformArray  uniformArray;obj.uniformBuffer  uniformBuffer;}private mStep  0;private createRectGeometryData(device: any, pass: any): void {let vertices  this.mRVertices;let vertexBuffer  this.mVtxBuffer;let cellPipeline  this.mRPipeline;if(!cellPipeline) {let hsize  0.8;vertices  new Float32Array([//   X,    Y,-hsize, -hsize, // Triangle 1 (Blue)hsize, -hsize,hsize,  hsize,-hsize, -hsize, // Triangle 2 (Red)hsize,  hsize,-hsize,  hsize,]);vertexBuffer  device.createBuffer({label: Cell vertices,size: vertices.byteLength,usage: GPUBufferUsage.VERTEX | GPUBufferUsage.COPY_DST,});device.queue.writeBuffer(vertexBuffer, /*bufferOffset*/0, vertices);const vertexBufferLayout  {arrayStride: 8,attributes: [{format: float32x2,offset: 0,shaderLocation: 0, // Position, see vertex shader}],};const shaderCodes  struct VertexInput {location(0) pos: vec2f,builtin(instance_index) instance: u32,};struct VertexOutput {builtin(position) pos: vec4f,location(0) cell: vec2f,};group(0) binding(0) varuniform grid: vec2f;group(0) binding(1) varstorage cellState: arrayu32;vertexfn vertexMain(input: VertexInput) - VertexOutput  {let i  f32(input.instance);let cell  vec2f(i % grid.x, floor(i / grid.x));let cellOffset  cell / grid * 2;let state  f32(cellState[input.instance]);let gridPos  (input.pos * state  1) / grid - 1  cellOffset;var output: VertexOutput;output.pos  vec4f(gridPos, 0, 1);output.cell  cell;return output;}fragmentfn fragmentMain(input: VertexOutput) - location(0) vec4f {// return vec4f(input.cell, 0, 1);let c  input.cell/grid;return vec4f(c, 1.0 - c.x, 1);};const cellShaderModule  device.createShaderModule({label: Cell shader,code: shaderCodes});cellPipeline  device.createRenderPipeline({label: Cell pipeline,layout: auto,vertex: {module: cellShaderModule,entryPoint: vertexMain,buffers: [vertexBufferLayout]},fragment: {module: cellShaderModule,entryPoint: fragmentMain,targets: [{format: this.mCanvasFormat}]},});this.mRVertices  vertices;this.mVtxBuffer  vertexBuffer;this.mRPipeline  cellPipeline;this.createUniform(device, cellPipeline);}pass.setPipeline(cellPipeline);pass.setVertexBuffer(0, vertexBuffer);// pass.setBindGroup(0, this.mUniformBindGroup);pass.setBindGroup(0, this.mUniformBindGroups[this.mStep % 2]);pass.draw(vertices.length / 2, this.mGridSize * this.mGridSize);this.mStep ;}private updateWGPUCanvas(clearColor: Color4  null): void {clearColor  clearColor ? clearColor : new Color4(0.05, 0.05, 0.1);const device  this.mWGPUDevice;const context  this.mWGPUContext;const rpassParam  {colorAttachments: [{clearValue: clearColor,// clearValue: [0.3,0.7,0.5,1.0], // yesview: context.getCurrentTexture().createView(),loadOp: clear,storeOp: store}]};const encoder  device.createCommandEncoder();const pass  encoder.beginRenderPass( rpassParam );this.createRectGeometryData(device, pass);pass.end();device.queue.submit([ encoder.finish() ]);}private async initWebGPU(canvas: HTMLCanvasElement) {const gpu  (navigator as any).gpu;if (gpu) {console.log(WebGPU supported on this browser.);const adapter  await gpu.requestAdapter();if (adapter) {console.log(Appropriate GPUAdapter found.);const device  await adapter.requestDevice();if (device) {this.mWGPUDevice  device;console.log(Appropriate GPUDevice found.);const context  canvas.getContext(webgpu) as any;const canvasFormat  gpu.getPreferredCanvasFormat();this.mWGPUContext  context;this.mCanvasFormat  canvasFormat;console.log(canvasFormat: , canvasFormat);context.configure({device: device,format: canvasFormat,alphaMode: premultiplied});} else {throw new Error(No appropriate GPUDevice found.);}} else {throw new Error(No appropriate GPUAdapter found.);}} else {throw new Error(WebGPU not supported on this browser.);}}run(): void {}
} 
切换后的效果: