All files / Sources/Filters/General/OBBTree OBBNode.js

75% Statements 21/28
33.33% Branches 1/3
100% Functions 5/5
74.07% Lines 20/27

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                6x             6x 1x 1x 1x 1x   1x                         825x           6x                                 6x   6x 6x         6x 6x 6x     6x   6x     6x     6x         1x          
import macro from 'vtk.js/Sources/macros';
 
// ----------------------------------------------------------------------------
// vtkOBBNode methods
// ----------------------------------------------------------------------------
 
function vtkOBBNode(publicAPI, model) {
  // Set our classname
  model.classHierarchy.push('vtkOBBNode');
 
  /**
   * Copy a vtkOBBNode into an other one
   * @param {vtkOBBNode} nodeSource
   * @param {vtkOBBNode} nodeTarget
   */
  publicAPI.deepCopy = (nodeSource) => {
    publicAPI.setCorner(nodeSource.getCorner());
    const axes = nodeSource.getAxes();
    publicAPI.setAxes([[...axes[0]], [...axes[1]], [...axes[2]]]);
    publicAPI.setCells([...nodeSource.getCells()]);
 
    Iif (nodeSource.getKids()) {
      const kids0 = vtkOBBNode.newInstance();
      kids0.setParent(publicAPI);
      const kids1 = vtkOBBNode.newInstance();
      kids1.setParent(publicAPI);
 
      kids0.deepCopy(nodeSource.getKids()[0]);
      kids1.deepCopy(nodeSource.getKids()[1], kids1);
 
      publicAPI.setKids(kids0, kids1);
    }
  };
 
  publicAPI.getAxis = (axis) => model.axes[axis];
}
 
// ----------------------------------------------------------------------------
 
function defaultValues(initialValues) {
  return {
    corner: [0, 0, 0], // center point of this node
    axes: [
      [0, 0, 0],
      [0, 0, 0],
      [0, 0, 0],
    ], // the axes defining the OBB - ordered from long->short
    cells: [], // list of cells in node
    // parent: null, null if root
    // kids: null, two children of this node; null if leaf
    ...initialValues,
  };
}
 
// ----------------------------------------------------------------------------
 
export function extend(publicAPI, model, initialValues = {}) {
  Object.assign(model, defaultValues(initialValues));
 
  model.corner = [0, 0, 0];
  model.axes = [
    [0, 0, 0],
    [0, 0, 0],
    [0, 0, 0],
  ];
  model.parent = null; // parent node; null if root
  model.kids = null; // two children of this node; nullptr if leaf
  model.cells = []; // list of cells in node
 
  // Build VTK API
  macro.setGet(publicAPI, model, ['parent', 'cells', 'kids']);
  // macro.setGetArray(publicAPI, model, ['kids'], 2);
  macro.setGetArray(publicAPI, model, ['corner', 'axes'], 3);
 
  // Make this a VTK object
  macro.obj(publicAPI, model);
 
  // Object specific methods
  vtkOBBNode(publicAPI, model);
}
 
// ----------------------------------------------------------------------------
 
export const newInstance = macro.newInstance(extend, 'vtkOBBNode');
 
// ----------------------------------------------------------------------------
 
export default { newInstance, extend };