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


TypeScript layers.LayerUtil類代碼示例

本文整理匯總了TypeScript中app/model/layers.LayerUtil的典型用法代碼示例。如果您正苦於以下問題:TypeScript LayerUtil類的具體用法?TypeScript LayerUtil怎麽用?TypeScript LayerUtil使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: swapLayers

 /**
  * Replaces an existing layer in the tree with a new layer. Note that
  * this method assumes that both layers still have the same children layers.
  */
 swapLayers(layerId: string, newLayer: Layer) {
   if (layerId === newLayer.id) {
     this.updateLayer(newLayer);
     return;
   }
   const vl = this.getVectorLayer();
   const parent = LayerUtil.findParent(vl, layerId).clone();
   const layerIndex = _.findIndex(parent.children, l => l.id === layerId);
   const children = [...parent.children];
   children.splice(layerIndex, 1, newLayer);
   parent.children = children;
   const actions: Action[] = [
     new SetVectorLayer(LayerUtil.updateLayer(vl, parent)),
     ...this.buildCleanupLayerIdActions(layerId),
   ];
   const animation = this.getAnimation();
   const oldLayerBlocks = animation.blocks.filter(b => b.layerId === layerId);
   const newAnimatableProperties = new Set(newLayer.animatableProperties.keys());
   // Preserve any blocks that are still animatable with the new layer.
   const newLayerBlocks = oldLayerBlocks
     .filter(b => newAnimatableProperties.has(b.propertyName))
     .map(b => {
       b = b.clone();
       b.layerId = newLayer.id;
       return b;
     });
   const newAnimation = animation.clone();
   newAnimation.blocks = [
     ...animation.blocks.filter(b => b.layerId !== layerId),
     ...newLayerBlocks,
   ];
   actions.push(new SetAnimation(newAnimation));
   this.store.dispatch(new BatchAction(...actions));
 }
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:38,代碼來源:layertimeline.service.ts

示例2: while

 tempSelLayers = tempSelLayers.filter(layer => {
   if (layer instanceof VectorLayer) {
     return false;
   }
   let p = LayerUtil.findParent(vl, layer.id);
   while (p) {
     if (_.find(tempSelLayers, l => l.id === p.id)) {
       return false;
     }
     p = LayerUtil.findParent(vl, p.id);
   }
   return true;
 });
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:13,代碼來源:layertimeline.service.ts

示例3:

 tempSelLayers.filter(layer => layer instanceof GroupLayer).forEach(groupLayer => {
   // Move children into parent.
   const parent = LayerUtil.findParent(vl, groupLayer.id).clone();
   const indexInParent = Math.max(
     0,
     _.findIndex(parent.children, l => l.id === groupLayer.id),
   );
   const newChildren = [...parent.children];
   newChildren.splice(indexInParent, 0, ...groupLayer.children);
   parent.children = newChildren;
   vl = LayerUtil.updateLayer(vl, parent);
   newSelectedLayers.splice(0, 0, ...groupLayer.children);
   // Delete the parent.
   vl = LayerUtil.removeLayers(vl, groupLayer.id);
 });
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:15,代碼來源:layertimeline.service.ts

示例4: doesNameExistFn

 const makeFinalNodeIdFn = (nodeId: string, prefix: string) => {
   const finalName = LayerUtil.getUniqueName(
     NameProperty.sanitize(nodeId || prefix),
     name => doesNameExistFn(name) || usedIds.has(name),
   );
   usedIds.add(finalName);
   return finalName;
 };
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:8,代碼來源:SvgLoader.ts

示例5: doesLayerNameExistFn

 const makeFinalNodeIdFn = (value: string, prefix: string) => {
   const finalName = LayerUtil.getUniqueName(
     NameProperty.sanitize(value || prefix),
     n => doesLayerNameExistFn(n) || usedNames.has(n),
   );
   usedNames.add(finalName);
   return finalName;
 };
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:8,代碼來源:VectorDrawableLoader.ts

示例6: addLayer

 /**
  * Adds a layer to the vector tree.
  */
 addLayer(layer: Layer) {
   const vl = this.getVectorLayer();
   const selectedLayers = this.getSelectedLayers();
   if (selectedLayers.length === 1) {
     const selectedLayer = selectedLayers[0];
     if (!(selectedLayer instanceof VectorLayer)) {
       // Add the new layer as a sibling to the currently selected layer.
       const parent = LayerUtil.findParent(vl, selectedLayer.id).clone();
       parent.children = [...parent.children, layer];
       this.updateLayer(parent);
       return;
     }
   }
   const vectorLayer = vl.clone();
   vectorLayer.children = [...vectorLayer.children, layer];
   this.updateLayer(vectorLayer);
 }
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:20,代碼來源:layertimeline.service.ts

