Room Creating: Place Kitchen Furniture #11
296
Cargo.lock
generated
|
@ -136,6 +136,12 @@ version = "0.12.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "33954243bd79057c2de7338850b85983a44588021f8a5fee574a8888c6de4344"
|
checksum = "33954243bd79057c2de7338850b85983a44588021f8a5fee574a8888c6de4344"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "arrayref"
|
||||||
|
version = "0.3.7"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6b4930d2cb77ce62f89ee5d5289b4ac049559b1c45539271f5ed4fdc7db34545"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "arrayvec"
|
name = "arrayvec"
|
||||||
version = "0.7.4"
|
version = "0.7.4"
|
||||||
|
@ -207,6 +213,12 @@ dependencies = [
|
||||||
"rustc-demangle",
|
"rustc-demangle",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "base64"
|
||||||
|
version = "0.22.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "72b3254f16251a8381aa12e40e3c4d2f0199f8c6508fbecb9d91f575e0fbb8c6"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "bimap"
|
name = "bimap"
|
||||||
version = "0.6.3"
|
version = "0.6.3"
|
||||||
|
@ -797,6 +809,12 @@ version = "0.11.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "0c87e182de0887fd5361989c677c4e8f5000cd9491d6d563161a8f3a5519fc7f"
|
checksum = "0c87e182de0887fd5361989c677c4e8f5000cd9491d6d563161a8f3a5519fc7f"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "data-url"
|
||||||
|
version = "0.3.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "5c297a1c74b71ae29df00c3e22dd9534821d60eb9af5a0192823fa2acea70c2a"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "dispatch"
|
name = "dispatch"
|
||||||
version = "0.2.0"
|
version = "0.2.0"
|
||||||
|
@ -1027,6 +1045,12 @@ dependencies = [
|
||||||
"miniz_oxide",
|
"miniz_oxide",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "float-cmp"
|
||||||
|
version = "0.9.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "98de4bbd547a563b716d8dfa9aad1cb19bfab00f4fa09a6a4ed21dbcf44ce9c4"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "flume"
|
name = "flume"
|
||||||
version = "0.11.0"
|
version = "0.11.0"
|
||||||
|
@ -1036,6 +1060,29 @@ dependencies = [
|
||||||
"spin",
|
"spin",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "fontconfig-parser"
|
||||||
|
version = "0.5.6"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6a595cb550439a117696039dfc69830492058211b771a2a165379f2a1a53d84d"
|
||||||
|
dependencies = [
|
||||||
|
"roxmltree 0.19.0",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "fontdb"
|
||||||
|
version = "0.18.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e32eac81c1135c1df01d4e6d4233c47ba11f6a6d07f33e0bba09d18797077770"
|
||||||
|
dependencies = [
|
||||||
|
"fontconfig-parser",
|
||||||
|
"log",
|
||||||
|
"memmap2",
|
||||||
|
"slotmap",
|
||||||
|
"tinyvec",
|
||||||
|
"ttf-parser 0.21.1",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "fontdue"
|
name = "fontdue"
|
||||||
version = "0.7.3"
|
version = "0.7.3"
|
||||||
|
@ -1131,6 +1178,16 @@ dependencies = [
|
||||||
"wasm-bindgen",
|
"wasm-bindgen",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "gif"
|
||||||
|
version = "0.13.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "3fb2d69b19215e18bb912fa30f7ce15846e301408695e44e0ef719f1da9e19f2"
|
||||||
|
dependencies = [
|
||||||
|
"color_quant",
|
||||||
|
"weezl",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "gimli"
|
name = "gimli"
|
||||||
version = "0.28.1"
|
version = "0.28.1"
|
||||||
|
@ -1286,6 +1343,12 @@ dependencies = [
|
||||||
"winapi",
|
"winapi",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "heck"
|
||||||
|
version = "0.5.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "2304e00983f87ffb38b55b444b5e3b60a884b5d30c0fca7d82fe33449bbe55ea"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "hecs"
|
name = "hecs"
|
||||||
version = "0.10.5"
|
version = "0.10.5"
|
||||||
|
@ -1378,6 +1441,12 @@ dependencies = [
|
||||||
"png",
|
"png",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "imagesize"
|
||||||
|
version = "0.12.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "029d73f573d8e8d63e6d5020011d3255b28c3ba85d6cf870a07184ed23de9284"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "indexmap"
|
name = "indexmap"
|
||||||
version = "2.2.6"
|
version = "2.2.6"
|
||||||
|
@ -1545,6 +1614,16 @@ dependencies = [
|
||||||
"libc",
|
"libc",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "kurbo"
|
||||||
|
version = "0.11.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6e5aa9f0f96a938266bdb12928a67169e8d22c6a786fda8ed984b85e6ba93c3c"
|
||||||
|
dependencies = [
|
||||||
|
"arrayvec",
|
||||||
|
"smallvec",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "lazy_static"
|
name = "lazy_static"
|
||||||
version = "1.5.0"
|
version = "1.5.0"
|
||||||
|
@ -1992,6 +2071,12 @@ version = "2.3.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e"
|
checksum = "e3148f5046208a5d56bcfc03053e3ca6334e51da8dfb19b6cdc8b306fae3283e"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "pico-args"
|
||||||
|
version = "0.5.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "5be167a7af36ee22fe3115051bc51f6e6c7054c9348e28deb4f49bd6f705a315"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "pin-project-lite"
|
name = "pin-project-lite"
|
||||||
version = "0.2.14"
|
version = "0.2.14"
|
||||||
|
@ -2043,7 +2128,9 @@ name = "powercreep"
|
||||||
version = "0.1.0"
|
version = "0.1.0"
|
||||||
dependencies = [
|
dependencies = [
|
||||||
"comfy",
|
"comfy",
|
||||||
|
"heck",
|
||||||
"log",
|
"log",
|
||||||
|
"resvg",
|
||||||
]
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
|
@ -2224,6 +2311,31 @@ version = "1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "19b30a45b0cd0bcca8037f3d0dc3421eaf95327a17cad11964fb8179b4fc4832"
|
checksum = "19b30a45b0cd0bcca8037f3d0dc3421eaf95327a17cad11964fb8179b4fc4832"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "resvg"
|
||||||
|
version = "0.42.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "944d052815156ac8fa77eaac055220e95ba0b01fa8887108ca710c03805d9051"
|
||||||
|
dependencies = [
|
||||||
|
"gif",
|
||||||
|
"jpeg-decoder",
|
||||||
|
"log",
|
||||||
|
"pico-args",
|
||||||
|
"rgb",
|
||||||
|
"svgtypes",
|
||||||
|
"tiny-skia",
|
||||||
|
"usvg",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "rgb"
|
||||||
|
version = "0.8.40"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a7439be6844e40133eda024efd85bf07f59d0dd2f59b10c00dd6cfb92cc5c741"
|
||||||
|
dependencies = [
|
||||||
|
"bytemuck",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ringbuf"
|
name = "ringbuf"
|
||||||
version = "0.3.3"
|
version = "0.3.3"
|
||||||
|
@ -2233,6 +2345,18 @@ dependencies = [
|
||||||
"crossbeam-utils",
|
"crossbeam-utils",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "roxmltree"
|
||||||
|
version = "0.19.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "3cd14fd5e3b777a7422cca79358c57a8f6e3a703d9ac187448d0daf220c2407f"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "roxmltree"
|
||||||
|
version = "0.20.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6c20b6793b5c2fa6553b250154b78d6d0db37e72700ae35fad9387a46f487c97"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "rustc-demangle"
|
name = "rustc-demangle"
|
||||||
version = "0.1.24"
|
version = "0.1.24"
|
||||||
|
@ -2258,6 +2382,22 @@ dependencies = [
|
||||||
"windows-sys 0.52.0",
|
"windows-sys 0.52.0",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "rustybuzz"
|
||||||
|
version = "0.14.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "cfb9cf8877777222e4a3bc7eb247e398b56baba500c38c1c46842431adc8b55c"
|
||||||
|
dependencies = [
|
||||||
|
"bitflags 2.6.0",
|
||||||
|
"bytemuck",
|
||||||
|
"smallvec",
|
||||||
|
"ttf-parser 0.21.1",
|
||||||
|
"unicode-bidi-mirroring",
|
||||||
|
"unicode-ccc",
|
||||||
|
"unicode-properties",
|
||||||
|
"unicode-script",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "same-file"
|
name = "same-file"
|
||||||
version = "1.0.6"
|
version = "1.0.6"
|
||||||
|
@ -2323,6 +2463,21 @@ version = "1.0.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "832ddd7df0d98d6fd93b973c330b7c8e0742d5cb8f1afc7dea89dba4d2531aa1"
|
checksum = "832ddd7df0d98d6fd93b973c330b7c8e0742d5cb8f1afc7dea89dba4d2531aa1"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "simplecss"
|
||||||
|
version = "0.2.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "a11be7c62927d9427e9f40f3444d5499d868648e2edbc4e2116de69e7ec0e89d"
|
||||||
|
dependencies = [
|
||||||
|
"log",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "siphasher"
|
||||||
|
version = "1.0.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "56199f7ddabf13fe5074ce809e7d3f42b42ae711800501b5b16ea82ad029c39d"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "slab"
|
name = "slab"
|
||||||
version = "0.4.9"
|
version = "0.4.9"
|
||||||
|
@ -2414,12 +2569,31 @@ version = "1.1.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f"
|
checksum = "a2eb9349b6444b326872e140eb1cf5e7c522154d69e7a0ffb0fb81c06b37543f"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "strict-num"
|
||||||
|
version = "0.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "6637bab7722d379c8b41ba849228d680cc12d0a45ba1fa2b48f2a30577a06731"
|
||||||
|
dependencies = [
|
||||||
|
"float-cmp",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "svg_fmt"
|
name = "svg_fmt"
|
||||||
version = "0.4.3"
|
version = "0.4.3"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "20e16a0f46cf5fd675563ef54f26e83e20f2366bcf027bcb3cc3ed2b98aaf2ca"
|
checksum = "20e16a0f46cf5fd675563ef54f26e83e20f2366bcf027bcb3cc3ed2b98aaf2ca"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "svgtypes"
|
||||||
|
version = "0.15.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "fae3064df9b89391c9a76a0425a69d124aee9c5c28455204709e72c39868a43c"
|
||||||
|
dependencies = [
|
||||||
|
"kurbo",
|
||||||
|
"siphasher",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "symphonia"
|
name = "symphonia"
|
||||||
version = "0.5.4"
|
version = "0.5.4"
|
||||||
|
@ -2572,6 +2746,47 @@ version = "0.6.1"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "92e170f93360bf9ae6fe3c31116bbf27adb1d054cedd6bc3d7857e34f2d98d0b"
|
checksum = "92e170f93360bf9ae6fe3c31116bbf27adb1d054cedd6bc3d7857e34f2d98d0b"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tiny-skia"
|
||||||
|
version = "0.11.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "83d13394d44dae3207b52a326c0c85a8bf87f1541f23b0d143811088497b09ab"
|
||||||
|
dependencies = [
|
||||||
|
"arrayref",
|
||||||
|
"arrayvec",
|
||||||
|
"bytemuck",
|
||||||
|
"cfg-if",
|
||||||
|
"log",
|
||||||
|
"png",
|
||||||
|
"tiny-skia-path",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tiny-skia-path"
|
||||||
|
version = "0.11.4"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "9c9e7fc0c2e86a30b117d0462aa261b72b7a99b7ebd7deb3a14ceda95c5bdc93"
|
||||||
|
dependencies = [
|
||||||
|
"arrayref",
|
||||||
|
"bytemuck",
|
||||||
|
"strict-num",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tinyvec"
|
||||||
|
version = "1.7.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ce6b6a2fb3a985e99cebfaefa9faa3024743da73304ca1c683a36429613d3d22"
|
||||||
|
dependencies = [
|
||||||
|
"tinyvec_macros",
|
||||||
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "tinyvec_macros"
|
||||||
|
version = "0.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1f3ccbac311fea05f86f61904b462b55fb3df8837a366dfc601a0161d0532f20"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "toml_datetime"
|
name = "toml_datetime"
|
||||||
version = "0.6.6"
|
version = "0.6.6"
|
||||||
|
@ -2611,6 +2826,12 @@ version = "0.15.2"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "7b3e06c9b9d80ed6b745c7159c40b311ad2916abb34a49e9be2653b90db0d8dd"
|
checksum = "7b3e06c9b9d80ed6b745c7159c40b311ad2916abb34a49e9be2653b90db0d8dd"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "ttf-parser"
|
||||||
|
version = "0.21.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "2c591d83f69777866b9126b24c6dd9a18351f177e49d625920d19f989fd31cf8"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "ttf-parser"
|
name = "ttf-parser"
|
||||||
version = "0.24.0"
|
version = "0.24.0"
|
||||||
|
@ -2626,18 +2847,54 @@ dependencies = [
|
||||||
"rustc-hash",
|
"rustc-hash",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-bidi"
|
||||||
|
version = "0.3.15"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "08f95100a766bf4f8f28f90d77e0a5461bbdb219042e7679bebe79004fed8d75"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-bidi-mirroring"
|
||||||
|
version = "0.2.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "23cb788ffebc92c5948d0e997106233eeb1d8b9512f93f41651f52b6c5f5af86"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-ccc"
|
||||||
|
version = "0.2.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "1df77b101bcc4ea3d78dafc5ad7e4f58ceffe0b2b16bf446aeb50b6cb4157656"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-ident"
|
name = "unicode-ident"
|
||||||
version = "1.0.12"
|
version = "1.0.12"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
|
checksum = "3354b9ac3fae1ff6755cb6db53683adb661634f67557942dea4facebec0fee4b"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-properties"
|
||||||
|
version = "0.1.1"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "e4259d9d4425d9f0661581b804cb85fe66a4c631cadd8f490d1c13a35d5d9291"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-script"
|
||||||
|
version = "0.5.6"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ad8d71f5726e5f285a935e9fe8edfd53f0491eb6e9a5774097fdabee7cd8c9cd"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-segmentation"
|
name = "unicode-segmentation"
|
||||||
version = "1.11.0"
|
version = "1.11.0"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "d4c87d22b6e3f4a18d4d40ef354e97c90fcb14dd91d7dc0aa9d8a1172ebf7202"
|
checksum = "d4c87d22b6e3f4a18d4d40ef354e97c90fcb14dd91d7dc0aa9d8a1172ebf7202"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "unicode-vo"
|
||||||
|
version = "0.1.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "b1d386ff53b415b7fe27b50bb44679e2cc4660272694b7b6f3326d8480823a94"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "unicode-width"
|
name = "unicode-width"
|
||||||
version = "0.1.13"
|
version = "0.1.13"
|
||||||
|
@ -2650,6 +2907,33 @@ version = "0.2.4"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c"
|
checksum = "f962df74c8c05a667b5ee8bcf162993134c104e96440b663c8daa176dc772d8c"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "usvg"
|
||||||
|
version = "0.42.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "b84ea542ae85c715f07b082438a4231c3760539d902e11d093847a0b22963032"
|
||||||
|
dependencies = [
|
||||||
|
"base64",
|
||||||
|
"data-url",
|
||||||
|
"flate2",
|
||||||
|
"fontdb",
|
||||||
|
"imagesize",
|
||||||
|
"kurbo",
|
||||||
|
"log",
|
||||||
|
"pico-args",
|
||||||
|
"roxmltree 0.20.0",
|
||||||
|
"rustybuzz",
|
||||||
|
"simplecss",
|
||||||
|
"siphasher",
|
||||||
|
"strict-num",
|
||||||
|
"svgtypes",
|
||||||
|
"tiny-skia-path",
|
||||||
|
"unicode-bidi",
|
||||||
|
"unicode-script",
|
||||||
|
"unicode-vo",
|
||||||
|
"xmlwriter",
|
||||||
|
]
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "version_check"
|
name = "version_check"
|
||||||
version = "0.9.4"
|
version = "0.9.4"
|
||||||
|
@ -2866,6 +3150,12 @@ dependencies = [
|
||||||
"wasm-bindgen",
|
"wasm-bindgen",
|
||||||
]
|
]
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "weezl"
|
||||||
|
version = "0.1.8"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "53a85b86a771b1c87058196170769dd264f66c0782acf1ae6cc51bfd64b39082"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "wgpu"
|
name = "wgpu"
|
||||||
version = "0.19.4"
|
version = "0.19.4"
|
||||||
|
@ -3382,6 +3672,12 @@ version = "0.8.20"
|
||||||
source = "registry+https://github.com/rust-lang/crates.io-index"
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
checksum = "791978798f0597cfc70478424c2b4fdc2b7a8024aaff78497ef00f24ef674193"
|
checksum = "791978798f0597cfc70478424c2b4fdc2b7a8024aaff78497ef00f24ef674193"
|
||||||
|
|
||||||
|
[[package]]
|
||||||
|
name = "xmlwriter"
|
||||||
|
version = "0.1.0"
|
||||||
|
source = "registry+https://github.com/rust-lang/crates.io-index"
|
||||||
|
checksum = "ec7a2a501ed189703dba8b08142f057e887dfc4b2cc4db2d343ac6376ba3e0b9"
|
||||||
|
|
||||||
[[package]]
|
[[package]]
|
||||||
name = "zerocopy"
|
name = "zerocopy"
|
||||||
version = "0.7.35"
|
version = "0.7.35"
|
||||||
|
|
|
@ -18,6 +18,10 @@ opt-level = 3
|
||||||
comfy = { version = "0.4.0", features = ["wayland"] }
|
comfy = { version = "0.4.0", features = ["wayland"] }
|
||||||
log = "0.4.22"
|
log = "0.4.22"
|
||||||
|
|
||||||
|
[build-dependencies]
|
||||||
|
heck = "0.5"
|
||||||
|
resvg = "0.42"
|
||||||
|
|
||||||
[patch.crates-io]
|
[patch.crates-io]
|
||||||
# https://github.com/darthdeus/comfy/issues/101
|
# https://github.com/darthdeus/comfy/issues/101
|
||||||
# https://github.com/darthdeus/comfy/pull/102
|
# https://github.com/darthdeus/comfy/pull/102
|
||||||
|
|
21
assets/overworld/fence-bottom-left.svg
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
<svg version="1.1" width="512" height="512" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"
|
||||||
|
stroke="black" stroke-width="1" fill="none">
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="grass.svg"/>
|
||||||
|
|
||||||
|
<!-- continuous upper line of the fence -->
|
||||||
|
<path d="M0,26 v4 h32 v-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M0,26 h32 m-32,4 h32"/>
|
||||||
|
|
||||||
|
<!-- continuous lower line of the fence -->
|
||||||
|
<path d="M0,34 v4 h32 v-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M0,34 h32 m-32,4 h32"/>
|
||||||
|
|
||||||
|
<!-- continuous upper line of the fence, vertical this time -->
|
||||||
|
<path d="M30,32 h4 v32 h-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M30,32 v32 M34,32 v32"/>
|
||||||
|
|
||||||
|
<!-- fence post -->
|
||||||
|
<path d="M28,40 v-16 l4,-4 l4,4 v16 z" fill="saddlebrown"/>
|
||||||
|
|
||||||
|
</svg>
|
Before Width: | Height: | Size: 757 B After Width: | Height: | Size: 757 B |
9
assets/overworld/fence-bottom-right.svg
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<svg version="1.1" width="512" height="512" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"
|
||||||
|
stroke="black" stroke-width="1" fill="none">
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="grass.svg"/>
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="fence-bottom-left.svg"
|
||||||
|
transform="translate(32,0) scale(-1,1) translate(-32,0)"/>
|
||||||
|
|
||||||
|
</svg>
|
Before Width: | Height: | Size: 351 B After Width: | Height: | Size: 351 B |
20
assets/overworld/fence-horiz.svg
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
<svg version="1.1" width="512" height="512" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"
|
||||||
|
stroke="black" stroke-width="1" fill="none">
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="grass.svg"/>
|
||||||
|
|
||||||
|
<!-- continuous upper line of the fence -->
|
||||||
|
<path d="M0,26 v4 h64 v-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M0,26 h64 m-64,4 h64"/>
|
||||||
|
|
||||||
|
<!-- continuous lower line of the fence -->
|
||||||
|
<path d="M0,34 v4 h64 v-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M0,34 h64 m-64,4 h64"/>
|
||||||
|
|
||||||
|
<!-- left fence post -->
|
||||||
|
<path d="M12,40 v-16 l4,-4 l4,4 v16 z" fill="saddlebrown"/>
|
||||||
|
|
||||||
|
<!-- right fence post -->
|
||||||
|
<path d="M44,40 v-16 l4,-4 l4,4 v16 z" fill="saddlebrown"/>
|
||||||
|
|
||||||
|
</svg>
|
Before Width: | Height: | Size: 684 B After Width: | Height: | Size: 684 B |
21
assets/overworld/fence-top-left.svg
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
<svg version="1.1" width="512" height="512" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"
|
||||||
|
stroke="black" stroke-width="1" fill="none">
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="grass.svg"/>
|
||||||
|
|
||||||
|
<!-- continuous upper line of the fence -->
|
||||||
|
<path d="M0,26 v4 h32 v-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M0,26 h32 m-32,4 h32"/>
|
||||||
|
|
||||||
|
<!-- continuous lower line of the fence -->
|
||||||
|
<path d="M0,34 v4 h32 v-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M0,34 h32 m-32,4 h32"/>
|
||||||
|
|
||||||
|
<!-- continuous upper line of the fence, vertical this time -->
|
||||||
|
<path d="M30,0 h4 v32 h-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M30,0 v32 M34,0 v32"/>
|
||||||
|
|
||||||
|
<!-- fence post -->
|
||||||
|
<path d="M28,40 v-16 l4,-4 l4,4 v16 z" fill="saddlebrown"/>
|
||||||
|
|
||||||
|
</svg>
|
Before Width: | Height: | Size: 754 B After Width: | Height: | Size: 754 B |
9
assets/overworld/fence-top-right.svg
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
<svg version="1.1" width="512" height="512" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"
|
||||||
|
stroke="black" stroke-width="1" fill="none">
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="grass.svg"/>
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="fence-top-left.svg"
|
||||||
|
transform="translate(32,0) scale(-1,1) translate(-32,0)"/>
|
||||||
|
|
||||||
|
</svg>
|
Before Width: | Height: | Size: 348 B After Width: | Height: | Size: 348 B |
18
assets/overworld/fence-vert.svg
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
<svg version="1.1" width="512" height="512" viewBox="0 0 64 64" xmlns="http://www.w3.org/2000/svg"
|
||||||
|
stroke="black" stroke-width="1" fill="none">
|
||||||
|
|
||||||
|
<image x="0" y="0" width="64" height="64" href="grass.svg"/>
|
||||||
|
|
||||||
|
<!-- continuous upper line of the fence -->
|
||||||
|
<path d="M30,0 h4 v64 h-4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M30,0 v64 M34,0 v64"/>
|
||||||
|
|
||||||
|
<!-- upper fence post -->
|
||||||
|
<path d="M28,24 h8 v-12 l-4,-4 l-4,4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M30,16 v8 h-2 v-12 l4,-4 l4,4 v12 h-2 v-8 z"/>
|
||||||
|
|
||||||
|
<!-- lower fence post -->
|
||||||
|
<path d="M28,56 h8 v-12 l-4,-4 l-4,4 z" stroke="none" fill="saddlebrown"/>
|
||||||
|
<path d="M30,48 v8 h-2 v-12 l4,-4 l4,4 v12 h-2 v-8 z"/>
|
||||||
|
|
||||||
|
</svg>
|
Before Width: | Height: | Size: 683 B After Width: | Height: | Size: 683 B |
220
build.rs
Normal file
|
@ -0,0 +1,220 @@
|
||||||
|
use heck::ToSnakeCase as _;
|
||||||
|
use resvg::{tiny_skia, usvg};
|
||||||
|
use std::{
|
||||||
|
collections::BTreeMap,
|
||||||
|
env,
|
||||||
|
fs::{self, File},
|
||||||
|
hash::{DefaultHasher, Hash, Hasher},
|
||||||
|
io::{self, Write as _},
|
||||||
|
path::{Path, PathBuf}
|
||||||
|
};
|
||||||
|
|
||||||
|
const TILE_SIZE: u32 = 64;
|
||||||
|
|
||||||
|
#[derive(Default)]
|
||||||
|
struct Assets {
|
||||||
|
/// Assets directly contained within this asset group, mapping their name to the name
|
||||||
|
/// of the constant storing their png.
|
||||||
|
assets: BTreeMap<String, String>,
|
||||||
|
|
||||||
|
/// Asset groups contained within this asset group, mapping their name to the assets
|
||||||
|
/// that group contains.
|
||||||
|
groups: BTreeMap<String, Box<Assets>>
|
||||||
|
}
|
||||||
|
|
||||||
|
struct AssetsWriter {
|
||||||
|
file: File,
|
||||||
|
root: Assets
|
||||||
|
}
|
||||||
|
|
||||||
|
impl AssetsWriter {
|
||||||
|
fn new<P: AsRef<Path>>(path: P) -> Self {
|
||||||
|
let mut file = File::create(path).expect("Failed to create assets file");
|
||||||
|
writeln!(file, "// @generated").unwrap();
|
||||||
|
Self {
|
||||||
|
file,
|
||||||
|
root: Assets::default()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn add_png<P: AsRef<Path>>(
|
||||||
|
&mut self,
|
||||||
|
canonical_path: P,
|
||||||
|
png: tiny_skia::Pixmap
|
||||||
|
) -> String {
|
||||||
|
let mut hasher = DefaultHasher::new();
|
||||||
|
canonical_path.as_ref().hash(&mut hasher);
|
||||||
|
let hash = hasher.finish();
|
||||||
|
let const_name = format!("ASSET_{hash:X}");
|
||||||
|
|
||||||
|
let out_dir = env::var_os("OUT_DIR").unwrap();
|
||||||
|
let out_dir: PathBuf = out_dir.into();
|
||||||
|
png.save_png(out_dir.join(format!("{const_name}.png")))
|
||||||
|
.expect("Failed to save png");
|
||||||
|
|
||||||
|
writeln!(self.file, "// {}", canonical_path.as_ref().display()).unwrap();
|
||||||
|
writeln!(
|
||||||
|
self.file,
|
||||||
|
"const {const_name}: &[u8] = include_bytes!(\"{const_name}.png\");"
|
||||||
|
)
|
||||||
|
.unwrap();
|
||||||
|
|
||||||
|
const_name
|
||||||
|
}
|
||||||
|
|
||||||
|
fn finish(mut self) {
|
||||||
|
fn write_assets_struct(
|
||||||
|
file: &mut File,
|
||||||
|
root: &Assets,
|
||||||
|
indent: &str
|
||||||
|
) -> io::Result<()> {
|
||||||
|
for (group_name, group) in &root.groups {
|
||||||
|
writeln!(file, "{indent}mod {group_name} {{")?;
|
||||||
|
writeln!(file, "{indent}\t#[allow(clippy::wildcard_imports)]")?;
|
||||||
|
writeln!(file, "{indent}\tuse super::*;")?;
|
||||||
|
write_assets_struct(file, group, &format!("{indent}\t"))?;
|
||||||
|
writeln!(file, "}}")?;
|
||||||
|
}
|
||||||
|
|
||||||
|
writeln!(file, "{indent}#[allow(dead_code)]")?;
|
||||||
|
writeln!(file, "{indent}pub struct Assets {{")?;
|
||||||
|
for asset_name in root.assets.keys() {
|
||||||
|
writeln!(
|
||||||
|
file,
|
||||||
|
"{indent}\tpub {}: comfy::TextureHandle,",
|
||||||
|
asset_name.to_snake_case()
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
for group_name in root.groups.keys() {
|
||||||
|
writeln!(
|
||||||
|
file,
|
||||||
|
"{indent}\tpub {group_name}: &'static {group_name}::Assets,"
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
writeln!(file, "{indent}}}")?;
|
||||||
|
|
||||||
|
writeln!(file, "{indent}impl Assets {{")?;
|
||||||
|
writeln!(
|
||||||
|
file,
|
||||||
|
"{indent}\tpub fn load(c: &mut comfy::EngineContext<'_>) {{"
|
||||||
|
)?;
|
||||||
|
for asset_const_name in root.assets.values() {
|
||||||
|
writeln!(file, "{indent}\t\tc.load_texture_from_bytes({asset_const_name:?}, {asset_const_name});")?;
|
||||||
|
}
|
||||||
|
for group_name in root.groups.keys() {
|
||||||
|
writeln!(file, "{indent}\t\t{group_name}::Assets::load(c);")?;
|
||||||
|
}
|
||||||
|
writeln!(file, "{indent}\t}}")?;
|
||||||
|
writeln!(file, "{indent}}}")?;
|
||||||
|
|
||||||
|
writeln!(
|
||||||
|
file,
|
||||||
|
"{indent}pub static ASSETS: comfy::Lazy<Assets> = comfy::Lazy::new(|| Assets {{"
|
||||||
|
)?;
|
||||||
|
for (asset_name, asset_const_name) in &root.assets {
|
||||||
|
writeln!(
|
||||||
|
file,
|
||||||
|
"{indent}\t{}: comfy::texture_id({asset_const_name:?}),",
|
||||||
|
asset_name.to_snake_case()
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
for group_name in root.groups.keys() {
|
||||||
|
writeln!(
|
||||||
|
file,
|
||||||
|
"{indent}\t{group_name}: comfy::Lazy::force(&{group_name}::ASSETS),"
|
||||||
|
)?;
|
||||||
|
}
|
||||||
|
writeln!(file, "{indent}}});")?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
|
}
|
||||||
|
|
||||||
|
write_assets_struct(&mut self.file, &self.root, "").unwrap();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
println!("cargo::rerun-if-changed=build.rs");
|
||||||
|
println!("cargo::rerun-if-changed=assets/");
|
||||||
|
|
||||||
|
let out_dir = env::var_os("OUT_DIR").unwrap();
|
||||||
|
let assets = PathBuf::from(out_dir).join("assets.rs");
|
||||||
|
println!("cargo::warning=Writing assets to {}", assets.display());
|
||||||
|
println!("cargo::rustc-env=ASSETS_RS={}", assets.display());
|
||||||
|
let mut writer = AssetsWriter::new(assets);
|
||||||
|
process_dir("assets", &mut writer, &mut Vec::new());
|
||||||
|
writer.finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
fn process_dir<P: AsRef<Path> + Copy>(
|
||||||
|
dir: P,
|
||||||
|
writer: &mut AssetsWriter,
|
||||||
|
groups: &mut Vec<String>
|
||||||
|
) {
|
||||||
|
for entry in fs::read_dir(dir).expect("Cannot read dir") {
|
||||||
|
let entry = entry.expect("Cannot read dir entry");
|
||||||
|
let path = entry.path();
|
||||||
|
if entry
|
||||||
|
.metadata()
|
||||||
|
.expect("Cannot read dir entry metadata")
|
||||||
|
.is_dir()
|
||||||
|
{
|
||||||
|
groups.push(
|
||||||
|
path.file_name()
|
||||||
|
.unwrap()
|
||||||
|
.to_str()
|
||||||
|
.expect("Non-UTF8 file names aren't allowed")
|
||||||
|
.into()
|
||||||
|
);
|
||||||
|
process_dir(&path, writer, groups);
|
||||||
|
groups.pop();
|
||||||
|
} else if path.extension().map(|ext| ext == "svg").unwrap_or(false) {
|
||||||
|
process_svg(&path, dir, writer, groups);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn process_svg<P: AsRef<Path> + Copy, Q: AsRef<Path>>(
|
||||||
|
file: P,
|
||||||
|
dir: Q,
|
||||||
|
writer: &mut AssetsWriter,
|
||||||
|
groups: &[String]
|
||||||
|
) {
|
||||||
|
let bytes = fs::read(file).expect("Cannot read svg file");
|
||||||
|
let tree = usvg::Tree::from_data(&bytes, &usvg::Options {
|
||||||
|
resources_dir: Some(dir.as_ref().to_owned()),
|
||||||
|
..Default::default()
|
||||||
|
})
|
||||||
|
.unwrap_or_else(|err| {
|
||||||
|
panic!("Cannot parse svg file {}: {err}", file.as_ref().display())
|
||||||
|
});
|
||||||
|
let mut pixmap = tiny_skia::Pixmap::new(TILE_SIZE, TILE_SIZE).unwrap();
|
||||||
|
let transform = tiny_skia::Transform::from_scale(
|
||||||
|
TILE_SIZE as f32 / tree.size().width(),
|
||||||
|
TILE_SIZE as f32 / tree.size().height()
|
||||||
|
);
|
||||||
|
resvg::render(&tree, transform, &mut pixmap.as_mut());
|
||||||
|
|
||||||
|
let const_name = writer.add_png(
|
||||||
|
file.as_ref()
|
||||||
|
.canonicalize()
|
||||||
|
.expect("Failed to canonicalize"),
|
||||||
|
pixmap
|
||||||
|
);
|
||||||
|
let mut group = &mut writer.root;
|
||||||
|
for group_name in groups {
|
||||||
|
if !group.groups.contains_key(group_name) {
|
||||||
|
group.groups.insert(group_name.to_owned(), Box::default());
|
||||||
|
}
|
||||||
|
group = group.groups.get_mut(group_name).unwrap();
|
||||||
|
}
|
||||||
|
group.assets.insert(
|
||||||
|
file.as_ref()
|
||||||
|
.file_stem()
|
||||||
|
.expect("File doesn't have a stem")
|
||||||
|
.to_str()
|
||||||
|
.expect("Non-UTF8 file names aren't allowed")
|
||||||
|
.into(),
|
||||||
|
const_name
|
||||||
|
);
|
||||||
|
}
|
|
@ -1,4 +1,4 @@
|
||||||
use comfy::*;
|
use comfy::{draw_circle, draw_line, error, vec2, Vec2, BLUE};
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Grid {
|
pub struct Grid {
|
||||||
|
|
|
@ -13,7 +13,7 @@ pub struct HouseState {
|
||||||
player: Player
|
player: Player
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn draw(state: &crate::State, _engine: &comfy::EngineContext) {
|
pub fn draw(state: &crate::State, _engine: &comfy::EngineContext<'_>) {
|
||||||
//Draw House
|
//Draw House
|
||||||
state.house.room.draw();
|
state.house.room.draw();
|
||||||
|
|
||||||
|
@ -24,6 +24,6 @@ pub fn draw(state: &crate::State, _engine: &comfy::EngineContext) {
|
||||||
state.house.player.draw();
|
state.house.player.draw();
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn update(state: &mut crate::State, _engine: &mut comfy::EngineContext) {
|
pub fn update(state: &mut crate::State, _engine: &mut comfy::EngineContext<'_>) {
|
||||||
state.house.player.update(&state.house.room.grid);
|
state.house.player.update(&state.house.room.grid);
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
use comfy::*;
|
|
||||||
|
|
||||||
use super::Grid;
|
use super::Grid;
|
||||||
|
use comfy::{delta, draw_circle, is_key_down, vec2, KeyCode, Vec2, RED};
|
||||||
|
use std::collections::HashSet;
|
||||||
|
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct Player {
|
pub struct Player {
|
||||||
|
|
|
@ -3,8 +3,8 @@ pub mod overworld;
|
||||||
|
|
||||||
#[derive(Debug, Default)]
|
#[derive(Debug, Default)]
|
||||||
pub enum Activity {
|
pub enum Activity {
|
||||||
#[default]
|
|
||||||
House,
|
|
||||||
#[allow(dead_code)]
|
#[allow(dead_code)]
|
||||||
|
House,
|
||||||
|
#[default]
|
||||||
Overworld
|
Overworld
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,7 +0,0 @@
|
||||||
use comfy::*;
|
|
||||||
|
|
||||||
pub fn draw(_state: &crate::State, _engine: &comfy::EngineContext) {
|
|
||||||
draw_circle(vec2(0.0, 0.0), 0.5, GREEN, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
pub fn update(_state: &mut crate::State, _engine: &mut comfy::EngineContext) {}
|
|
31
src/activities/overworld/mod.rs
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
use comfy::{
|
||||||
|
draw_rect_outline, draw_sprite, main_camera_mut, EngineContext, IVec2, Vec2, RED,
|
||||||
|
WHITE
|
||||||
|
};
|
||||||
|
|
||||||
|
use crate::game::ZLayer;
|
||||||
|
|
||||||
|
pub mod worldgen;
|
||||||
|
|
||||||
|
pub fn draw(state: &crate::State, _engine: &comfy::EngineContext<'_>) {
|
||||||
|
for (coords, tile) in state.overworld.iter_tiles() {
|
||||||
|
for (i, texture) in tile.textures().iter().rev().enumerate() {
|
||||||
|
let i = i as i32;
|
||||||
|
draw_sprite(
|
||||||
|
*texture,
|
||||||
|
coords.as_vec2(),
|
||||||
|
WHITE,
|
||||||
|
ZLayer::MapMax - i,
|
||||||
|
Vec2::ONE
|
||||||
|
);
|
||||||
|
draw_rect_outline(coords.as_vec2(), Vec2::ONE, 0.1, RED, 10);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn update(state: &mut crate::State, _engine: &mut EngineContext<'_>) {
|
||||||
|
let mut camera = main_camera_mut();
|
||||||
|
camera.center = Vec2::ZERO;
|
||||||
|
camera.zoom = 30.0;
|
||||||
|
state.overworld.get_or_generate_tile(IVec2::ZERO);
|
||||||
|
}
|
453
src/activities/overworld/worldgen.rs
Normal file
|
@ -0,0 +1,453 @@
|
||||||
|
// TODO remove this
|
||||||
|
#![allow(dead_code)]
|
||||||
|
|
||||||
|
use crate::assets::ASSETS;
|
||||||
|
use comfy::{IVec2, TextureHandle, UVec2};
|
||||||
|
use log::info;
|
||||||
|
use std::collections::HashMap;
|
||||||
|
|
||||||
|
pub enum MovementCost {
|
||||||
|
/// No movement possible - cost infinitely high.
|
||||||
|
Infinite,
|
||||||
|
/// There is a path for this movement - movement is cheap.
|
||||||
|
Path,
|
||||||
|
/// There is no path and no obstacle.
|
||||||
|
Default,
|
||||||
|
/// There is an obstacle (i.e. fence) - movement is expensive.
|
||||||
|
Obstacle
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Clone, Copy, Debug)]
|
||||||
|
pub enum Tile {
|
||||||
|
Grass,
|
||||||
|
|
||||||
|
Path {
|
||||||
|
left: bool,
|
||||||
|
right: bool,
|
||||||
|
top: bool,
|
||||||
|
bottom: bool
|
||||||
|
},
|
||||||
|
|
||||||
|
Fence {
|
||||||
|
left: bool,
|
||||||
|
right: bool,
|
||||||
|
top: bool,
|
||||||
|
bottom: bool
|
||||||
|
},
|
||||||
|
|
||||||
|
House {
|
||||||
|
texture: TextureHandle,
|
||||||
|
door: bool
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Tile {
|
||||||
|
pub fn textures(&self) -> Vec<TextureHandle> {
|
||||||
|
match self {
|
||||||
|
Self::Grass => vec![ASSETS.overworld.grass],
|
||||||
|
|
||||||
|
Self::Path {
|
||||||
|
left,
|
||||||
|
right,
|
||||||
|
top,
|
||||||
|
bottom
|
||||||
|
} => {
|
||||||
|
let path_texture = match (left, right, top, bottom) {
|
||||||
|
(true, true, false, false) => ASSETS.overworld.path_horiz,
|
||||||
|
(false, false, true, true) => ASSETS.overworld.path_vert,
|
||||||
|
|
||||||
|
(true, false, true, false) => ASSETS.overworld.path_top_left,
|
||||||
|
(true, false, false, true) => ASSETS.overworld.path_bottom_left,
|
||||||
|
(false, true, true, false) => ASSETS.overworld.path_top_right,
|
||||||
|
(false, true, false, true) => ASSETS.overworld.path_bottom_right,
|
||||||
|
|
||||||
|
(true, true, true, false) => ASSETS.overworld.path_top_left_right,
|
||||||
|
(true, true, false, true) => ASSETS.overworld.path_bottom_left_right,
|
||||||
|
(true, false, true, true) => ASSETS.overworld.path_top_left_bottom,
|
||||||
|
(false, true, true, true) => ASSETS.overworld.path_top_right_bottom,
|
||||||
|
|
||||||
|
(true, true, true, true) => ASSETS.overworld.path_crossing,
|
||||||
|
|
||||||
|
(true, false, false, false)
|
||||||
|
| (false, true, false, false)
|
||||||
|
| (false, false, true, false)
|
||||||
|
| (false, false, false, true) => panic!("We don't have no dead ends"),
|
||||||
|
(false, false, false, false) => panic!("I think you meant grass?!?")
|
||||||
|
};
|
||||||
|
|
||||||
|
vec![ASSETS.overworld.grass, path_texture]
|
||||||
|
},
|
||||||
|
|
||||||
|
Self::Fence {
|
||||||
|
left,
|
||||||
|
right,
|
||||||
|
top,
|
||||||
|
bottom
|
||||||
|
} => {
|
||||||
|
let path_texture = match (left, right, top, bottom) {
|
||||||
|
(true, true, false, false) => ASSETS.overworld.fence_horiz,
|
||||||
|
(false, false, true, true) => ASSETS.overworld.fence_vert,
|
||||||
|
|
||||||
|
(true, false, true, false) => ASSETS.overworld.fence_top_left,
|
||||||
|
(true, false, false, true) => ASSETS.overworld.fence_bottom_left,
|
||||||
|
(false, true, true, false) => ASSETS.overworld.fence_top_right,
|
||||||
|
(false, true, false, true) => ASSETS.overworld.fence_bottom_right,
|
||||||
|
|
||||||
|
(true, true, true, false)
|
||||||
|
| (true, true, false, true)
|
||||||
|
| (true, false, true, true)
|
||||||
|
| (false, true, true, true) => unimplemented!(),
|
||||||
|
|
||||||
|
(true, true, true, true) => unimplemented!(),
|
||||||
|
|
||||||
|
(true, false, false, false)
|
||||||
|
| (false, true, false, false)
|
||||||
|
| (false, false, true, false)
|
||||||
|
| (false, false, false, true) => panic!("We don't have no dead ends"),
|
||||||
|
(false, false, false, false) => panic!("I think you meant grass?!?")
|
||||||
|
};
|
||||||
|
|
||||||
|
vec![ASSETS.overworld.grass, path_texture]
|
||||||
|
},
|
||||||
|
|
||||||
|
Self::House { texture, .. } => {
|
||||||
|
vec![ASSETS.overworld.grass, *texture]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn can_stand_inside(&self) -> bool {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
pub fn movement_cost_left(&self) -> MovementCost {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
pub fn movement_cost_right(&self) -> MovementCost {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
pub fn movement_cost_up(&self) -> MovementCost {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
pub fn movement_cost_down(&self) -> MovementCost {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
pub fn can_enter_house(&self) -> bool {
|
||||||
|
unimplemented!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// The size of a chunk (both width and height). This value squared gives the amount of
|
||||||
|
/// tiles in the chunk.
|
||||||
|
const CHUNK_SIZE: u32 = 100;
|
||||||
|
|
||||||
|
/// Chunks
|
||||||
|
#[derive(Debug)]
|
||||||
|
#[allow(dead_code)]
|
||||||
|
pub struct Chunk {
|
||||||
|
/// All tiles within this chunk.
|
||||||
|
tiles: [Tile; (CHUNK_SIZE * CHUNK_SIZE) as usize],
|
||||||
|
/// All paths that leave this chunk on the left hand side.
|
||||||
|
paths_left: Vec<u32>,
|
||||||
|
/// All paths that leave this chunk on the right hand side.
|
||||||
|
paths_right: Vec<u32>,
|
||||||
|
/// All paths that leave this chunk on the bottom side.
|
||||||
|
paths_bottom: Vec<u32>,
|
||||||
|
/// All paths that leave this chunk on the top side.
|
||||||
|
paths_top: Vec<u32>
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Chunk {
|
||||||
|
pub fn generate_chunk() -> Self {
|
||||||
|
info!("gen chunk");
|
||||||
|
// TODO real worldgen
|
||||||
|
// for the time being we just copy this pre-made house block into the chunk
|
||||||
|
|
||||||
|
fn house(texture: TextureHandle) -> Tile {
|
||||||
|
Tile::House {
|
||||||
|
texture,
|
||||||
|
door: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
let path_horiz = Tile::Path {
|
||||||
|
left: true,
|
||||||
|
right: true,
|
||||||
|
top: false,
|
||||||
|
bottom: false
|
||||||
|
};
|
||||||
|
let path_vert = Tile::Path {
|
||||||
|
left: false,
|
||||||
|
right: false,
|
||||||
|
top: true,
|
||||||
|
bottom: true
|
||||||
|
};
|
||||||
|
let path_crossing = Tile::Path {
|
||||||
|
left: true,
|
||||||
|
right: true,
|
||||||
|
top: true,
|
||||||
|
bottom: true
|
||||||
|
};
|
||||||
|
let fence_horiz = Tile::Fence {
|
||||||
|
left: true,
|
||||||
|
right: true,
|
||||||
|
top: false,
|
||||||
|
bottom: false
|
||||||
|
};
|
||||||
|
let fence_vert = Tile::Fence {
|
||||||
|
left: false,
|
||||||
|
right: false,
|
||||||
|
top: true,
|
||||||
|
bottom: true
|
||||||
|
};
|
||||||
|
let grass = Tile::Grass;
|
||||||
|
|
||||||
|
let block = [
|
||||||
|
[
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_crossing
|
||||||
|
],
|
||||||
|
[
|
||||||
|
Tile::Fence {
|
||||||
|
left: false,
|
||||||
|
right: true,
|
||||||
|
top: false,
|
||||||
|
bottom: true
|
||||||
|
},
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
Tile::Fence {
|
||||||
|
left: true,
|
||||||
|
right: false,
|
||||||
|
top: false,
|
||||||
|
bottom: true
|
||||||
|
},
|
||||||
|
path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
house(ASSETS.overworld.house_roof_top),
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
fence_vert,
|
||||||
|
path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
house(ASSETS.overworld.house_roof_mid_left),
|
||||||
|
house(ASSETS.overworld.house_mid_window),
|
||||||
|
house(ASSETS.overworld.house_roof_mid_right),
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
fence_vert,
|
||||||
|
path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert,
|
||||||
|
grass,
|
||||||
|
house(ASSETS.overworld.house_roof_left),
|
||||||
|
house(ASSETS.overworld.house_mid_window),
|
||||||
|
house(ASSETS.overworld.house_mid),
|
||||||
|
house(ASSETS.overworld.house_mid_window),
|
||||||
|
house(ASSETS.overworld.house_roof_right),
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
fence_vert,
|
||||||
|
path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert,
|
||||||
|
grass,
|
||||||
|
house(ASSETS.overworld.house_bottom_left),
|
||||||
|
house(ASSETS.overworld.house_bottom_door),
|
||||||
|
house(ASSETS.overworld.house_bottom_window),
|
||||||
|
house(ASSETS.overworld.house_bottom_window),
|
||||||
|
house(ASSETS.overworld.house_bottom_right),
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
fence_vert,
|
||||||
|
path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert,
|
||||||
|
grass,
|
||||||
|
grass,
|
||||||
|
Tile::Path {
|
||||||
|
left: false,
|
||||||
|
right: true,
|
||||||
|
top: true,
|
||||||
|
bottom: false
|
||||||
|
},
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
path_horiz,
|
||||||
|
fence_vert,
|
||||||
|
Tile::Path {
|
||||||
|
left: true,
|
||||||
|
right: false,
|
||||||
|
top: true,
|
||||||
|
bottom: true
|
||||||
|
}
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert, grass, grass, grass, grass, grass, grass, grass, grass,
|
||||||
|
grass, fence_vert, path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
fence_vert, grass, grass, grass, grass, grass, grass, grass, grass,
|
||||||
|
grass, fence_vert, path_vert
|
||||||
|
],
|
||||||
|
[
|
||||||
|
Tile::Fence {
|
||||||
|
left: false,
|
||||||
|
right: true,
|
||||||
|
top: true,
|
||||||
|
bottom: false
|
||||||
|
},
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
fence_horiz,
|
||||||
|
Tile::Fence {
|
||||||
|
left: true,
|
||||||
|
right: false,
|
||||||
|
top: true,
|
||||||
|
bottom: false
|
||||||
|
},
|
||||||
|
path_vert
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
|
// and then we copy this pre-made block into our chunk
|
||||||
|
let mut tiles = [Tile::Grass; (CHUNK_SIZE * CHUNK_SIZE) as usize];
|
||||||
|
for y in 0 .. CHUNK_SIZE {
|
||||||
|
for x in 0 .. CHUNK_SIZE {
|
||||||
|
let row = block[y as usize % block.len()];
|
||||||
|
tiles[(y * CHUNK_SIZE + x) as usize] = row[x as usize % row.len()];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Self {
|
||||||
|
tiles,
|
||||||
|
paths_left: vec![],
|
||||||
|
paths_right: vec![],
|
||||||
|
paths_bottom: vec![],
|
||||||
|
paths_top: vec![]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn get_tile(&self, local_chunk_coords: UVec2) -> Option<&Tile> {
|
||||||
|
self.tiles
|
||||||
|
.get((local_chunk_coords.y * CHUNK_SIZE + local_chunk_coords.x) as usize)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// iterate over all tiles and its local chunk coords
|
||||||
|
pub fn iter_tiles(&self) -> impl Iterator<Item = (UVec2, &Tile)> {
|
||||||
|
self.tiles.iter().enumerate().map(|(i, tile)| {
|
||||||
|
let i = i as u32;
|
||||||
|
(UVec2::new(i % CHUNK_SIZE, i / CHUNK_SIZE), tile)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
#[derive(Debug, Default)]
|
||||||
|
pub struct Overworld {
|
||||||
|
chunks: HashMap<IVec2, Chunk>
|
||||||
|
}
|
||||||
|
|
||||||
|
fn world_to_chunk_and_local_coords(world_coords: IVec2) -> (IVec2, UVec2) {
|
||||||
|
let chunk_coords = IVec2 {
|
||||||
|
x: world_coords.x.div_euclid(CHUNK_SIZE as _),
|
||||||
|
y: world_coords.y.div_euclid(CHUNK_SIZE as _)
|
||||||
|
};
|
||||||
|
let local_chunk_coords = UVec2 {
|
||||||
|
x: world_coords.x.rem_euclid(CHUNK_SIZE as _) as _,
|
||||||
|
y: world_coords.y.rem_euclid(CHUNK_SIZE as _) as _
|
||||||
|
};
|
||||||
|
(chunk_coords, local_chunk_coords)
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Overworld {
|
||||||
|
fn get_tile(&self, world_coords: IVec2) -> Option<&Tile> {
|
||||||
|
let (chunk_coords, local_chunk_coords) =
|
||||||
|
world_to_chunk_and_local_coords(world_coords);
|
||||||
|
|
||||||
|
let chunk = self.chunks.get(&chunk_coords)?;
|
||||||
|
chunk.get_tile(local_chunk_coords)
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Return a [`Tile`] at the given world coordinates, or `None` if that tile has not
|
||||||
|
/// been generated yet. use engine/world cordinates.
|
||||||
|
pub fn get_or_generate_tile(&mut self, world_coords: IVec2) -> &Tile {
|
||||||
|
let mut coords = world_coords;
|
||||||
|
coords.y *= -1;
|
||||||
|
self.get_or_generate_tiles_private(coords)
|
||||||
|
}
|
||||||
|
|
||||||
|
fn get_or_generate_tiles_private(&mut self, world_coords: IVec2) -> &Tile {
|
||||||
|
let (chunk_coords, local_chunk_coords) =
|
||||||
|
world_to_chunk_and_local_coords(world_coords);
|
||||||
|
|
||||||
|
let chunk = self
|
||||||
|
.chunks
|
||||||
|
.entry(chunk_coords)
|
||||||
|
.or_insert_with(Chunk::generate_chunk);
|
||||||
|
chunk.get_tile(local_chunk_coords).unwrap()
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Iterate over all generated tiles and its engine/world cordinates. using a [`Tile`] at the given world coordinates, or `None` if that tile has not
|
||||||
|
/// been generated yet.
|
||||||
|
pub fn iter_tiles(&self) -> impl Iterator<Item = (IVec2, &Tile)> {
|
||||||
|
self.iter_tilese_private().map(|(coords, tile)| {
|
||||||
|
let mut w_coords = coords;
|
||||||
|
w_coords.y *= -1;
|
||||||
|
(w_coords, tile)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
|
/// iterate over all tiles and its global coords
|
||||||
|
fn iter_tilese_private(&self) -> impl Iterator<Item = (IVec2, &Tile)> {
|
||||||
|
self.chunks.iter().flat_map(|(chunk_coords, chunk)| {
|
||||||
|
chunk.iter_tiles().map(|(local_coords, tile)| {
|
||||||
|
// never fail because chunksize fits alswas into i32
|
||||||
|
let local_coords: IVec2 = local_coords.try_into().unwrap();
|
||||||
|
(local_coords + (*chunk_coords * CHUNK_SIZE as i32), tile)
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
47
src/game.rs
|
@ -1,20 +1,59 @@
|
||||||
use comfy::*;
|
|
||||||
|
|
||||||
use crate::{
|
use crate::{
|
||||||
activities::{house, overworld, Activity},
|
activities::{house, overworld, Activity},
|
||||||
State
|
State
|
||||||
};
|
};
|
||||||
|
use comfy::EngineContext;
|
||||||
|
use std::ops::Sub;
|
||||||
|
|
||||||
pub fn update(state: &mut State, engine: &mut EngineContext) {
|
#[derive(Debug)]
|
||||||
|
pub struct Ghost {
|
||||||
|
/// current electric charge of the Ghost
|
||||||
|
pub charge: f32,
|
||||||
|
/// max electric charge of the Ghost
|
||||||
|
pub max_charge: f32
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Default for Ghost {
|
||||||
|
fn default() -> Self {
|
||||||
|
Self {
|
||||||
|
charge: 1000.0,
|
||||||
|
max_charge: 1000.0
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#[repr(i32)]
|
||||||
|
pub enum ZLayer {
|
||||||
|
MapMax = -1,
|
||||||
|
Human = 0,
|
||||||
|
Ghost = 1
|
||||||
|
}
|
||||||
|
|
||||||
|
impl From<ZLayer> for i32 {
|
||||||
|
fn from(value: ZLayer) -> Self {
|
||||||
|
// safe because #[repr(i32)]
|
||||||
|
value as i32
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Sub<i32> for ZLayer {
|
||||||
|
type Output = i32;
|
||||||
|
|
||||||
|
fn sub(self, other: i32) -> Self::Output {
|
||||||
|
i32::from(self) - other
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pub fn update(state: &mut State, engine: &mut EngineContext<'_>) {
|
||||||
match state.activity {
|
match state.activity {
|
||||||
Activity::House => house::update(state, engine),
|
Activity::House => house::update(state, engine),
|
||||||
Activity::Overworld => overworld::update(state, engine)
|
Activity::Overworld => overworld::update(state, engine)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn draw(state: &State, engine: &EngineContext) {
|
pub fn draw(state: &State, engine: &EngineContext<'_>) {
|
||||||
match state.activity {
|
match state.activity {
|
||||||
Activity::House => house::draw(state, engine),
|
Activity::House => house::draw(state, engine),
|
||||||
Activity::Overworld => overworld::draw(state, engine)
|
Activity::Overworld => overworld::draw(state, engine)
|
||||||
}
|
}
|
||||||
|
crate::ui::draw(state, engine);
|
||||||
}
|
}
|
||||||
|
|
34
src/main.rs
|
@ -1,14 +1,33 @@
|
||||||
|
#![warn(rust_2018_idioms)]
|
||||||
|
#![deny(clippy::wildcard_imports)]
|
||||||
|
#![forbid(elided_lifetimes_in_paths, unsafe_code)]
|
||||||
|
|
||||||
|
mod assets {
|
||||||
|
include!(env!("ASSETS_RS"));
|
||||||
|
}
|
||||||
|
|
||||||
mod activities;
|
mod activities;
|
||||||
mod game;
|
mod game;
|
||||||
|
mod ui;
|
||||||
|
|
||||||
use activities::{house::HouseState, Activity};
|
use self::{
|
||||||
use comfy::*;
|
activities::{house::HouseState, overworld::worldgen::Overworld, Activity},
|
||||||
|
assets::Assets,
|
||||||
|
game::Ghost
|
||||||
|
};
|
||||||
|
use comfy::{
|
||||||
|
init_game_config, pollster, run_comfy_main_async, EngineContext, EngineState,
|
||||||
|
GameConfig, GameLoop
|
||||||
|
};
|
||||||
|
|
||||||
const GAME_NAME: &str = "Powercreep";
|
const GAME_NAME: &str = "Powercreep";
|
||||||
|
|
||||||
#[derive(Debug, Default)]
|
#[derive(Debug, Default)]
|
||||||
struct State {
|
struct State {
|
||||||
|
setup_called: bool,
|
||||||
activity: Activity,
|
activity: Activity,
|
||||||
|
ghost: Ghost,
|
||||||
|
overworld: Overworld,
|
||||||
house: HouseState
|
house: HouseState
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -17,7 +36,12 @@ impl GameLoop for State {
|
||||||
Self::default()
|
Self::default()
|
||||||
}
|
}
|
||||||
|
|
||||||
fn update(&mut self, engine: &mut EngineContext) {
|
fn update(&mut self, engine: &mut EngineContext<'_>) {
|
||||||
|
if !self.setup_called {
|
||||||
|
setup(engine);
|
||||||
|
self.setup_called = true;
|
||||||
|
}
|
||||||
|
|
||||||
game::update(self, engine);
|
game::update(self, engine);
|
||||||
game::draw(self, engine);
|
game::draw(self, engine);
|
||||||
}
|
}
|
||||||
|
@ -27,6 +51,10 @@ fn config(config: GameConfig) -> GameConfig {
|
||||||
config
|
config
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn setup(ctx: &mut EngineContext<'_>) {
|
||||||
|
Assets::load(ctx);
|
||||||
|
}
|
||||||
|
|
||||||
async fn run() {
|
async fn run() {
|
||||||
init_game_config(GAME_NAME.to_string(), env!("CARGO_PKG_VERSION"), config);
|
init_game_config(GAME_NAME.to_string(), env!("CARGO_PKG_VERSION"), config);
|
||||||
let mut engine = EngineState::new();
|
let mut engine = EngineState::new();
|
||||||
|
|
31
src/ui.rs
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
use crate::State;
|
||||||
|
use comfy::{
|
||||||
|
draw_rect, draw_rect_outline, screen_height, screen_to_world, screen_width,
|
||||||
|
EngineContext, Vec2, BLUE, RED
|
||||||
|
};
|
||||||
|
|
||||||
|
pub fn draw(state: &State, _engine: &EngineContext<'_>) {
|
||||||
|
// seperate fill state into smaller section for better readability
|
||||||
|
let section_count = 5;
|
||||||
|
let mut start_positon = screen_to_world(Vec2::new(screen_width(), screen_height()));
|
||||||
|
// section size in world codinates
|
||||||
|
let section_size = Vec2::new(0.5, 0.25);
|
||||||
|
start_positon.x -= 0.5 * section_size.x + 0.5 * section_size.y;
|
||||||
|
start_positon.y += 0.5 * section_size.y + 0.5 * section_size.y;
|
||||||
|
// draw fill level
|
||||||
|
{
|
||||||
|
let ghost = &state.ghost;
|
||||||
|
let percent = ghost.charge / ghost.max_charge;
|
||||||
|
let mut size = section_size;
|
||||||
|
size.y = section_size.y * section_count as f32 * percent;
|
||||||
|
let mut position = start_positon;
|
||||||
|
position.y += 0.5 * -section_size.y + 0.5 * size.y;
|
||||||
|
draw_rect(position, size, BLUE, 100);
|
||||||
|
}
|
||||||
|
// draw sections
|
||||||
|
for i in 0 .. section_count {
|
||||||
|
let mut position = start_positon;
|
||||||
|
position.y += i as f32 * section_size.y;
|
||||||
|
draw_rect_outline(position, section_size, 0.1, RED, 100);
|
||||||
|
}
|
||||||
|
}
|