<template> <Controls :layer="tiles" :depth="0" /> </template> <script setup lang="ts"> import config from '@/config' import { useScene } from 'phavuer' import { useZoneStore } from '@/stores/zoneStore' import { onBeforeMount, onBeforeUnmount } from 'vue' import { placeTile, setAllTiles } from '@/composables/zoneComposable' import Controls from '@/components/utilities/Controls.vue' const emit = defineEmits(['tilemap:create']) const zoneStore = useZoneStore() const scene = useScene() const zoneTilemap = createTilemap() const tiles = createTileLayer() function createTilemap() { const zoneData = new Phaser.Tilemaps.MapData({ width: zoneStore.zone?.width, height: zoneStore.zone?.height, tileWidth: config.tile_size.x, tileHeight: config.tile_size.y, orientation: Phaser.Tilemaps.Orientation.ISOMETRIC, format: Phaser.Tilemaps.Formats.ARRAY_2D }) const tilemap = new Phaser.Tilemaps.Tilemap(scene, zoneData) emit('tilemap:create', tilemap) return tilemap } function createTileLayer() { const tilesFromZone = zoneStore.zone?.tiles || [] const uniqueTiles = new Set(tilesFromZone.flat().filter(Boolean)) const tilesetImages = Array.from(uniqueTiles).map((tile, index) => { return zoneTilemap.addTilesetImage(tile, tile, config.tile_size.x, config.tile_size.y, 1, 2, index + 1, { x: 0, y: -config.tile_size.y }) }) as any // Add blank tile tilesetImages.push(zoneTilemap.addTilesetImage('blank_tile', 'blank_tile', config.tile_size.x, config.tile_size.y, 1, 2, 0, { x: 0, y: -config.tile_size.y })) const layer = zoneTilemap.createBlankLayer('tiles', tilesetImages, 0, config.tile_size.y) as Phaser.Tilemaps.TilemapLayer layer.setDepth(0) layer.setCullPadding(2, 2) return layer } onBeforeMount(() => { if (!zoneStore.zone?.tiles) { return } setAllTiles(zoneTilemap, tiles, zoneStore.zone.tiles) }) onBeforeUnmount(() => { zoneTilemap.destroyLayer('tiles') zoneTilemap.removeAllLayers() zoneTilemap.destroy() }) </script>