From c610e889d62cb96d0d6e0d76e9dc3ec29695fc82 Mon Sep 17 00:00:00 2001
From: Per Lindgren <per.lindgren@ltu.se>
Date: Mon, 16 Aug 2021 21:58:20 +0200
Subject: [PATCH] changes

---
 Cargo.lock            |  96 +++++++++++++++----------
 Cargo.toml            |   9 ++-
 assets/Dungeon.piskel |   2 +-
 assets/Dungeon.png    | Bin 1944 -> 6303 bytes
 assets/Dungeon.tmx    |  98 +++++++++++++++-----------
 src/main.rs           | 158 +++++++++++++++++-------------------------
 6 files changed, 185 insertions(+), 178 deletions(-)

diff --git a/Cargo.lock b/Cargo.lock
index 8cf8a85..fea9995 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -113,9 +113,9 @@ dependencies = [
 
 [[package]]
 name = "anyhow"
-version = "1.0.42"
+version = "1.0.43"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "595d3cfa7a60d4555cb5067b99f07142a08ea778de5cf993f7b75c7d8fabc486"
+checksum = "28ae2b3dec75a406790005a200b1bd89785afc02517a00ca99ecfe093ee9e6cf"
 
 [[package]]
 name = "approx"
@@ -384,7 +384,6 @@ dependencies = [
 [[package]]
 name = "bevy_ecs_tilemap"
 version = "0.4.1"
-source = "git+https://github.com/perlindgren/bevy_ecs_tilemap?branch=rotate#36b6c80c60010b281c526c244abdacf8ee24b116"
 dependencies = [
  "anyhow",
  "bevy",
@@ -1118,14 +1117,14 @@ dependencies = [
 
 [[package]]
 name = "cpal"
-version = "0.13.3"
+version = "0.13.4"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8351ddf2aaa3c583fa388029f8b3d26f3c7035a20911fdd5f2e2ed7ab57dad25"
+checksum = "98f45f0a21f617cd2c788889ef710b63f075c949259593ea09c826f1e47a2418"
 dependencies = [
  "alsa",
- "core-foundation-sys 0.6.2",
+ "core-foundation-sys 0.8.2",
  "coreaudio-rs",
- "jni",
+ "jni 0.19.0",
  "js-sys",
  "lazy_static",
  "libc",
@@ -1313,9 +1312,9 @@ dependencies = [
 
 [[package]]
 name = "filetime"
-version = "0.2.14"
+version = "0.2.15"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1d34cfa13a63ae058bfa601fe9e313bbdb3746427c1459185464ce0fcf62e1e8"
+checksum = "975ccf83d8d9d0d84682850a38c8169027be83368805971cc4f238c2b245bc98"
 dependencies = [
  "cfg-if 1.0.0",
  "libc",
@@ -1741,9 +1740,9 @@ dependencies = [
 
 [[package]]
 name = "guillotiere"
-version = "0.6.1"
+version = "0.6.2"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "9253eedea82720b2bc91fe831c9ce3a31299955ed5eb19b9ed600a625b686212"
+checksum = "b62d5865c036cb1393e23c50693df631d3f5d7bcca4c04fe4cc0fd592e74a782"
 dependencies = [
  "euclid",
  "svg_fmt",
@@ -1919,6 +1918,20 @@ dependencies = [
  "walkdir",
 ]
 
+[[package]]
+name = "jni"
+version = "0.19.0"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "c6df18c2e3db7e453d3c6ac5b3e9d5182664d28788126d39b91f2d1e22b017ec"
+dependencies = [
+ "cesu8",
+ "combine",
+ "jni-sys",
+ "log",
+ "thiserror",
+ "walkdir",
+]
+
 [[package]]
 name = "jni-sys"
 version = "0.3.0"
@@ -1927,9 +1940,9 @@ checksum = "8eaf4bc02d17cbdd7ff4c7438cafcdf7fb9a4613313ad11b4f8fefe7d3fa0130"
 
 [[package]]
 name = "jobserver"
-version = "0.1.22"
+version = "0.1.23"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "972f5ae5d1cb9c6ae417789196c803205313edde988685da5e3aae0827b9e7fd"
+checksum = "f5ca711fd837261e14ec9e674f092cbb931d3fa1482b017ae59328ddc6f3212b"
 dependencies = [
  "libc",
 ]
@@ -1977,9 +1990,9 @@ checksum = "830d08ce1d1d941e6b30645f1a0eb5643013d835ce3779a5fc208261dbe10f55"
 
 [[package]]
 name = "libc"
-version = "0.2.98"
+version = "0.2.99"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "320cfe77175da3a483efed4bc0adc1968ca050b098ce4f2f1c13a56626128790"
+checksum = "a7f823d141fe0a24df1e23b4af4e3c7ba9e5966ec514ea068c93024aa7deb765"
 
 [[package]]
 name = "libflate"
@@ -2101,6 +2114,15 @@ version = "2.4.0"
 source = "registry+https://github.com/rust-lang/crates.io-index"
 checksum = "b16bd47d9e329435e309c58469fe0791c2d0d1ba96ec0954152a5ae2b04387dc"
 
+[[package]]
+name = "memoffset"
+version = "0.6.4"
+source = "registry+https://github.com/rust-lang/crates.io-index"
+checksum = "59accc507f1338036a0477ef61afdae33cde60840f4dfe481319ce3ad116ddf9"
+dependencies = [
+ "autocfg",
+]
+
 [[package]]
 name = "metal"
 version = "0.21.0"
@@ -2255,7 +2277,7 @@ checksum = "8794322172319b972f528bf90c6b467be0079f1fa82780ffb431088e741a73ab"
 dependencies = [
  "jni-sys",
  "ndk-sys",
- "num_enum 0.5.2",
+ "num_enum 0.5.3",
  "thiserror",
 ]
 
@@ -2320,14 +2342,15 @@ dependencies = [
 
 [[package]]
 name = "nix"
-version = "0.20.0"
+version = "0.20.1"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "fa9b4819da1bc61c0ea48b63b7bc8604064dd43013e7cc325df098d49cd7c18a"
+checksum = "df8e5e343312e7fbeb2a52139114e9e702991ef9c2aea6817ff2440b35647d56"
 dependencies = [
  "bitflags",
  "cc",
  "cfg-if 1.0.0",
  "libc",
+ "memoffset",
 ]
 
 [[package]]
@@ -2488,12 +2511,12 @@ dependencies = [
 
 [[package]]
 name = "num_enum"
-version = "0.5.2"
+version = "0.5.3"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "e5adf0198d427ee515335639f275e806ca01acf9f07d7cf14bb36a10532a6169"
+checksum = "ee2c8fd66061a707503d515639b8af10fd3807a5b5ee6959f7ff1bd303634bd5"
 dependencies = [
  "derivative",
- "num_enum_derive 0.5.2",
+ "num_enum_derive 0.5.3",
 ]
 
 [[package]]
@@ -2510,9 +2533,9 @@ dependencies = [
 
 [[package]]
 name = "num_enum_derive"
-version = "0.5.2"
+version = "0.5.3"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "b1def5a3f69d4707d8a040b12785b98029a39e8c610ae685c7f6265669767482"
+checksum = "474fd1d096da3ad17084694eebed40ba09c4a36c5255cd772bd8b98859cc562e"
 dependencies = [
  "proc-macro-crate 1.0.0",
  "proc-macro2",
@@ -2545,7 +2568,7 @@ version = "0.4.2"
 source = "registry+https://github.com/rust-lang/crates.io-index"
 checksum = "dfa187b38ae20374617b7ad418034ed3dc90ac980181d211518bd03537ae8f8d"
 dependencies = [
- "jni",
+ "jni 0.18.0",
  "ndk 0.3.0",
  "ndk-glue 0.3.0",
  "num-derive",
@@ -2760,9 +2783,9 @@ checksum = "831eb2fcb5b72b09c72a3f2d24c09a28d79886512827cd4674d9bac10557f16a"
 
 [[package]]
 name = "redox_syscall"
-version = "0.2.9"
+version = "0.2.10"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "5ab49abadf3f9e1c4bc499e8845e152ad87d2ad2d30371841171169e9d75feee"
+checksum = "8383f39639269cde97d255a32bdb68c047337295414940c68bdd30c2e13203ff"
 dependencies = [
  "bitflags",
 ]
@@ -2947,9 +2970,9 @@ dependencies = [
 
 [[package]]
 name = "sharded-slab"
-version = "0.1.1"
+version = "0.1.3"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "79c719719ee05df97490f80a45acfc99e5a30ce98a1e4fb67aee422745ae14e3"
+checksum = "740223c51853f3145fe7c90360d2d4232f2b62e3449489c207eccde818979982"
 dependencies = [
  "lazy_static",
 ]
@@ -2962,9 +2985,9 @@ checksum = "7fdf1b9db47230893d76faad238fd6097fd6d6a9245cd7a4d90dbd639536bbd2"
 
 [[package]]
 name = "slab"
-version = "0.4.3"
+version = "0.4.4"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "f173ac3d1a7e3b28003f40de0b5ce7fe2710f9b9dc3fc38664cebee46b3b6527"
+checksum = "c307a32c1c5c437f38c7fd45d753050587732ba8628319fbdf12a7e289ccc590"
 
 [[package]]
 name = "slice-deque"
@@ -3020,9 +3043,9 @@ dependencies = [
 
 [[package]]
 name = "spirv-std-macros"
-version = "0.4.0-alpha.10"
+version = "0.4.0-alpha.12"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8b9b334f272ad19ae3e071b0d9d3ca275843c77b39f85e29d3908fa2fb6a7cb8"
+checksum = "207e8515dfbb48bff03f64bf5f8388d4e0f2f526ee769cc6556df98477098ca5"
 dependencies = [
  "heck",
  "proc-macro2",
@@ -3033,9 +3056,9 @@ dependencies = [
 
 [[package]]
 name = "spirv-types"
-version = "0.4.0-alpha.10"
+version = "0.4.0-alpha.12"
 source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "1cfb357212185d2175e5f92c35902f0dc7590cd05121239b22251d360ef01c53"
+checksum = "71cc4b8f7ec707459fdeddb4f137109947045592f5b0c139f7bf1360058bac6b"
 
 [[package]]
 name = "spirv_cross"
@@ -3209,9 +3232,8 @@ checksum = "7572415bd688d401c52f6e36f4c8e805b9ae1622619303b9fa835d531db0acae"
 
 [[package]]
 name = "tiled"
-version = "0.9.5"
-source = "registry+https://github.com/rust-lang/crates.io-index"
-checksum = "8c9b76189425fed476c9cb0e2a97adb0c6c9d370bf69a57cb951814e77a5fe63"
+version = "0.9.6"
+source = "git+https://github.com/perlindgren/rs-tiled?branch=parallax#8e62df52ead53976c1587ce2cb50043176f16cb0"
 dependencies = [
  "base64 0.10.1",
  "libflate",
diff --git a/Cargo.toml b/Cargo.toml
index cea0fe1..353b620 100644
--- a/Cargo.toml
+++ b/Cargo.toml
@@ -7,9 +7,14 @@ edition = "2018"
 
 [dependencies]
 bevy = { version = "0.5.0", features = ["dynamic"] }
-bevy_ecs_tilemap = { git = "https://github.com/perlindgren/bevy_ecs_tilemap", branch = "rotate", version = "0.4.1", features = ["tiled_map"]} 
+# bevy_ecs_tilemap = { git = "https://github.com/perlindgren/bevy_ecs_tilemap", branch = "rotate", version = "0.4.1", features = ["tiled_map"]} 
+# bevy_ecs_tilemap = { git = "https://github.com/perlindgren/bevy_ecs_tilemap", branch = "tiled_animation", version = "0.4.0", features = ["tiled_map"]} 
+# bevy_ecs_tilemap = { git = "https://github.com/perlindgren/bevy_ecs_tilemap", branch = "animation_and_rotation", version = "0.4.1", features = ["tiled_map"]} 
+bevy_ecs_tilemap = { path = "../bevydev/bevy_ecs_tilemap", features = [
+    "tiled_map",
+] }
 rand = "0.8.4"
 env_logger = "0.9"
 log = "0.4"
 
-# bevy = { version = "0.5.0" }
\ No newline at end of file
+# bevy = { version = "0.5.0" }
diff --git a/assets/Dungeon.piskel b/assets/Dungeon.piskel
index ecbf4ce..e951ef3 100644
--- a/assets/Dungeon.piskel
+++ b/assets/Dungeon.piskel
@@ -1 +1 @@
-{"modelVersion":2,"piskel":{"name":"Dungeon","description":"","fps":12,"height":160,"width":160,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":1,\"chunks\":[{\"layout\":[[0]],\"base64PNG\":\"\"}]}"]}}
\ No newline at end of file
+{"modelVersion":2,"piskel":{"name":"Dungeon","description":"","fps":12,"height":160,"width":160,"layers":["{\"name\":\"Layer 1\",\"opacity\":1,\"frameCount\":1,\"chunks\":[{\"layout\":[[0]],\"base64PNG\":\"\"}]}"]}}
\ No newline at end of file
diff --git a/assets/Dungeon.png b/assets/Dungeon.png
index abfba06928a05b0d6e661f14df9cb441f55c3b9c..24b0fce1ff8f2ea5e58125d6e123bb7fe169173a 100644
GIT binary patch
literal 6303
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

literal 1944
zcmeAS@N?(olHy`uVBq!ia0y~yU|0ac9Bd2>4Bh9`br~4g<2+p)Ln`9l&hb4h<0{gc
zuEH(Kqq4~9gquqYt6+W0kI8=pA00{+FjriV)WRYpt~fEPsNL(LeCSo%%gg)E=cv8^
zeeL+p?>0N{h6Z1Le)(m|uWz&E?=Sm4ef|6;+aG@YIJf=q`JdJIp53&spYyNo+jGlb
z?)Nj|`-&xh+_iu9%f9~Ovy$(V`P-)LTox04Z@<j!`Tdg{i<|V#e|}xfzT8^gc5bi2
z*2;hH^_^$8&#(P2r(yb6*ydx`zhvQO3eOCleLh~_^mvKP(n_{-@%3LbR@A+m+LK$U
z%JKgG@1!lK??f=>GssN+b~4_6{=2##v0GbA_!z>LdvAKUl*uhLlT{&f!-@qfH*NjK
z->_I~+c$Ox&vmO@_p&FHt}o~P%r)cibiIeBS53b5dw&S}>YZC`vAByVVRd%Y+jj2)
z|F7POEDfpu!x(~D=dPZoT4PvV#qOZHAnK}4*a6EKi<(p$vb5s#^x}{BFiJe=Wt0$L
zN?83g>aBkF1jB|TQybQBzJ%9G%UB9>`h*Sy@plX8&ZxSg6Lw&wBlCh9(K|t`*$h29
znOzv(Y>e1_UZuhNd!c2+#_!j;9~4;DeoQk7HuR5bQ1Sh_S4lKLdYx41<mnF#89rBU
zjAJ-$m?WM4N@z|K$B#?<nH|Contpq=edb<vou}s+BZRZ!&L#<NWO;Don)feRhHEJ?
z`_HCIr+H>^#yd=S$Cz#RRl|J7X)Y_X|2OW%_b@kj_sKqf?<;C>zy37in^?x>bsIZY
z?yTo|@#)GY-eR5$%R=Va@BRPt_KKwB=_fWNM>YoC|Flo%*OTd|cA6ZOsGPki|4+<6
zIR<{dgh}%i-f${6e*UpNp1q^`7rRaN@9$@P<$HNz&V5$3)P2tATxa!v`uDk3{1R_Z
zRc7h!4gTI9V$a)gZN&>aeu>$KR2xj6GZr7rX7G8;@KEaa_xHOi<TmX2C~vJdRX*V?
z|LkK*%Imv+-jD8!b6xf6ucz6f@9Y_Cn?j#6em+?ou>63QxTWnQ#trJ(yJ~mYbKkR8
z`NsIYEMfM~@VV?h@iMc1@svwfUS7=bV5@P>?2qEw4=ycixqU)rerxps+s*sW-dTN)
zIZt_Eok(Bu)#tA?bj7t71Sv4Acyi1vYS($@JmcEi8gtllPG1*{GM~$ShI!Xhrj$3U
z8Fifc8m@0T_Uy93Y3ID_NpCoLWjyZc?dMYFo&I3&wxB3sgEEC_{g0wHuecglBseL2
z-_FIqG^aAGU=3M4>n`J*Uu!DgEVkuavhCLD`*q*FKfL#^kE)#)V1HI)&Zz@GPqW*X
z$f|{UW->*%a$DUpE)ZontuMUw^s4ua4PSQ#<y10$nD)CWT8)We`<Z8Nk4rK19Df*B
zY^`SRxc8|ILq&DQwmBb}63z>+i)vv=@ZR>%KDRxzfb07$hPc(If*AXGUk5Nwmpd$`
zs5Ot5#etb2+bN($|0UZ2sqZDXL-G$ZELhj+9u~&>V5^uwv`Qb>4p*`7(#e7cK5@S&
z=AWdqzprv_tNT1XhCBT8bko)`8O*CQ*j^uA_e=0Y>j~ZO{}>9mUz;9V!L~tkfy{x5
zXFl(fEuICrvR+|W8SX0Du=jxqNA<(ie{Ccgs@GnBVa}cK_TPh90a@pmpFRFubHMcG
zwb#2N7}x90{M>N;+=g#IRx>^kT9Lb9mlZ=u`H2{LhFQ{U<m4DuS*NVyXE@6n#?Q}i
zRo3V_d&4uf)$QyJulQ!ZW_BoUzIvG1p|t(XSH=Z9559WHxL}v_vtJAs?j(Huzz}d(
zvAC8YBX2`h1;dJW6L#9oTbqvHFqoJ}*xJy{u2JLhM8wbwod1k-*@f?JUa(~v0|Ntt
Nr>mdKI;Vst1_0!Dd}#mx

diff --git a/assets/Dungeon.tmx b/assets/Dungeon.tmx
index 358f8b0..b458c47 100644
--- a/assets/Dungeon.tmx
+++ b/assets/Dungeon.tmx
@@ -3,7 +3,21 @@
  <tileset firstgid="1" name="Dungeon" tilewidth="16" tileheight="16" tilecount="100" columns="10">
   <image source="Dungeon.png" trans="000000" width="160" height="160"/>
  </tileset>
- <layer id="4" name="bg" width="92" height="24">
+ <tileset firstgid="101" name="Obstacles" tilewidth="16" tileheight="16" tilecount="100" columns="10">
+  <image source="Obstacles.png" trans="000000" width="160" height="160"/>
+ </tileset>
+ <tileset firstgid="201" name="Fire" tilewidth="16" tileheight="16" tilecount="4" columns="2">
+  <image source="Fire.png" trans="000000" width="32" height="32"/>
+  <tile id="0">
+   <animation>
+    <frame tileid="0" duration="1000"/>
+    <frame tileid="1" duration="1000"/>
+    <frame tileid="2" duration="1000"/>
+    <frame tileid="3" duration="1000"/>
+   </animation>
+  </tile>
+ </tileset>
+ <layer id="4" name="bg" width="92" height="24" visible="0">
   <data encoding="csv">
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
@@ -37,16 +51,16 @@
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,2,2,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,52,0,0,0,0,0,0,0,53,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,52,0,0,0,0,0,0,0,53,201,0,0,71,72,71,72,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,52,0,0,0,0,0,0,0,0,0,0,0,81,82,81,82,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,52,0,61,62,0,0,0,0,0,0,0,0,71,72,71,72,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,52,0,103,103,0,0,103,102,0,0,0,0,81,82,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,52,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,62,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
@@ -65,18 +79,18 @@
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-1073741836,1073741836,1073741836,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+22,26,22,22,1610612762,22,32,32,32,32,32,32,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+22,22,22,25,22,33,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+35,35,22,22,33,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+32,32,32,33,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,1,1,3,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,11,3,0,0,1,2,1,1,0,0,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,11,31,31,31,0,0,1,1,3,1,0,0,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,1610612748,31,31,31,3,3,3,3,3,3,3,3,3,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,11,31,22,22,31,31,31,31,3,3,2,3,3,1,3,1,3,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-11,12,12,12,21,31,31,22,22,22,22,3,3,3,1,3,3,3,3,1,3,2,2,3,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-1610612748,21,22,31,22,21,22,31,22,31,31,1,1,3,3,3,3,3,3,3,1,3,3,3,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,11,13,0,0,1,2,1,1,0,0,73,74,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,11,12,22,23,0,0,1,1,3,1,0,0,83,84,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,101,1610612748,3221225494,1610612758,22,11,12,13,3,3,3,3,3,3,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,11,12,25,22,22,22,21,35,23,3,2,3,3,1,3,1,3,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+11,12,12,12,25,22,22,2,2,22,31,32,33,3,1,3,3,3,3,1,3,2,2,3,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+31,32,32,32,32,32,32,2,2,32,32,32,32,3,3,3,3,3,3,3,1,3,3,3,3,3,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
@@ -87,32 +101,32 @@
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
 </data>
  </layer>
- <layer id="2" name="fg" width="92" height="24" visible="0">
+ <layer id="2" name="fg" width="92" height="24">
   <data encoding="csv">
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
 0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
-0,0,1,0,0,0,0,0,0,1,1,0,0,0,0,0,0,1,0,0,0,0,0,0,1,0,0,0,1,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
+0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,42,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,42,43,44,42,43,44,42,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,42,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,41,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,41,0,42,0,42,0,42,0,42,0,0,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+3,0,41,0,0,0,0,0,41,0,0,0,0,0,0,0,41,0,41,0,41,0,41,0,41,0,41,0,41,0,0,0,0,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
+0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,2,0,0,2,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0
 </data>
  </layer>
 </map>
diff --git a/src/main.rs b/src/main.rs
index 3eec8a7..95251e2 100644
--- a/src/main.rs
+++ b/src/main.rs
@@ -30,12 +30,11 @@ fn main() {
         .add_startup_system(setup.system())
         .add_system_set(
             SystemSet::new()
-                .with_run_criteria(FixedTimestep::step(1.0 / 60.0))
+                //.with_run_criteria(FixedTimestep::step(1.0 / 60.0))
                 .with_system(player_movement.system())
-                .with_system(camera.system())
-                .with_system(parallax.system()),
+                .with_system(camera.system()), // .with_system(parallax.system()),
         )
-        .add_system(set_texture_filters_to_nearest.system())
+        //.add_system(set_texture_filters_to_nearest.system())
         .run();
 }
 
@@ -56,6 +55,7 @@ fn set_texture_filters_to_nearest(
     }
 }
 
+const MAP_SCALE: f32 = 4.0;
 fn setup(
     mut commands: Commands,
     asset_server: Res<AssetServer>,
@@ -68,7 +68,7 @@ fn setup(
     let bottom = -window.height() / 2.0;
 
     // load the tile map
-    let handle: Handle<TiledMap> = asset_server.load("Dungeon.tmx");
+    let handle: Handle<TiledMap> = asset_server.load("Overworld.tmx");
     let map_entity = commands.spawn().id();
     commands.entity(map_entity).insert_bundle(TiledMapBundle {
         tiled_map: handle,
@@ -76,7 +76,7 @@ fn setup(
 
         transform: Transform {
             translation: Vec3::new(0., bottom, 1.0),
-            scale: Vec3::new(4.0, 4.0, 1.0),
+            scale: Vec3::new(MAP_SCALE, MAP_SCALE, 1.0),
             ..Default::default()
         },
 
@@ -98,9 +98,20 @@ fn setup(
             ..Default::default()
         })
         .insert(Player {
-            y: bottom / 2.,
+            player_y: bottom / 2.,
             ..Player::default()
         });
+    // commands.spawn_bundle(TextBundle {
+    //     text: Text::with_section(
+    //         "Game Over",
+    //         TextStyle::default(),
+    //         TextAlignment {
+    //             vertical: VerticalAlign::Center,
+    //             horizontal: HorizontalAlign::Center,
+    //         },
+    //     ),
+    //     ..Default::default()
+    // });
 }
 
 #[derive(Copy, Clone)]
@@ -110,19 +121,21 @@ enum Direction {
     Idle,
 }
 pub struct Player {
-    direction: Direction,
-    jump: bool,
-    index: u32,
-    y: f32,
+    player_direction: Direction,
+    player_jump: bool,
+    player_index: u32,
+    player_y: f32,
+    player_x: f32,
 }
 
 impl Default for Player {
     fn default() -> Self {
         Player {
-            direction: Direction::Idle,
-            jump: false,
-            index: 3,
-            y: 0.,
+            player_direction: Direction::Idle,
+            player_jump: false,
+            player_index: 3,
+            player_y: 0.,
+            player_x: 0.,
         }
     }
 }
@@ -133,9 +146,9 @@ fn player_movement(
     keyboard_input: Res<Input<KeyCode>>,
 ) {
     if let Ok((mut player, mut transform, mut sprite)) = query.single_mut() {
-        let (index, state, dir) = if player.jump {
+        let (index, state, dir) = if player.player_jump {
             // already in jump
-            let mut index = player.index + 1;
+            let mut index = player.player_index + 1;
             match index {
                 4 => {
                     sprite.index = 7;
@@ -150,141 +163,94 @@ fn player_movement(
             };
             if index == 64 {
                 index = 0;
-                player.jump = false
+                player.player_jump = false
             };
 
             if index > 8 && index < (60) {
                 transform.translation.y =
-                    player.y + (((index - 8) as f32) * PI / (60.0 - 8.0)).sin() * 200.0;
+                    player.player_y + (((index - 8) as f32) * PI / (60.0 - 8.0)).sin() * 200.0;
             } else {
-                transform.translation.y = player.y
+                transform.translation.y = player.player_y
             }
 
-            (index, player.direction, 0.)
+            (index, player.player_direction, 0.)
         } else if keyboard_input.pressed(KeyCode::Space) {
             // start jump
-            player.jump = true;
+            player.player_jump = true;
             sprite.index = 3;
             let index = 0;
-            (index, player.direction, 0.)
+            (index, player.player_direction, 0.)
         } else if keyboard_input.pressed(KeyCode::Right) {
             sprite.flip_x = false;
-            match player.direction {
+            match player.player_direction {
                 // already walking
                 Direction::Right => {
-                    let index = (player.index + 1) % 32;
+                    let index = (player.player_index + 1) % 32;
                     sprite.index = (4 * 9) + index / 4;
-                    (index, Direction::Right, 2.)
+                    (index, Direction::Right, 1.)
                 }
                 // starting walking
                 _ => {
                     let index = 3 * 4;
                     sprite.index = (4 * 9) + index / 4;
-                    (index, Direction::Right, 2.)
+                    (index, Direction::Right, 1.)
                 }
             }
         } else if keyboard_input.pressed(KeyCode::Left) {
             sprite.flip_x = true;
-            match player.direction {
+            match player.player_direction {
                 // already walking
                 Direction::Left => {
-                    let index = (player.index + 1) % 32;
+                    let index = (player.player_index + 1) % 32;
                     sprite.index = (4 * 9) + index / 4;
-                    (index, Direction::Left, -2.)
+                    (index, Direction::Left, -1.)
                 }
                 // starting walking
                 _ => {
                     let index = 3 * 4;
                     sprite.index = (4 * 9) + index / 4;
-                    (index, Direction::Left, -2.)
+                    (index, Direction::Left, -1.)
                 }
             }
         } else {
-            match player.direction {
+            match player.player_direction {
                 // already idle
                 Direction::Idle => {
-                    let index = (player.index + 1) % 256;
+                    let index = (player.player_index + 1) % 256;
                     sprite.index = if index > 224 { 0 } else { 9 * 1 + 6 };
                     (index, Direction::Idle, 0.)
                 }
                 // start idle
                 _ => {
-                    player.index = 0;
+                    player.player_index = 0;
                     sprite.index = 0;
                     (0, Direction::Idle, 0.)
                 }
             }
         };
 
-        player.direction = state;
-        player.index = index;
-        transform.translation.x += dir;
+        player.player_direction = state;
+        player.player_index = index;
+        player.player_x += dir * 4.0; // 4.0 seems to be good nominal speed
+        transform.translation.x = player.player_x;
     }
 }
 
-// A simple camera system for moving and zooming the camera.
 pub fn camera(
-    time: Res<Time>,
-    keyboard_input: Res<Input<KeyCode>>,
-    mut query: Query<&mut Transform, With<Camera>>,
+    player_query: Query<&Player>,
+    mut layer_query: Query<(&mut Transform, &Layer)>,
+    mut camera_query: Query<&mut Transform, (With<Camera>, Without<Layer>)>,
 ) {
-    // println!("camera");
-    for mut transform in query.iter_mut() {
-        // print!("-");
-        let mut direction = Vec3::ZERO;
-        let scale = transform.scale.x;
-
-        if keyboard_input.pressed(KeyCode::A) {
-            direction -= Vec3::new(1.0, 0.0, 0.0);
-        }
-
-        if keyboard_input.pressed(KeyCode::D) {
-            direction += Vec3::new(1.0, 0.0, 0.0);
-        }
+    // parallaxing
+    let player = player_query.single().unwrap();
+    let mut camera_transform = camera_query.single_mut().unwrap();
 
-        if keyboard_input.pressed(KeyCode::W) {
-            direction += Vec3::new(0.0, 1.0, 0.0);
-        }
-
-        if keyboard_input.pressed(KeyCode::S) {
-            direction -= Vec3::new(0.0, 1.0, 0.0);
-        }
+    // for now, move the camera to the
+    camera_transform.translation.x = player.player_x;
+    camera_transform.translation.y = player.player_y;
 
-        if keyboard_input.pressed(KeyCode::Z) {
-            let scale = scale + 0.1;
-            transform.scale = Vec3::splat(scale);
-        }
-
-        if keyboard_input.pressed(KeyCode::X) {
-            let scale = scale - 0.1;
-            transform.scale = Vec3::splat(scale);
-        }
-
-        if transform.scale.x < 1.0 {
-            transform.scale = Vec3::splat(1.0)
-        }
-
-        transform.translation += time.delta_seconds() * direction * 500.;
-    }
-}
-
-enum Layers {
-    Cloud,
-}
-
-// parallaxing
-pub fn parallax(
-    mut layer_query: Query<(&mut Transform, &Layer)>,
-    camera_query: Query<&Transform, (With<Camera>, Without<Layer>)>,
-) {
-    let camera_x = camera_query.single().unwrap().translation.x;
     for (mut transform, layer) in layer_query.iter_mut() {
-        match layer.settings.layer_id {
-            0 => transform.translation.x = camera_x / 8.0,
-            1 => {}
-            2 => {}
-            3 => transform.translation.x = -camera_x / 4.0,
-            _ => panic!("illegal layer id"),
-        }
+        // (1. - parallax) gives the per layer translation.
+        transform.translation.x = player.player_x * (1. - layer.settings.parallax_x) / MAP_SCALE;
     }
 }
-- 
GitLab