当前位置: 首页>>代码示例>>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;未经允许,请勿转载。