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


TypeScript Polyhedron.smallestFace方法代碼示例

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


在下文中一共展示了Polyhedron.smallestFace方法的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: getTruncateLength

function getTruncateLength(polyhedron: Polyhedron) {
  const face = polyhedron.smallestFace();
  const n = face.numSides;
  const theta = Math.PI / n;
  const newTheta = theta / 2;
  return 2 * face.apothem() * Math.tan(newTheta);
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:7,代碼來源:truncate.ts

示例3: applySharpen

function applySharpen(
  polyhedron: Polyhedron,
  { faceType = polyhedron.smallestFace().numSides }: SharpenOptions = {},
) {
  // face indices with the right number of sides
  let sharpenFaces = getsharpenFaces(polyhedron, faceType);

  let mock: Polyhedron;
  if (polyhedron.isQuasiRegular()) {
    mock = duplicateVertices(polyhedron, sharpenFaces);
    sharpenFaces = sharpenFaces.map(face => face.withPolyhedron(mock));
  } else {
    mock = polyhedron;
  }

  const verticesToAdd = sharpenFaces.map(face => getVertexToAdd(mock, face));

  const oldToNew: Record<number, number> = {};
  sharpenFaces.forEach((face, i) => {
    face.vertices.forEach(v => {
      oldToNew[v.index] = i;
    });
  });

  const endVertices = mock.vertices.map((v, vIndex) =>
    _.has(oldToNew, vIndex.toString())
      ? verticesToAdd[oldToNew[vIndex]]
      : v.vec,
  );

  return {
    animationData: {
      start: mock,
      endVertices,
    },
  };
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:37,代碼來源:sharpen.ts


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