UNPKG

@jscad/modeling

Version:

Constructive Solid Geometry (CSG) Library for JSCAD

59 lines (43 loc) 1.93 kB
const test = require('ava') const { geom2, geom3, path2 } = require('../geometries') const { ellipsoid, line, rectangle, cuboid } = require('../primitives') const { measureCenterOfMass } = require('./index') test('measureCenterOfMass (single objects)', (t) => { const aline = line([[10, 10], [15, 15]]) const arect = rectangle({ center: [5, 5] }) const acube = cuboid({ size: [3, 3, 3], center: [-15, -5, -10] }) const apath2 = path2.create() const ageom2 = geom2.create() const ageom3 = geom3.create() const n = null const o = {} const x = 'hi' const lcenter = measureCenterOfMass(aline) const rcenter = measureCenterOfMass(arect) const ccenter = measureCenterOfMass(acube) const p2center = measureCenterOfMass(apath2) const g2center = measureCenterOfMass(ageom2) const g3center = measureCenterOfMass(ageom3) const ncenter = measureCenterOfMass(n) const ocenter = measureCenterOfMass(o) const xcenter = measureCenterOfMass(x) t.deepEqual(lcenter, [0, 0, 0]) t.deepEqual(rcenter, [5, 5, 0]) t.deepEqual(ccenter, [-15, -5, -10]) t.deepEqual(p2center, [0, 0, 0]) t.deepEqual(g2center, [0, 0, 0]) t.deepEqual(g3center, [0, 0, 0]) t.deepEqual(ncenter, [0, 0, 0]) t.deepEqual(ocenter, [0, 0, 0]) t.deepEqual(xcenter, [0, 0, 0]) }) test('measureCenterOfMass (multiple objects)', (t) => { const aline = line([[10, 10], [15, 15]]) const arect = rectangle({ size: [10, 20], center: [10, -10] }) const asphere = ellipsoid({ radius: [5, 10, 15], center: [5, -5, 50] }) const o = {} let allcenters = measureCenterOfMass(aline, arect, asphere, o) t.deepEqual(allcenters, [[0, 0, 0], [10, -10, 0], [4.999999999999991, -5.000000000000006, 49.999999999999915], [0, 0, 0]]) allcenters = measureCenterOfMass(aline, arect, asphere, o) t.deepEqual(allcenters, [[0, 0, 0], [10, -10, 0], [4.999999999999991, -5.000000000000006, 49.999999999999915], [0, 0, 0]]) })