mr-crocs-adventures/tilorswift/js/menu/TilesetPickerWidget.js

79 lines
2.5 KiB
JavaScript
Raw Normal View History

2020-02-04 21:42:14 +01:00
import ButtonTile from "../ButtonTile.js";
import TilorswiftEvent from "../events/TilorswiftEvent.js";
import Widget from "./Widget.js";
2020-02-04 23:03:33 +01:00
import BrushMode from "../BrushMode.js";
2020-02-04 21:42:14 +01:00
export default class TilesetPickerWidget extends Widget
{
2020-02-04 23:03:33 +01:00
constructor(tileset, brush)
2020-02-04 21:42:14 +01:00
{
super('Terrain');
this.tileset = tileset;
2020-02-04 23:03:33 +01:00
this.brush = brush;
2020-02-04 21:42:14 +01:00
this.htmlElement = this.createElementPicker();
this.htmlElementSelector = this.createElementSelector();
this.htmlElement.appendChild(this.htmlElementSelector);
2020-02-04 21:42:14 +01:00
this.loadTileset();
window.addEventListener(
TilorswiftEvent.BUTTON_TILE_CLICKED,
(event) => {
if (this.isActive) {
this.setTile(event.button.index);
2020-02-04 23:03:33 +01:00
this.brush.mode = BrushMode.TERRAIN;
2020-02-04 21:42:14 +01:00
}
}
)
}
loadTileset()
{
for (let t = 0; t < this.tileset.tiles; t++) {
let button = new ButtonTile(this.tileset, t);
this.htmlElementSelector.appendChild(button.getElement());
}
this.htmlElement.style.backgroundImage = 'url("' + this.tileset.image.src + '")';
this.htmlElement.style.backgroundSize = 'auto ' + this.tileset.getTileWidth() + 'px';
}
reloadTileset(tileset)
{
this.tileset = tileset;
this.htmlElementSelector.innerHTML = '';
this.loadTileset();
2020-02-04 21:42:14 +01:00
}
createElementPicker()
{
let htmlElement = document.createElement('div');
htmlElement.id = 'tileset-picker';
htmlElement.style.width = this.tileset.getTileWidth() + 'px';
htmlElement.style.height = this.tileset.getTileHeight() + 'px';
htmlElement.style.backgroundSize = this.tileset.getTileWidth() + 'px ' + this.tileset.getTileHeight() + 'px';
return htmlElement;
}
createElementSelector()
{
let htmlElementSelector = document.createElement('div');
htmlElementSelector.id = 'tileset-selector-widget';
2020-02-04 21:42:14 +01:00
htmlElementSelector.style.width = Math.ceil(Math.sqrt(this.tileset.tiles)) * this.tileset.getTileWidth() + 'px';
htmlElementSelector.style.left = String(this.tileset.getTileWidth() + 1) + 'px';
return htmlElementSelector;
}
setTile(index)
{
let position = -this.tileset.getTileWidth() * index + 'px ' + this.tileset.getTileHeight() + 'px';
this.htmlElement.style.backgroundPosition = position;
}
getElement()
{
return this.htmlElement;
}
}