本文整理汇总了TypeScript中math/polyhedra.Polyhedron.getFace方法的典型用法代码示例。如果您正苦于以下问题:TypeScript Polyhedron.getFace方法的具体用法?TypeScript Polyhedron.getFace怎么用?TypeScript Polyhedron.getFace使用的例子?那么恭喜您, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类math/polyhedra.Polyhedron
的用法示例。
在下文中一共展示了Polyhedron.getFace方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的TypeScript代码示例。
示例1: doExpansion
function doExpansion(
polyhedron: Polyhedron,
referenceName: string,
twist?: Twist,
) {
const reference = Polyhedron.get(referenceName);
const n = polyhedron.getFace().numSides;
const duplicated = duplicateVertices(polyhedron, twist);
// TODO precalculate this
const referenceFace =
_.find<Face>(reference.faces, face => isExpandedFace(reference, face, n)) ||
reference.getFace();
const referenceLength =
(referenceFace.distanceToCenter() / reference.edgeLength()) *
polyhedron.edgeLength();
const expandFaces = _.filter<Face>(duplicated.faces, face =>
isExpandedFace(duplicated, face, n),
);
const refFaces = getExpandedFaces(reference, n);
const angle = twist
? getTwistSign(twist) * Math.abs(getSnubAngle(reference, refFaces))
: 0;
// Update the vertices with the expanded-out version
const endVertices = getResizedVertices(expandFaces, referenceLength, angle);
return {
animationData: {
start: duplicated,
endVertices,
},
};
}
示例2: getsharpenFaces
function getsharpenFaces(polyhedron: Polyhedron, faceType: number) {
// Special octahedron case
if (polyhedron.isRegular()) {
const face0 = polyhedron.getFace();
const adjacentFaces = face0.adjacentFaces();
return _.filter(face0.vertexAdjacentFaces(), f => !f.inSet(adjacentFaces));
}
return _.filter(polyhedron.faces, { numSides: faceType });
}