Merge pull request #9144 from Mailaender/opt-find-resource

Optimized FindResources worse case scenario path finding
This commit is contained in:
Pavel Penev
2015-08-25 04:24:05 +03:00
2 changed files with 6 additions and 46 deletions

View File

@@ -353,12 +353,8 @@ namespace OpenRA.Mods.Common.Traits
}
else
{
// A bot order gives us a CPos.Zero TargetLocation, so find some good resources for him:
loc = FindNextResourceForBot(self);
// No more resources? Oh well.
if (!loc.HasValue)
return;
// A bot order gives us a CPos.Zero TargetLocation.
loc = self.Location;
}
var next = new FindResources(self);
@@ -411,45 +407,6 @@ namespace OpenRA.Mods.Common.Traits
}
}
static CPos? FindNextResourceForBot(Actor self)
{
// NOTE: This is only used for the AI to find the next available resource to harvest.
var harvInfo = self.Info.Traits.Get<HarvesterInfo>();
var mobileInfo = self.Info.Traits.Get<MobileInfo>();
var resLayer = self.World.WorldActor.Trait<ResourceLayer>();
var territory = self.World.WorldActor.TraitOrDefault<ResourceClaimLayer>();
// Find any harvestable resources:
var path = self.World.WorldActor.Trait<IPathFinder>().FindPath(
PathSearch.Search(self.World, mobileInfo, self, true,
loc =>
{
var resType = resLayer.GetResource(loc);
if (resType == null)
return false;
// Can the harvester collect this kind of resource?
if (!harvInfo.Resources.Contains(resType.Info.Name))
return false;
if (territory != null)
{
// Another harvester has claimed this resource:
ResourceClaim claim;
if (territory.IsClaimedByAnyoneElse(self, loc, out claim))
return false;
}
return true;
})
.FromPoint(self.Location));
if (path.Count == 0)
return null;
return path[0];
}
public void OnNotifyResourceClaimLost(Actor self, ResourceClaim claim, Actor claimer)
{
if (self == claimer) return;