UI for adding rows and columns.

This commit is contained in:
Mal
2020-02-09 00:29:46 +01:00
parent de3c73a508
commit d43cd56d65
14 changed files with 317 additions and 12 deletions

View File

@@ -27,7 +27,7 @@ export default class Terrain
this.htmlElement.style.height = this.tileset.getTileHeight() * this.tilesY + 'px';
for (let r = 0; r < this.tilesY; r++) {
this.insertRow();
this._insertRow();
}
window.addEventListener(
@@ -48,15 +48,17 @@ export default class Terrain
return this.tileset;
}
addRows(quantity, index)
addRows(index, quantity = 1)
{
for (let q = 0; q < quantity; q++) {
this.insertRow(index);
this._insertRow(index);
this.tilesY++;
}
this.htmlElement.style.height = this.tileset.getTileHeight() * this.tilesY + 'px';
}
insertRow(index = undefined)
_insertRow(index = undefined)
{
let row = [];
let tr = document.createElement('tr');
@@ -77,6 +79,32 @@ export default class Terrain
}
}
addColumns(index, quantity = 1)
{
for (let c = 0; c < quantity; c++) {
this._insertColumn(index);
this.tilesX++;
}
this.htmlElement.style.width = this.tileset.getTileWidth() * this.tilesX + 'px';
}
_insertColumn(index = undefined)
{
if (index === undefined || index > this.tilesX - 1) {
index = this.tilesX;
}
for (let y = 0; y < this.tilesY; y++) {
let field = new Field(this.tileset);
this.fields[y] = this.fields[y].slice(0, index).concat(field).concat(this.fields[y].slice(index));
let htmlRow = this.htmlElement.childNodes[y];
htmlRow.insertBefore(field.getElement(), htmlRow.childNodes[index]);
}
}
setFieldIndex(x, y, index)
{
this.fields[y][x].setIndex(index);