本文整理匯總了C#中AIHeroClient.GetDashInfo方法的典型用法代碼示例。如果您正苦於以下問題:C# AIHeroClient.GetDashInfo方法的具體用法?C# AIHeroClient.GetDashInfo怎麽用?C# AIHeroClient.GetDashInfo使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類AIHeroClient
的用法示例。
在下文中一共展示了AIHeroClient.GetDashInfo方法的1個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: HandleQ
private static void HandleQ(AIHeroClient comboTarget)
{
var QPrediction = spells[SpellSlot.Q].GetPrediction(comboTarget);
if (QPrediction.Hitchance >= HitChance.High)
{
if (spells[SpellSlot.Q].GetDamage(comboTarget) > comboTarget.Health + 15 &&
getCheckBoxItem(comboMenu, "dz191.bard.combo.qks"))
{
spells[SpellSlot.Q].Cast(QPrediction.CastPosition);
return;
}
var QPushDistance = getSliderItem(miscMenu, "dz191.bard.misc.distance");
var QAccuracy = getSliderItem(miscMenu, "dz191.bard.misc.accuracy");
var PlayerPosition = ObjectManager.Player.ServerPosition;
var BeamStartPositions = new List<Vector3>
{
QPrediction.CastPosition,
QPrediction.UnitPosition,
comboTarget.ServerPosition,
comboTarget.Position
};
if (comboTarget.IsDashing())
{
BeamStartPositions.Add(comboTarget.GetDashInfo().EndPos);
}
var PositionsList = new List<Vector3>();
var CollisionPositions = new List<Vector3>();
foreach (var position in BeamStartPositions)
{
var collisionableObjects = spells[SpellSlot.Q].GetCollision(position.LSTo2D(),
new List<Vector2> { position.LSExtend(PlayerPosition, -QPushDistance).LSTo2D() });
if (collisionableObjects.Any())
{
if (collisionableObjects.Any(h => h is AIHeroClient) &&
collisionableObjects.All(h => h.LSIsValidTarget()))
{
spells[SpellSlot.Q].Cast(QPrediction.CastPosition);
break;
}
for (var i = 0; i < QPushDistance; i += (int)comboTarget.BoundingRadius)
{
CollisionPositions.Add(position.LSExtend(PlayerPosition, -i));
}
}
for (var i = 0; i < QPushDistance; i += (int)comboTarget.BoundingRadius)
{
PositionsList.Add(position.LSExtend(PlayerPosition, -i));
}
}
if (PositionsList.Any())
{
//We don't want to divide by 0 Kappa
var WallNumber = PositionsList.Count(p => p.LSIsWall()) * 1.3f;
var CollisionPositionCount = CollisionPositions.Count;
var Percent = (WallNumber + CollisionPositionCount) / PositionsList.Count;
var AccuracyEx = QAccuracy / 100f;
if (Percent >= AccuracyEx)
{
spells[SpellSlot.Q].Cast(QPrediction.CastPosition);
}
}
}
else if (QPrediction.Hitchance == HitChance.Collision)
{
var QCollision = QPrediction.CollisionObjects;
if (QCollision.Count == 1)
{
spells[SpellSlot.Q].Cast(QPrediction.CastPosition);
}
}
}