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


TypeScript Polyhedron.get方法代碼示例

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


在下文中一共展示了Polyhedron.get方法的6個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的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,
    },
  };
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:35,代碼來源:expand.ts

示例2: 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

示例3: it

  tests.forEach(test => {
    const { start, description, operations } = test;
    let polyhedron = Polyhedron.get(start);
    let solidName = start;
    it(description, () => {
      operations.forEach(opInfo => {
        const { op, args, expected } = getOpInfo(opInfo, polyhedron);
        const result = op.apply(polyhedron, args);
        expect(result).toBeValidPolyhedron();

        polyhedron = result.result;
        expect(polyhedron.name).toBe(expected);
        solidName = result.name;
      });
    });
  });
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:16,代碼來源:chainedOperations.test.ts

示例4: setupOperations

export function setupOperations() {
  expect.extend({
    toBeValidPolyhedron(received) {
      const { result } = received;
      const isProper = isProperPolyhedron(result);
      const matchesName = result.isSame(Polyhedron.get(result.name));
      return {
        message: () => {
          if (!isProper)
            return `expected ${
              this.isNot ? 'an improper' : 'a proper'
            } CRF polyhedron`;
          return `expected polyhedron to ${this.isNot ? 'not be' : 'be'} a ${
            result.name
          }`;
        },
        pass: isProper && matchesName,
      };
    },
  });
}
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:21,代碼來源:operationTestUtils.ts

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

示例6:

 const polyhedra = _.map(allSolidNames, name => Polyhedron.get(name));
開發者ID:tessenate,項目名稱:polyhedra-viewer,代碼行數:1,代碼來源:applyOperation.test.ts


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