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


TypeScript lodash.clamp函數代碼示例

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


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

示例1: movePlant

export function movePlant(payload: MovePlantProps) {
  const tr = payload.plant;
  const update = defensiveClone(payload.plant).body;
  update.x += payload.deltaX;
  update.y += payload.deltaY;
  update.x = clamp(update.x, 0, payload.gridSize.x);
  update.y = clamp(update.y, 0, payload.gridSize.y);
  return edit(tr, update);
}
開發者ID:FarmBot,項目名稱:Farmbot-Web-API,代碼行數:9,代碼來源:actions.ts

示例2: interpolateValue

 // @Override
 interpolateValue(start: string, end: string, f: number) {
   if (!start || !end) {
     return undefined;
   }
   const s = ColorUtil.parseAndroidColor(start);
   const e = ColorUtil.parseAndroidColor(end);
   return ColorUtil.toAndroidString({
     r: _.clamp(Math.round(MathUtil.lerp(s.r, e.r, f)), 0, 0xff),
     g: _.clamp(Math.round(MathUtil.lerp(s.g, e.g, f)), 0, 0xff),
     b: _.clamp(Math.round(MathUtil.lerp(s.b, e.b, f)), 0, 0xff),
     a: _.clamp(Math.round(MathUtil.lerp(s.a, e.a, f)), 0, 0xff),
   });
 }
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:14,代碼來源:ColorProperty.ts

示例3: while

 static *tween(duration: number, effectFactory: (t: number) => Effect) {
   let accumulation = 0
   while (accumulation < duration) {
     const { delta }: actions.Tick = yield take(actions.A.Tick)
     accumulation += delta
     yield effectFactory(clamp(accumulation / duration, 0, 1))
   }
 }
開發者ID:socoolxin,項目名稱:battle-city,代碼行數:8,代碼來源:Timing.ts

示例4: parseLevel

export function parseLevel(level: Level|number|string): Level {
    level = +level;
    if (isNaN(level)) {
        return 0;
    }

    return _.clamp(+level, 0, 16) as Level;
}
開發者ID:bgotink,項目名稱:IngressIdentity,代碼行數:8,代碼來源:util.ts

示例5:

export function createItemStack<I extends Item>(
  item: I, stackAmount: number, maxStackAmount = stackAmount
): ItemStack<I> {
  return {
    item,
    maxStackAmount,
    stackAmount: _.clamp(stackAmount, 0, maxStackAmount)
  };
}
開發者ID:zthomae,項目名稱:xanadu,代碼行數:9,代碼來源:item.ts

示例6: getWorkspaceById

const setStageZoom = (state: ApplicationState, workspaceId: string, zoom: number, smooth: boolean = true) => {
  const workspace = getWorkspaceById(state, workspaceId);
  return updateWorkspaceStage(state, workspace.$id, {
    smooth,
    translate: centerTransformZoom(
      workspace.stage.translate, workspace.stage.container.getBoundingClientRect(), 
      clamp(zoom, MIN_ZOOM, MAX_ZOOM),
      workspace.stage.mousePosition
    )
  });
};
開發者ID:cryptobuks,項目名稱:tandem,代碼行數:11,代碼來源:index.ts

示例7: function

export default function(t: number, cols: tinycolorInstance[], hsv?: boolean) {
	var c = cols.length - 1; t = t * c; if (c === 0) return cols[0];
	var i = _.clamp(Math.floor(t), 0, c-1); t = t - i;
	var a = cols[i], b = cols[i+1], lerp = function(s: number, e: number) { return (1-t)*s+t*e; };
	if (hsv) {
		let s = a.toHsv(), e = b.toHsv();
		return tinycolor({h: lerp(s.h, e.h), s: lerp(s.s, e.s), v: lerp(s.v, e.v)});
	} else {
		let s = a.toRgb(), e = b.toRgb();
		return tinycolor({r: lerp(s.r, e.r), g: lerp(s.g, e.g), b: lerp(s.b, e.b)});
	}
};
開發者ID:UnlitStudio,項目名稱:PlazaPlus,代碼行數:12,代碼來源:colorLerp.ts

示例8: changeStats

export function changeStats(
  stats: Stats, changes: PartialStats,
  min: Stats = { health: 0, agility: 0, intelligence: 0, strength: 0 },
  max: Stats = { health: Infinity, agility: Infinity, intelligence: Infinity, strength: Infinity }
): Stats {
  const completeChange = partialStatsToCompleteStats(changes);

  stats.health = _.clamp(
    stats.health + completeChange.health, min.health, max.health
  );
  stats.strength = _.clamp(
    stats.strength + completeChange.strength, min.strength, max.strength
  );
  stats.intelligence = _.clamp(
    stats.intelligence + completeChange.intelligence, min.intelligence, max.intelligence
  );
  stats.agility = _.clamp(
    stats.agility + completeChange.agility, min.agility, max.agility
  );

  return stats;
}
開發者ID:zthomae,項目名稱:xanadu,代碼行數:22,代碼來源:stats.ts

示例9: setEditableValue

 // @Override
 setEditableValue(model: any, propertyName: string, value: string | number | undefined) {
   if (typeof value !== 'number') {
     value = parseFloat(value);
   }
   if (isNaN(value)) {
     return;
   }
   value = _.clamp(value, this.min, this.max);
   if (this.isInteger) {
     value = Math.floor(value);
   }
   model[propertyName] = value;
 }
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:14,代碼來源:NumberProperty.ts

示例10: setter

 // @Override
 protected setter(model: any, propertyName: string, value: string | number | undefined) {
   if (typeof value === 'string') {
     value = Number(value);
   }
   if (typeof value === 'number') {
     if (!isNaN(value)) {
       value = _.clamp(value, this.min, this.max);
       if (this.isInteger) {
         value = Math.floor(value);
       }
     }
   }
   model[`${propertyName}_`] = value;
 }
開發者ID:arpitsaan,項目名稱:ShapeShifter,代碼行數:15,代碼來源:NumberProperty.ts


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