2013-12-30 11:04:59 +01:00
|
|
|
var AEGIS = function(m)
|
|
|
|
{
|
|
|
|
|
2013-09-29 15:32:52 +02:00
|
|
|
// other map functions
|
2013-12-30 11:04:59 +01:00
|
|
|
m.TERRITORY_PLAYER_MASK = 0x3F;
|
2013-08-17 15:59:53 +02:00
|
|
|
|
2013-12-30 11:04:59 +01:00
|
|
|
m.createObstructionMap = function(gameState, accessIndex, template){
|
2013-08-17 15:59:53 +02:00
|
|
|
var passabilityMap = gameState.getMap();
|
2013-09-29 15:32:52 +02:00
|
|
|
var territoryMap = gameState.ai.territoryMap;
|
2013-08-17 15:59:53 +02:00
|
|
|
|
|
|
|
// default values
|
|
|
|
var placementType = "land";
|
|
|
|
var buildOwn = true;
|
|
|
|
var buildAlly = true;
|
|
|
|
var buildNeutral = true;
|
|
|
|
var buildEnemy = false;
|
|
|
|
// If there is a template then replace the defaults
|
|
|
|
if (template){
|
|
|
|
placementType = template.buildPlacementType();
|
2013-09-29 15:32:52 +02:00
|
|
|
buildOwn = template.hasBuildTerritory("own");
|
|
|
|
buildAlly = template.hasBuildTerritory("ally");
|
|
|
|
buildNeutral = template.hasBuildTerritory("neutral");
|
2013-08-17 15:59:53 +02:00
|
|
|
buildEnemy = template.hasBuildTerritory("enemy");
|
|
|
|
}
|
2013-09-29 15:32:52 +02:00
|
|
|
|
2013-08-17 15:59:53 +02:00
|
|
|
var obstructionMask = gameState.getPassabilityClassMask("foundationObstruction") | gameState.getPassabilityClassMask("building-land");
|
|
|
|
|
|
|
|
if (placementType == "shore")
|
|
|
|
{
|
|
|
|
// TODO: this won't change much, should be cached, it's slow.
|
|
|
|
var obstructionTiles = new Uint8Array(passabilityMap.data.length);
|
|
|
|
var okay = false;
|
|
|
|
for (var x = 0; x < passabilityMap.width; ++x)
|
|
|
|
{
|
|
|
|
for (var y = 0; y < passabilityMap.height; ++y)
|
|
|
|
{
|
|
|
|
var i = x + y*passabilityMap.width;
|
2013-12-30 11:04:59 +01:00
|
|
|
var tilePlayer = (territoryMap.data[i] & m.TERRITORY_PLAYER_MASK);
|
2013-09-29 15:32:52 +02:00
|
|
|
|
|
|
|
if (gameState.ai.myIndex !== gameState.ai.accessibility.landPassMap[i])
|
|
|
|
{
|
|
|
|
obstructionTiles[i] = 0;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if (gameState.isPlayerEnemy(tilePlayer) && tilePlayer !== 0)
|
|
|
|
{
|
|
|
|
obstructionTiles[i] = 0;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
if ((passabilityMap.data[i] & (gameState.getPassabilityClassMask("building-shore") | gameState.getPassabilityClassMask("default"))))
|
|
|
|
{
|
|
|
|
obstructionTiles[i] = 0;
|
|
|
|
continue;
|
|
|
|
}
|
2013-08-17 15:59:53 +02:00
|
|
|
|
2013-09-29 15:32:52 +02:00
|
|
|
okay = false;
|
2013-08-17 15:59:53 +02:00
|
|
|
var positions = [[0,1], [1,1], [1,0], [1,-1], [0,-1], [-1,-1], [-1,0], [-1,1]];
|
|
|
|
var available = 0;
|
|
|
|
for each (var stuff in positions)
|
|
|
|
{
|
|
|
|
var index = x + stuff[0] + (y+stuff[1])*passabilityMap.width;
|
|
|
|
var index2 = x + stuff[0]*2 + (y+stuff[1]*2)*passabilityMap.width;
|
|
|
|
var index3 = x + stuff[0]*3 + (y+stuff[1]*3)*passabilityMap.width;
|
|
|
|
var index4 = x + stuff[0]*4 + (y+stuff[1]*4)*passabilityMap.width;
|
2013-09-29 15:32:52 +02:00
|
|
|
|
|
|
|
if ((passabilityMap.data[index] & gameState.getPassabilityClassMask("default")) && gameState.ai.accessibility.getRegionSizei(index,true) > 500)
|
|
|
|
if ((passabilityMap.data[index2] & gameState.getPassabilityClassMask("default")) && gameState.ai.accessibility.getRegionSizei(index2,true) > 500)
|
|
|
|
if ((passabilityMap.data[index3] & gameState.getPassabilityClassMask("default")) && gameState.ai.accessibility.getRegionSizei(index3,true) > 500)
|
|
|
|
if ((passabilityMap.data[index4] & gameState.getPassabilityClassMask("default")) && gameState.ai.accessibility.getRegionSizei(index4,true) > 500) {
|
2013-08-17 15:59:53 +02:00
|
|
|
if (available < 2)
|
|
|
|
available++;
|
|
|
|
else
|
|
|
|
okay = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// checking for accessibility: if a neighbor is inaccessible, this is too. If it's not on the same "accessible map" as us, we crash-i~u.
|
|
|
|
var radius = 3;
|
|
|
|
for (var xx = -radius;xx <= radius; xx++)
|
|
|
|
for (var yy = -radius;yy <= radius; yy++)
|
|
|
|
{
|
|
|
|
var id = x + xx + (y+yy)*passabilityMap.width;
|
|
|
|
if (id > 0 && id < passabilityMap.data.length)
|
|
|
|
if (gameState.ai.terrainAnalyzer.map[id] === 0 || gameState.ai.terrainAnalyzer.map[id] == 30 || gameState.ai.terrainAnalyzer.map[id] == 40)
|
|
|
|
okay = false;
|
|
|
|
}
|
|
|
|
obstructionTiles[i] = okay ? 255 : 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
var playerID = PlayerID;
|
|
|
|
|
|
|
|
var obstructionTiles = new Uint8Array(passabilityMap.data.length);
|
|
|
|
for (var i = 0; i < passabilityMap.data.length; ++i)
|
|
|
|
{
|
2013-12-30 11:04:59 +01:00
|
|
|
var tilePlayer = (territoryMap.data[i] & m.TERRITORY_PLAYER_MASK);
|
2013-08-17 15:59:53 +02:00
|
|
|
var invalidTerritory = (
|
|
|
|
(!buildOwn && tilePlayer == playerID) ||
|
|
|
|
(!buildAlly && gameState.isPlayerAlly(tilePlayer) && tilePlayer != playerID) ||
|
|
|
|
(!buildNeutral && tilePlayer == 0) ||
|
|
|
|
(!buildEnemy && gameState.isPlayerEnemy(tilePlayer) && tilePlayer != 0)
|
|
|
|
);
|
2013-09-29 15:32:52 +02:00
|
|
|
if (accessIndex)
|
|
|
|
var tileAccessible = (accessIndex === gameState.ai.accessibility.landPassMap[i]);
|
|
|
|
else
|
|
|
|
var tileAccessible = true;
|
2013-08-17 15:59:53 +02:00
|
|
|
if (placementType === "shore")
|
|
|
|
tileAccessible = true;
|
|
|
|
obstructionTiles[i] = (!tileAccessible || invalidTerritory || (passabilityMap.data[i] & obstructionMask)) ? 0 : 255;
|
|
|
|
}
|
|
|
|
}
|
2013-09-29 15:32:52 +02:00
|
|
|
|
2013-12-30 11:04:59 +01:00
|
|
|
var map = new API3.Map(gameState.sharedScript, obstructionTiles);
|
2013-08-17 15:59:53 +02:00
|
|
|
map.setMaxVal(255);
|
|
|
|
|
|
|
|
if (template && template.buildDistance()){
|
|
|
|
var minDist = template.buildDistance().MinDistance;
|
|
|
|
var category = template.buildDistance().FromCategory;
|
|
|
|
if (minDist !== undefined && category !== undefined){
|
2014-01-12 02:07:07 +01:00
|
|
|
gameState.getOwnStructures().forEach(function(ent) {
|
|
|
|
if (ent.buildCategory() === category && ent.position()){
|
|
|
|
var pos = ent.position();
|
|
|
|
var x = Math.round(pos[0] / gameState.cellSize);
|
|
|
|
var z = Math.round(pos[1] / gameState.cellSize);
|
|
|
|
map.addInfluence(x, z, minDist/gameState.cellSize, -255, 'constant');
|
|
|
|
}
|
|
|
|
});
|
2013-08-17 15:59:53 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
return map;
|
|
|
|
};
|
|
|
|
|
2013-09-29 15:32:52 +02:00
|
|
|
|
2013-12-30 11:04:59 +01:00
|
|
|
m.createTerritoryMap = function(gameState) {
|
2013-08-17 15:59:53 +02:00
|
|
|
var map = gameState.ai.territoryMap;
|
|
|
|
|
2013-12-30 11:04:59 +01:00
|
|
|
var ret = new API3.Map(gameState.sharedScript, map.data);
|
2013-08-17 15:59:53 +02:00
|
|
|
|
|
|
|
ret.getOwner = function(p) {
|
2013-12-30 11:04:59 +01:00
|
|
|
return this.point(p) & m.TERRITORY_PLAYER_MASK;
|
2013-08-17 15:59:53 +02:00
|
|
|
}
|
|
|
|
ret.getOwnerIndex = function(p) {
|
2013-12-30 11:04:59 +01:00
|
|
|
return this.map[p] & m.TERRITORY_PLAYER_MASK;
|
2013-08-17 15:59:53 +02:00
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
};
|
2013-12-30 11:04:59 +01:00
|
|
|
|
|
|
|
return m;
|
|
|
|
}(AEGIS);
|