示例7: AnimationRenderer

 (vl, anim, block) => {
   if (!block) {
     return undefined;
   }
   // Note this is a bit dangerous because the renderer interpolates paths
   // and that causes all mutated path state to be lost if we aren't careful.
   // There are currently checks in PathProperty.ts to avoid this by returning
   // the start and end path when the interpolated fraction is 0 and 1 respectively.
   const renderer = new AnimationRenderer(vl, anim);
   const timeMillis = getTimeFn(block);
   // First interpolate the entire vector layer.
   const renderedVl = renderer.setCurrentTime(timeMillis);
   // TODO: this is hacky! the real solution is to not clear path state after interpolations
   // Replace the interpolated value with the block's to/from value.
   const layer = vl.findLayerById(block.layerId).clone() as MorphableLayer;
   layer.pathData = timeMillis === block.startTime ? block.fromValue : block.toValue;
   return LayerUtil.updateLayer(renderedVl, layer);
 },
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:18,代碼來源:selectors.ts

示例8: groupOrUngroupSelectedLayers

  /**
   * Groups or ungroups the selected layers.
   */
  groupOrUngroupSelectedLayers(shouldGroup: boolean) {
    let selectedLayerIds = this.getSelectedLayerIds();
    if (!selectedLayerIds.size) {
      return;
    }
    let vl = this.getVectorLayer();

    // Sort selected layers by order they appear in tree.
    let tempSelLayers = Array.from(selectedLayerIds).map(id => vl.findLayerById(id));
    const selLayerOrdersMap: Dictionary<number> = {};
    let n = 0;
    vl.walk(layer => {
      if (_.find(tempSelLayers, l => l.id === layer.id)) {
        selLayerOrdersMap[layer.id] = n;
        n++;
      }
    });
    tempSelLayers.sort((a, b) => selLayerOrdersMap[a.id] - selLayerOrdersMap[b.id]);

    if (shouldGroup) {
      // Remove any layers that are descendants of other selected layers,
      // and remove the vectorLayer itself if selected.
      tempSelLayers = tempSelLayers.filter(layer => {
        if (layer instanceof VectorLayer) {
          return false;
        }
        let p = LayerUtil.findParent(vl, layer.id);
        while (p) {
          if (_.find(tempSelLayers, l => l.id === p.id)) {
            return false;
          }
          p = LayerUtil.findParent(vl, p.id);
        }
        return true;
      });

      if (!tempSelLayers.length) {
        return;
      }

      // Find destination parent and insertion point.
      const firstSelectedLayerParent = LayerUtil.findParent(vl, tempSelLayers[0].id).clone();
      const firstSelectedLayerIndexInParent = _.findIndex(
        firstSelectedLayerParent.children,
        l => l.id === tempSelLayers[0].id,
      );

      // Remove all selected items from their parents and move them into a new parent.
      const newGroup = new GroupLayer({
        name: LayerUtil.getUniqueLayerName([vl], 'group'),
        children: tempSelLayers,
      });
      const parentChildren = [...firstSelectedLayerParent.children];
      parentChildren.splice(firstSelectedLayerIndexInParent, 0, newGroup);
      _.remove(parentChildren, child =>
        _.find(tempSelLayers, selectedLayer => selectedLayer.id === child.id),
      );
      firstSelectedLayerParent.children = parentChildren;
      vl = LayerUtil.updateLayer(vl, firstSelectedLayerParent);
      selectedLayerIds = new Set([newGroup.id]);
    } else {
      // Ungroup selected groups layers.
      const newSelectedLayers: Layer[] = [];
      tempSelLayers.filter(layer => layer instanceof GroupLayer).forEach(groupLayer => {
        // Move children into parent.
        const parent = LayerUtil.findParent(vl, groupLayer.id).clone();
        const indexInParent = Math.max(
          0,
          _.findIndex(parent.children, l => l.id === groupLayer.id),
        );
        const newChildren = [...parent.children];
        newChildren.splice(indexInParent, 0, ...groupLayer.children);
        parent.children = newChildren;
        vl = LayerUtil.updateLayer(vl, parent);
        newSelectedLayers.splice(0, 0, ...groupLayer.children);
        // Delete the parent.
        vl = LayerUtil.removeLayers(vl, groupLayer.id);
      });
      selectedLayerIds = new Set(newSelectedLayers.map(l => l.id));
    }
    this.store.dispatch(
      new BatchAction(new SetVectorLayer(vl), new SetSelectedLayers(selectedLayerIds)),
    );
  }
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:87,代碼來源:layertimeline.service.ts


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