本文整理匯總了TypeScript中math/polyhedra.Polyhedron.largestFace方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Polyhedron.largestFace方法的具體用法?TypeScript Polyhedron.largestFace怎麽用?TypeScript Polyhedron.largestFace使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類math/polyhedra.Polyhedron
的用法示例。
在下文中一共展示了Polyhedron.largestFace方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。
示例1: getCapAlignment
export function getCapAlignment(polyhedron: Polyhedron, cap: Cap) {
const isRhombicosidodecahedron = cap.type === 'cupola';
const orthoCaps = isRhombicosidodecahedron
? _.filter(
Cap.getAll(polyhedron),
cap => getCupolaGyrate(polyhedron, cap) === 'ortho',
)
: [];
const otherNormal =
orthoCaps.length > 0
? getSingle(orthoCaps)
.boundary()
.normal()
: polyhedron.largestFace().normal();
return isInverse(cap.normal(), otherNormal) ? 'para' : 'meta';
}
示例2: doTwist
// TODO deduplicate with expand/contract
function doTwist(
polyhedron: Polyhedron,
referenceName: string,
twist: Twist = 'left',
) {
const reference = Polyhedron.get(referenceName);
const isSnub = expansionType(polyhedron) === 'snub';
const f0 = polyhedron.largestFace();
const n = f0.numSides;
const twistFaces = getExpandedFaces(polyhedron, n);
const referenceFace =
_.find(reference.faces, face => isExpandedFace(reference, face, n)) ||
reference.getFace();
const referenceLength =
(referenceFace.distanceToCenter() / reference.edgeLength()) *
polyhedron.edgeLength();
const refFaces = getExpandedFaces(reference, n);
const angle = !isSnub
? getTwistSign(twist) * Math.abs(getSnubAngle(reference, refFaces))
: -getSnubAngle(polyhedron, twistFaces);
const snubTwist = angle > 0 ? 'left' : 'right';
const duplicated = isSnub
? polyhedron
: bisectEdgeFaces(twistFaces, snubTwist);
const endVertices = getResizedVertices(twistFaces, referenceLength, angle);
return {
animationData: {
start: duplicated,
endVertices,
},
result: isSnub
? joinEdgeFaces(twistFaces, snubTwist).withVertices(endVertices)
: undefined,
};
}