Press n or j to go to the next uncovered block, b, p or k for the previous block.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 | 1x 1x 1x | import macro from 'vtk.js/Sources/macros'; import Constants from 'vtk.js/Sources/Rendering/WebGPU/BufferManager/Constants'; // methods we forward to the handle const forwarded = ['getMappedRange', 'mapAsync', 'unmap']; function bufferSubData(device, destBuffer, destOffset, srcArrayBuffer) { const byteCount = srcArrayBuffer.byteLength; const srcBuffer = device.createBuffer({ size: byteCount, /* eslint-disable no-undef */ usage: GPUBufferUsage.COPY_SRC, /* eslint-enable no-undef */ mappedAtCreation: true, }); const arrayBuffer = srcBuffer.getMappedRange(0, byteCount); new Uint8Array(arrayBuffer).set(new Uint8Array(srcArrayBuffer)); // memcpy srcBuffer.unmap(); const encoder = device.createCommandEncoder(); encoder.copyBufferToBuffer(srcBuffer, 0, destBuffer, destOffset, byteCount); const commandBuffer = encoder.finish(); const queue = device.queue; queue.submit([commandBuffer]); srcBuffer.destroy(); } // ---------------------------------------------------------------------------- // vtkWebGPUBufferManager methods // ---------------------------------------------------------------------------- function vtkWebGPUBuffer(publicAPI, model) { // Set our className model.classHierarchy.push('vtkWebGPUBuffer'); publicAPI.create = (sizeInBytes, usage) => { model.handle = model.device.getHandle().createBuffer({ size: sizeInBytes, usage, label: model.label, }); model.sizeInBytes = sizeInBytes; model.usage = usage; }; publicAPI.write = (data) => { bufferSubData(model.device.getHandle(), model.handle, 0, data.buffer); }; publicAPI.createAndWrite = (data, usage) => { model.handle = model.device.getHandle().createBuffer({ size: data.byteLength, usage, mappedAtCreation: true, label: model.label, }); model.sizeInBytes = data.byteLength; model.usage = usage; new Uint8Array(model.handle.getMappedRange()).set( new Uint8Array(data.buffer) ); // memcpy model.handle.unmap(); }; // simple forwarders for (let i = 0; i < forwarded.length; i++) { publicAPI[forwarded[i]] = (...args) => model.handle[forwarded[i]](...args); } } // ---------------------------------------------------------------------------- // Object factory // ---------------------------------------------------------------------------- const DEFAULT_VALUES = { device: null, handle: null, sizeInBytes: 0, strideInBytes: 0, arrayInformation: null, usage: null, label: null, sourceTime: null, }; // ---------------------------------------------------------------------------- export function extend(publicAPI, model, initialValues = {}) { Object.assign(model, DEFAULT_VALUES, initialValues); // Object methods macro.obj(publicAPI, model); macro.get(publicAPI, model, ['handle', 'sizeInBytes', 'usage']); macro.setGet(publicAPI, model, [ 'strideInBytes', 'device', 'arrayInformation', 'label', 'sourceTime', ]); vtkWebGPUBuffer(publicAPI, model); } // ---------------------------------------------------------------------------- export const newInstance = macro.newInstance(extend); // ---------------------------------------------------------------------------- export default { newInstance, extend, ...Constants }; |