當前位置: 首頁>>代碼示例>>TypeScript>>正文


TypeScript Polyhedron.isRegular方法代碼示例

本文整理匯總了TypeScript中math/polyhedra.Polyhedron.isRegular方法的典型用法代碼示例。如果您正苦於以下問題:TypeScript Polyhedron.isRegular方法的具體用法?TypeScript Polyhedron.isRegular怎麽用?TypeScript Polyhedron.isRegular使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在math/polyhedra.Polyhedron的用法示例。


在下文中一共展示了Polyhedron.isRegular方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的TypeScript代碼示例。

示例1: getTruncateTransform

function getTruncateTransform(polyhedron: Polyhedron, result = ''): Transform {
  if (polyhedron.isRegular()) {
    return vector => vector;
  }

  // If we're doing a bevel, we need to do some fidgeting to make sure the created
  // faces are all regular
  const truncateLength = getTruncateLength(polyhedron);
  const oldSideLength = polyhedron.edgeLength();

  const multiplier = getRectifiedMultiplier(result);
  const newSideLength = oldSideLength * multiplier;
  const faceResizeScale = newSideLength / truncateLength;

  const reference = Polyhedron.get(result);
  const normalizedResizeAmount =
    reference.faceWithNumSides(6).distanceToCenter() / reference.edgeLength() -
    polyhedron.smallestFace().distanceToCenter() / newSideLength;

  return (vector, vertex) => {
    const smallFace = find(vertex.adjacentFaces(), {
      numSides: 6,
    });
    const normal = smallFace.withPolyhedron(polyhedron).normal();
    const transform = withOrigin(smallFace.centroid(), v =>
      v
        .scale(faceResizeScale)
        .add(normal.scale(normalizedResizeAmount * newSideLength)),
    );
    return transform(vector);
  };
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:32,代碼來源:truncate.ts

示例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 });
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:10,代碼來源:sharpen.ts

示例3: getsharpenDist

function getsharpenDist(polyhedron: Polyhedron, face: Face) {
  if (!polyhedron.isRegular() && !polyhedron.isQuasiRegular()) {
    return _.meanBy(face.edges, edge => calculatesharpenDist(face, edge));
  }
  return calculatesharpenDist(face, face.edges[0]);
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:6,代碼來源:sharpen.ts


注:本文中的math/polyhedra.Polyhedron.isRegular方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。