本文整理匯總了TypeScript中math/polyhedra.Face.centroid方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Face.centroid方法的具體用法?TypeScript Face.centroid怎麽用?TypeScript Face.centroid使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類math/polyhedra.Face
的用法示例。
在下文中一共展示了Face.centroid方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: doAugment
// Augment the following
function doAugment(
polyhedron: Polyhedron,
base: Face,
augmentType: string,
gyrate?: string,
) {
const numSides = base.numSides;
const augmentee = getAugmentee(augmentType, numSides);
const underside = augmentee.faceWithNumSides(base.numSides);
// Determine the orientations of the underside and the base
const undersideRadius = underside.vertices[0].vec
.sub(underside.centroid())
.getNormalized();
const baseIsAligned = isAligned(
polyhedron,
base,
underside,
isFastigium(augmentType, numSides) ? 'gyro' : gyrate,
augmentType,
);
const offset = baseIsAligned ? 0 : 1;
const baseRadius = base.vertices[offset].vec
.sub(base.centroid())
.getNormalized();
// https://math.stackexchange.com/questions/624348/finding-rotation-axis-and-angle-to-align-two-oriented-vectors
// Determine the transformation that rotates the underside orientation to the base orientation
// TODO we probably want this as some sort of generic method
const transformMatrix = getOrthonormalTransform(
undersideRadius,
underside.normal().getInverted(),
baseRadius,
base.normal(),
);
const transform = withOrigin(base.centroid(), u =>
transformMatrix.applyTo(u),
);
// Scale and position the augmentee so that it lines up with the base
const alignedVertices = augmentee.vertices.map(v => {
return v.vec
.sub(underside.centroid())
.scale(base.sideLength() / augmentee.edgeLength())
.add(base.centroid());
});
// Rotate the vertices so that they align with the base
const rotatedVertices = alignedVertices.map(v => transform(v));
const newAugmentee = augmentee.withChanges(solid =>
solid.withVertices(rotatedVertices).withoutFaces([underside]),
);
return polyhedron.withChanges(solid =>
solid.withoutFaces([base]).addPolyhedron(newAugmentee),
);
}
示例2:
const alignedVertices = augmentee.vertices.map(v => {
return v.vec
.sub(underside.centroid())
.scale(base.sideLength() / augmentee.edgeLength())
.add(base.centroid());
});