52 lines
1.5 KiB
JavaScript
52 lines
1.5 KiB
JavaScript
var deleting;
|
|
function search(twoD,oneD){
|
|
for(var i=0;i<twoD.length;i++){
|
|
if(twoD[i][0] == oneD[0] && twoD[i][1] == oneD[1]) {
|
|
return true;
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
function floodFill(clock,side,index) {
|
|
if(clock.blocks[side] === undefined || clock.blocks[side][index] === undefined){return;}
|
|
var color = clock.blocks[side][index].color;
|
|
for(var x =-1;x<2;x++){
|
|
for(var y =-1;y<2;y++){
|
|
if(x==0 && y==0){continue;}
|
|
if(clock.blocks[(side+x+clock.sides)%clock.sides][index+y] !== undefined){
|
|
if(clock.blocks[(side+x+clock.sides)%clock.sides][index+y].color== color && search(deleting,[(side+x+clock.sides)%clock.sides,index+y]) == -1){
|
|
deleting.push([(side+x+clock.sides)%clock.sides,index+y]);
|
|
floodFill(clock,(side+x+clock.sides)%clock.sides,index+y);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
function consolidateBlocks(clock,side,index){
|
|
for(var i=0;i<clock.sides.length;i++){
|
|
deleted.push(0);
|
|
}
|
|
var sidesChanged =[];
|
|
deleting=[];
|
|
deleting.push([side,index]);
|
|
floodFill(clock,side,index);
|
|
debugger;
|
|
var deleteList= deleting;
|
|
if(deleteList.length<3){return;}
|
|
for(i in deleteList){
|
|
var arr = deleteList[i];
|
|
if(arr !== undefined && arr.length==2) {
|
|
if(sidesChanged.indexOf(arr[0])==-1){
|
|
sidesChanged.push(arr[0]);
|
|
}
|
|
clock.blocks[arr[0]].splice(arr[1]-deleted[arr[0]],1);
|
|
deleted[arr[0]]++;
|
|
}
|
|
}
|
|
sidesChanged.forEach(function(o) {
|
|
MainClock.blocks[o].forEach(function(block) {
|
|
console.log('unsettled');
|
|
block.settled = 0;
|
|
})
|
|
});
|
|
}
|