@kitware/vtk.js
Version:
Visualization Toolkit for the Web
138 lines (119 loc) • 5.06 kB
JavaScript
import { n as newInstance$1, r as vtkErrorMacro } from '../../macros2.js';
import vtkWebGPUBufferManager from './BufferManager.js';
import vtkWebGPUCellArrayMapper from './CellArrayMapper.js';
import vtkViewNode from '../SceneGraph/ViewNode.js';
import { registerOverride } from './ViewNodeFactory.js';
const {
PrimitiveTypes
} = vtkWebGPUBufferManager;
// ----------------------------------------------------------------------------
// vtkWebGPUPolyDataMapper methods
// ----------------------------------------------------------------------------
function vtkWebGPUPolyDataMapper(publicAPI, model) {
// Set our className
model.classHierarchy.push('vtkWebGPUPolyDataMapper');
publicAPI.createCellArrayMapper = () => vtkWebGPUCellArrayMapper.newInstance();
publicAPI.buildPass = prepass => {
if (prepass) {
model.WebGPUActor = publicAPI.getFirstAncestorOfType('vtkWebGPUActor');
if (!model.renderable.getStatic()) {
model.renderable.update();
}
const poly = model.renderable.getInputData();
model.renderable.mapScalars(poly, 1.0);
publicAPI.updateCellArrayMappers(poly);
}
};
publicAPI.updateCellArrayMappers = poly => {
if (!poly) {
vtkErrorMacro('No input!');
return;
}
const prims = [poly.getVerts(), poly.getLines(), poly.getPolys(), poly.getStrips()];
// we instantiate a cell array mapper for each cellArray that has cells
// and they handle the rendering of that cell array
const cellMappers = [];
let cellOffset = 0;
// Handle all primitive types including strips
for (let i = PrimitiveTypes.Points; i <= PrimitiveTypes.TriangleStrips; i++) {
if (prims[i].getNumberOfValues() > 0) {
if (!model.primitives[i]) {
model.primitives[i] = publicAPI.createCellArrayMapper();
}
const cellMapper = model.primitives[i];
cellMapper.setCellArray(prims[i]);
cellMapper.setCurrentInput(poly);
cellMapper.setCellOffset(cellOffset);
cellMapper.setPrimitiveType(i);
cellMapper.setRenderable(model.renderable);
cellOffset += prims[i].getNumberOfCells();
cellMappers.push(cellMapper);
} else {
model.primitives[i] = null;
}
}
// Handle edge visibility for both triangles and triangle strips
if (model.WebGPUActor.getRenderable().getProperty().getEdgeVisibility()) {
// Handle triangle edges
if (prims[PrimitiveTypes.Triangles].getNumberOfValues() > 0) {
const i = PrimitiveTypes.TriangleEdges;
if (!model.primitives[i]) {
model.primitives[i] = publicAPI.createCellArrayMapper();
}
const cellMapper = model.primitives[i];
cellMapper.setCellArray(prims[PrimitiveTypes.Triangles]);
cellMapper.setCurrentInput(poly);
cellMapper.setCellOffset(model.primitives[PrimitiveTypes.Triangles].getCellOffset());
cellMapper.setPrimitiveType(i);
cellMapper.setRenderable(model.renderable);
cellMappers.push(cellMapper);
} else {
model.primitives[PrimitiveTypes.TriangleEdges] = null;
}
// Handle triangle strip edges
if (prims[PrimitiveTypes.TriangleStrips].getNumberOfValues() > 0) {
const i = PrimitiveTypes.TriangleStripEdges;
if (!model.primitives[i]) {
model.primitives[i] = publicAPI.createCellArrayMapper();
}
const cellMapper = model.primitives[i];
cellMapper.setCellArray(prims[PrimitiveTypes.TriangleStrips]);
cellMapper.setCurrentInput(poly);
cellMapper.setCellOffset(model.primitives[PrimitiveTypes.TriangleStrips].getCellOffset());
cellMapper.setPrimitiveType(i);
cellMapper.setRenderable(model.renderable);
cellMappers.push(cellMapper);
} else {
model.primitives[PrimitiveTypes.TriangleStripEdges] = null;
}
}
publicAPI.prepareNodes();
publicAPI.addMissingChildren(cellMappers);
publicAPI.removeUnusedNodes();
};
}
// ----------------------------------------------------------------------------
// Object factory
// ----------------------------------------------------------------------------
const DEFAULT_VALUES = {
primitives: null
};
// ----------------------------------------------------------------------------
function extend(publicAPI, model, initialValues = {}) {
Object.assign(model, DEFAULT_VALUES, initialValues);
// Inheritance
vtkViewNode.extend(publicAPI, model, initialValues);
model.primitives = [];
// Object methods
vtkWebGPUPolyDataMapper(publicAPI, model);
}
// ----------------------------------------------------------------------------
const newInstance = newInstance$1(extend, 'vtkWebGPUPolyDataMapper');
// ----------------------------------------------------------------------------
var vtkWebGPUPolyDataMapper$1 = {
newInstance,
extend
};
// Register ourself to WebGPU backend if imported
registerOverride('vtkMapper', newInstance);
export { vtkWebGPUPolyDataMapper$1 as default, extend, newInstance };