update board dimensions after window resize

This commit is contained in:
Ali Gator 2022-12-04 18:14:57 +01:00
parent 2c69840d6f
commit 5c21fb2ac3
4 changed files with 43 additions and 17 deletions

View File

@ -18,6 +18,8 @@
import MainMenu from "./components/MainMenu.vue"; import MainMenu from "./components/MainMenu.vue";
import CanvasBoard from "./components/CanvasBoard.vue"; import CanvasBoard from "./components/CanvasBoard.vue";
import MenuReset from "./components/MenuReset.vue"; import MenuReset from "./components/MenuReset.vue";
import { mapWritableState, mapActions } from "pinia";
import { globalStore } from "./stores/index.js";
export default { export default {
name: "App", name: "App",
@ -32,22 +34,35 @@
windowWidth: window.innerWidth, windowWidth: window.innerWidth,
}; };
}, },
methods: { computed: {
toggleMainMenu() { ...mapWritableState(globalStore, {
this.mainMenu = !this.mainMenu; canvasWidth: "canvasWidth",
}, canvasHeight: "canvasHeight",
onResize() { }),
this.windowWidth = window.innerWidth;
},
}, },
mounted() { mounted() {
this.$nextTick(() => { this.$nextTick(() => {
window.addEventListener("resize", this.onResize); window.addEventListener("resize", this.onResize);
}); });
}, },
beforeDestroy() { beforeUnmount() {
window.removeEventListener("resize", this.onResize); window.removeEventListener("resize", this.onResize);
}, },
methods: {
...mapActions(globalStore, ["setBoardWidth", "setBoardHeight"]),
toggleMainMenu() {
this.mainMenu = !this.mainMenu;
},
onResize() {
this.$nextTick(() => {
this.windowWidth = window.innerWidth;
this.canvasWidth = window.innerWidth;
this.canvasHeight = window.innerHeight;
this.setBoardWidth();
this.setBoardHeight();
});
},
},
}; };
</script> </script>
@ -121,8 +136,9 @@
h1 { h1 {
font-size: medium; font-size: medium;
display: flex; display: flex;
justify-content: space-around;
align-items: center; align-items: center;
justify-content: space-between;
padding: 0 10px;
} }
#burger-toggle { #burger-toggle {

View File

@ -38,6 +38,8 @@
getDraw1d: "draw1d", getDraw1d: "draw1d",
getDraw2d: "draw2d", getDraw2d: "draw2d",
getDraw2dLast: "draw2dLast", getDraw2dLast: "draw2dLast",
boardWidth: "boardWidth",
boardHeight: "boardHeight",
}), }),
...mapWritableState(globalStore, { ...mapWritableState(globalStore, {
lastBoard: "lastBoard", lastBoard: "lastBoard",
@ -45,12 +47,6 @@
canvasHeight: "canvasHeight", canvasHeight: "canvasHeight",
getReset: "reset", getReset: "reset",
}), }),
boardWidth: function () {
return Math.floor(this.canvasWidth / this.cellProperties.size);
},
boardHeight: function () {
return Math.floor(this.canvasHeight / this.cellProperties.size);
},
}, },
watch: { watch: {
getDraw1d(value) { getDraw1d(value) {
@ -71,9 +67,15 @@
this.ctx = this.canvas.getContext("2d"); this.ctx = this.canvas.getContext("2d");
this.canvasWidth = this.canvas.parentElement.clientWidth; this.canvasWidth = this.canvas.parentElement.clientWidth;
this.canvasHeight = this.canvas.parentElement.clientHeight; this.canvasHeight = this.canvas.parentElement.clientHeight;
this.setBoardWidth();
this.setBoardHeight();
}, },
methods: { methods: {
...mapActions(globalStore, ["toggleStop"]), ...mapActions(globalStore, [
"toggleStop",
"setBoardWidth",
"setBoardHeight",
]),
drawCanvas(board) { drawCanvas(board) {
const props = this.cellProperties; const props = this.cellProperties;
board.map((row, y) => { board.map((row, y) => {

View File

@ -30,7 +30,7 @@
<style scoped> <style scoped>
.form-field { .form-field {
display: flex; display: flex;
margin: 0; margin: 5px;
justify-content: flex-end; justify-content: flex-end;
} }
</style> </style>

View File

@ -37,6 +37,14 @@ export const globalStore = defineStore("globalStore", {
}; };
}, },
actions: { actions: {
setBoardWidth() {
this.boardWidth = Math.floor(this.canvasWidth / this.cellProperties.size);
},
setBoardHeight() {
this.boardHeight = Math.floor(
this.canvasHeight / this.cellProperties.size
);
},
toggleDraw1d() { toggleDraw1d() {
this.draw1d = true; this.draw1d = true;
}, },