1
0
forked from noxious/client

#202 - Enable / disable placed map object preview

This commit is contained in:
Dennis Postma 2025-02-10 01:51:45 +01:00
parent cbd111a05b
commit 390187f353
2 changed files with 12 additions and 14 deletions

View File

@ -1,13 +1,13 @@
<template>
<SelectedPlacedMapObjectComponent v-if="mapEditor.selectedPlacedObject.value" :key="mapEditor.selectedPlacedObject.value.id" :map :placedMapObject="mapEditor.selectedPlacedObject.value" @move="moveMapObject" @rotate="rotatePlacedMapObject" @delete="deletePlacedMapObject" />
<PlacedMapObject v-for="placedMapObject in mapEditor.currentMap.value?.placedMapObjects" :tileMap :tileMapLayer :placedMapObject @pointerdown="clickPlacedMapObject(placedMapObject)" />
<PlacedMapObject v-if="
mapEditor.tool.value === 'pencil' &&
mapEditor.drawMode.value === 'map_object' &&
mapEditor.isPlacedMapObjectPreviewEnabled.value &&
mapEditor.selectedPlacedObject.value && previewPlacedMapObject" :tileMap :tileMapLayer
<PlacedMapObject
v-if="mapEditor.tool.value === 'pencil' && mapEditor.drawMode.value === 'map_object' && mapEditor.isPlacedMapObjectPreviewEnabled.value && mapEditor.selectedPlacedObject.value && previewPlacedMapObject"
:tileMap
:tileMapLayer
:key="previewPlacedMapObject?.id"
:placedMapObject="previewPlacedMapObject" />
:placedMapObject="previewPlacedMapObject as PlacedMapObjectT"
/>
</template>
<script setup lang="ts">
@ -37,7 +37,9 @@ const props = defineProps<{
const previewPosition = ref({ x: 0, y: 0 })
const previewPlacedMapObject = computed(() => ({
...mapEditor.selectedPlacedObject.value!,
id: uuidv4(),
mapObject: mapEditor.selectedMapObject.value?.id,
isRotated: false,
positionX: previewPosition.value.x,
positionY: previewPosition.value.y
}))

View File

@ -93,7 +93,7 @@
<label for="continuous-drawing" class="text-sm font-medium text-gray-200 cursor-pointer"> Continuous Drawing </label>
</div>
<div class="m-4 flex items-center space-x-2">
<input id="show-placed-map-object-preview" @change="toggleShowPlacedMapObjectPreview" v-model="isShowPlacedMapObjectPreviewEnabled" type="checkbox" class="h-4 w-4 rounded border-gray-300 text-blue-600 focus:ring-blue-500" />
<input id="show-placed-map-object-preview" @change="mapEditor.togglePlacedMapObjectPreview()" v-model="isShowPlacedMapObjectPreviewEnabled" type="checkbox" class="h-4 w-4 rounded border-gray-300 text-blue-600 focus:ring-blue-500" />
<label for="show-placed-map-object-preview" class="text-sm font-medium text-gray-200 cursor-pointer"> Show placed map object preview </label>
</div>
</template>
@ -116,7 +116,7 @@ const isMapEditorSettingsModalOpen = ref(false)
const selectPencilOpen = ref(false)
const selectEraserOpen = ref(false)
const isContinuousDrawingEnabled = ref<Boolean>(false)
const isShowPlacedMapObjectPreviewEnabled = ref<Boolean>(false)
const isShowPlacedMapObjectPreviewEnabled = ref<Boolean>(mapEditor.isPlacedMapObjectPreviewEnabled.value)
const listOpen = computed(() => mapEditor.tool.value === 'pencil' && (mapEditor.drawMode.value === 'tile' || mapEditor.drawMode.value === 'map_object'))
// drawMode
@ -141,10 +141,6 @@ function toggleContinuousDrawing() {
mapEditor.setInputMode(isContinuousDrawingEnabled.value ? 'hold' : 'tap')
}
function toggleShowPlacedMapObjectPreview() {
}
function handleModeClick(mode: string, type: 'pencil' | 'eraser') {
setDrawMode(mode)
type === 'pencil' ? setPencilMode() : setEraserMode()