本文整理匯總了C#中AIHeroClient.WalkingTime方法的典型用法代碼示例。如果您正苦於以下問題:C# AIHeroClient.WalkingTime方法的具體用法?C# AIHeroClient.WalkingTime怎麽用?C# AIHeroClient.WalkingTime使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類AIHeroClient
的用法示例。
在下文中一共展示了AIHeroClient.WalkingTime方法的2個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: IsPathSafeEx
public bool IsPathSafeEx(Vector2[] path, AIHeroClient hero = null)
{
hero = hero ?? Player.Instance;
for (var i = 0; i < path.Length - 1; i++)
{
var start = path[i];
var end = path[i + 1];
foreach (var pair in _skillshotPolygonCache)
{
var skillshot = pair.Key;
var polygon = pair.Value;
if (polygon.IsInside(start) && polygon.IsInside(end))
{
//var time1 = skillshot.GetAvailableTime(start);
var time2 = skillshot.GetAvailableTime(end);
if (hero.WalkingTime(start, end) >= time2 - Game.Ping)
{
return false;
}
}
else
{
var intersections =
polygon.GetIntersectionPointsWithLineSegment(start, end)
.Concat(new[] {start, end})
.ToList()
.GetSortedPath(start).ToArray();
for (var i2 = 0; i2 < intersections.Length - 1; i2++)
{
var point1 = intersections[i2];
var point2 = intersections[i2 + 1];
if (polygon.IsInside(point2) || polygon.IsInside(point1))
{
//var time1 = polygon.IsInside(point1) ? skillshot.GetAvailableTime(point1) : short.MaxValue;
var time2 = polygon.IsInside(point2) ? skillshot.GetAvailableTime(point2) : short.MaxValue;
if (hero.WalkingTime(point1, point2) >= time2 - Game.Ping)
{
return false;
}
}
}
}
}
}
return true;
}
示例2: IsHeroPathSafe
public bool IsHeroPathSafe(EvadeResult evade, Vector3[] desiredPath, AIHeroClient hero = null)
{
hero = hero ?? Player.Instance;
var path = (desiredPath ?? hero.RealPath()).ToVector2();
return IsPathSafeEx(path, hero);
var polygons = ClippedPolygons;
var points = new List<Vector2>();
for (var i = 0; i < path.Length - 1; i++)
{
var start = path[i];
var end = path[i + 1];
foreach (var pol in polygons)
{
var intersections = pol.GetIntersectionPointsWithLineSegment(start, end);
if (intersections.Length > 0 && !pol.IsInside(hero))
{
return false;
}
points.AddRange(intersections);
}
}
if (points.Count == 1)
{
var walkTime = hero.WalkingTime(points[0]);
return walkTime <= evade.TimeAvailable;
}
return false;
}