From e67558f8f0fcdaab47583f6430e89299298e86bd Mon Sep 17 00:00:00 2001 From: Nyeogmi Date: Mon, 17 Feb 2025 16:41:18 -0800 Subject: [PATCH] Add manor skeleton --- src/art/mapdata/zoo.mapfile | 61 ---------------------------- src/art/thralls/thrall_bat.png | Bin 468 -> 523 bytes src/art/thralls/thrall_charm.png | Bin 535 -> 601 bytes src/art/thralls/thrall_lore.png | Bin 536 -> 614 bytes src/art/thralls/thrall_party.png | Bin 503 -> 559 bytes src/art/thralls/thrall_stare.png | Bin 523 -> 570 bytes src/art/thralls/thrall_stealth.png | Bin 503 -> 572 bytes src/checkmodal.ts | 11 ++++- src/huntmode.ts | 10 ++--- src/manormap.ts | 62 +++++++++++++++++++++++++++++ src/pickups.ts | 30 +++++++++++++- src/sprites.ts | 12 +++--- src/statemanager.ts | 6 +-- src/thralls.ts | 33 +++++++++++++++ 14 files changed, 148 insertions(+), 77 deletions(-) delete mode 100644 src/art/mapdata/zoo.mapfile create mode 100644 src/manormap.ts diff --git a/src/art/mapdata/zoo.mapfile b/src/art/mapdata/zoo.mapfile deleted file mode 100644 index 1c4cd3f..0000000 --- a/src/art/mapdata/zoo.mapfile +++ /dev/null @@ -1,61 +0,0 @@ -architecture: - --------------- -provinces: - --------------- -{ - "provinces": { - "a": "Zoo", - "b": "Gator Pen", - "c": "Food Storage" - }, - "architecture": { - "@": "entrance", - "#": "wall", - " ": "floor", - "*": { "item": "gecko" }, - ".": { - "pickup": [ - "AGI", "AGI", "AGI", "AGI", - "PSI", "PSI", - "EXP" - ] - }, - "!": { "item": "colonialGoose" }, - "1": { - "label": "The gator pen appears to be locked. Some bats behind the barred gate are amusing themselves by swooping and darting just out of the alligators' reach.", - "checks": [ - { - "skills": ["lore1"], - "locked": "That wall sure does look impenetrable.", - "unlockable": "Notice a failure in the construction.", - "unlockScene": [ - "I dig my clawed fingers into a crack between the bricks and feel the concrete give way.", - "This structure, built by mortals, is impermanent. Soon none of it will exist.", - "I rip another clump of brittle earth from the crack, no longer invisible.", - "And another. When the gap's wide enough to crawl through, I climb in." - ] - }, - { - "skills": ["stare0"], - "locked": "The bats are happy by themselves.", - "unlockable": "These bats could be enjoying themselves so much more.", - "unlockScene": [ - "I hold my face to the bars. One bat looks at me.", - "\"Here, little bat\" -- I think before I say it. No, relate to it as an equal.", - "What does it really want?", - "What does any mortal want? It wants to feel good --"", - "So stare --", - "...", - "... Now it breaks. Like any mortal.", - "Still dripping, it flaps unsurely to the door and -- with only a little coaxing -- it opens the lock." - ] - } - ] - }, - "2": { - "label": - } - } -} \ No newline at end of file diff --git a/src/art/thralls/thrall_bat.png b/src/art/thralls/thrall_bat.png index 7ad992ac5e65ce2653b8ca3a78e078e59f99a589..4f258f72eb8104acd76a6af09eaa10cdfc84f061 100644 GIT binary patch delta 238 zcmV#4#Y4B1o;MR@&{bGa{m9U1E)JLC*|Za8%(hhV+;{__396)#@PWfi?f5I zsSTVUb?x+mnHS%EX5Q0DOw0G`@@Q|(Gcyv5(Vv492b+;9pPt_$6@r7gLF&q;=WY=c z6kpNONv4%jl5vnU4w7q(i$ie)Fxo26s9!Y%-~g$p{1T*DK=$eBv#nJi$$}?- o39=ch+Kg2{hRy$r!v9+T2hlJc2HxzT#Q*>R07*qoM6N<$f>t?XkN^Mx delta 183 zcmV;o07(Cf1k?i|iBL{Q4GJ0x0000DNk~Le0000m0000O2m=5B0E;7z?y(^#0e^N$ zL_t(IjqQ-J5d<*^1Jwrb*Mo?z|IXeJeDKI~#?Gx2pdM zX0qx?90%4&EiqC{e&Sx9ob+WGFuN`lAQcB(2avl!gooz2;qeL4*>PAk=9a+XYD=ib l35U0*vMq1I=7k^s0#yeQMXLQD8Vmpc002ovPDHLkV1nS%NXGyG diff --git a/src/art/thralls/thrall_charm.png b/src/art/thralls/thrall_charm.png index 9985dbda6c5b6d42fc58f598f5cb3818850c68ee..698c4e3640dffc49f19e7f5e3a2d4d4c1968a9ce 100644 GIT binary patch delta 317 zcmV-D0mA;51la^3iBL{Q4GJ0x0000DNk~Le0000;0000O2m=5B0B*fYg0Uee0e|~R zL_t(IjpdU;4#Xe`MOig5u+?L@c4O~;;EOK5^(QMdz|Akp#hi*w?3V{pTL&Q{+?r#gcEkOzwSyBOfydiyvxAgkm=}LUDgUenF<+r1&JcaY z^4E3Y6Z5rJd@|rDvVc%z0fMs=4`4VuA+51NkW)HH?;+%`%>V!Z07*qoM6N<$f=2df AeE>!SL>GqTkIO`(-L~}w3MAQp`Sx+hB zo2nI!+HNDbkY41entHCAJkd23v(n83KM+oEtuXJpU)MdBBQ`n72P(6z9Vizh6J$ZP zzxu!vWI?soPe4{tpQ{8vjWSm$fP+A8rnzZ$20z`b3i4Z!%dH&1&(?gWUmyey`v-(c dZ9@w7KLCwhJ9tbfEnWZs002ovPDHLkV1io)h`Rs) delta 252 zcmVt22)xBH4x(cZ?<3EOjdFGEtUYq*9Sr@8j9k#v#kLS#TYpta@>04VEYLwW$pnBWAI z610!});W)Ch!)XyoxkX6R$4#UPEm;Yq?;-{A21O->pB3W2(zVp2aqC|w+=SER$Fx3 z9$xEuA3ZvS&F#zU%i)7Q%)Lkc8X`T8U*k;3O1uE^`6%Iz_@STx0000>Vk|ED`mmu;lP-8p=;uG*I zGlPA1XA=lWD2R}#SO{|6hy^ympf~pj9ELk4nPF0*upU)iOXaNoTFQpGihwp91A$)J z8UW!SJUx3gyi_@%07*qoM6N<$g0LNGsQ>@~ delta 218 zcmV<0044vg1os0WiBL{Q4GJ0x0000DNk~Le0000m0000O2m=5B0E;7z?y(^#0e_iE zL_t(Ijpfm?4MQ;q1W;(QK^Or8rS~5$*xeU*Dbj|*mJm+{Eb`|O5isxW1PB2_fDj-I zWCv*picBorvB*@_K4yLA`#|8W5eU50Y~;I}s+^ncZmQhO;0O^=oO&SYyfLyO%YF4V zz`il-S^ft={%wo!4-exV UR3y8pEdT%j07*qoM6N<$f)M*wLjV8( diff --git a/src/art/thralls/thrall_stare.png b/src/art/thralls/thrall_stare.png index cc40e25acf46776e35b46d1faac89779fb41fe4c..12a800a486ad9aabcd2af2c889a8b7f1cd6f8fb1 100644 GIT binary patch delta 285 zcmV+&0pk9P1iAzviBL{Q4GJ0x0000DNk~Le0000;0000O2m=5B0B*fYg0Uee0e{>{ zL_t(IjqQ^`5`!QNMOk?SHqJi;+2j3>RfC{3`RSDDw%>7~jxR3|Qu@b5Mt%mNCn{iy zN(Gm@itujE?$?MGh5naAYq^+mDB~ZNg z0G|w?oXKhCNZXvqD6lR5z33JPpmJzXON*-+f`m>**CAu~0mO|8h!H&nkE<3Tob!Th zE!7r}X%uA{Ort2v{c_ZL5FPZx_6|}N1RyTd=a7J~3KG_u8bz%!kbt*#F_u6wI0jS( j=c~mQlbd7WgeIjIwf9RLB`7%V?gThKn4s1v`}e~Hu;}`j$J;I*QaVw_3uc{PBd}7oq^kz zfFGsz?O}t%0F!YC_1j4|K>d1g1w&-Hjj8#~ZA{Dm{7f0Jt@!}(0pJrLD3WzRk%V!i o?S+82zW~$y36P@q6J=TL2Oq>X7*zF43;+NC07*qoM6N<$f+PH57XSbN diff --git a/src/art/thralls/thrall_stealth.png b/src/art/thralls/thrall_stealth.png index cdc55b7a80a4a4ee0d110d66b599dc0c6e1d966c..bd6a5f3b7d4ffa055333b3062522f00d3e60d280 100644 GIT binary patch delta 287 zcmV+)0pR}k1H1$wiBL{Q4GJ0x0000DNk~Le0000;0000O2m=5B0B*fYg0Uee0e{{} zL_t(Ijop#44#PkQLyslL9x3oMV%110D{pmaf=dywZA3aUe3-5iJ6}%!ujA(C8$= z#}UO0EezDgd3qD$IK21qehK$2fL+4AC5%qK6^8L|t_p3ojly2`c`pFeeu>_oS`hHDB4cym+bHAVqTL9~|Np UJ(?x)S^xk507*qoM6N<$g1SFiwg3PC diff --git a/src/checkmodal.ts b/src/checkmodal.ts index 386e665..f58f06a 100644 --- a/src/checkmodal.ts +++ b/src/checkmodal.ts @@ -102,7 +102,16 @@ export class CheckModal { }) } - if (options.length == 1) { + if (options.length == 0) { + addButton( + this.#drawpile, + "OK!", + new Rect(new Point(0, size.h - 64), new Size(size.w, 64)), + true, + () => { this.show(null, null) } + ) + } + else if (options.length == 1) { addOptionButton(options[0], new Rect(new Point(0, size.h - 64), new Size(size.w, 64))); } else if (options.length == 2) { diff --git a/src/huntmode.ts b/src/huntmode.ts index 9da3234..bdc202f 100644 --- a/src/huntmode.ts +++ b/src/huntmode.ts @@ -132,11 +132,11 @@ export class HuntMode { offsetInCells: Point, mapPosition: Point, ) { - const OFFSET_UNDER_FLOOR = -512; - const OFFSET_FLOOR = -256; - const OFFSET_AIR = 0; - const OFFSET_TOP = 256; - const OFFSET_TOP_OF_TOP = 512; + const OFFSET_UNDER_FLOOR = -512 + mapPosition.y; + const OFFSET_FLOOR = -256 + mapPosition.y; + const OFFSET_AIR = 0 + mapPosition.y; + const OFFSET_TOP = 256 + mapPosition.y; + const OFFSET_TOP_OF_TOP = 512 + mapPosition.y; const gridArt = new GridArt(offsetInCells); diff --git a/src/manormap.ts b/src/manormap.ts new file mode 100644 index 0000000..d28b62c --- /dev/null +++ b/src/manormap.ts @@ -0,0 +1,62 @@ +import {Architecture, LoadedNewMap} from "./newmap.ts"; +import {Grid, Point} from "./engine/datatypes.ts"; +import {getThralls} from "./thralls.ts"; +import {LadderPickup, ThrallPosterPickup} from "./pickups.ts"; + +const BASIC_PLAN = Grid.createGridFromMultilineString(` +##################### +######### ######### +##### A # L # D ##### +##### a # # d ##### +##### ## ## ##### +# ## ## ## ## # +#Bb eE# +# ## ## ## ## # +##### ## ## ##### +##### c # # f ##### +##### C # @ # F ##### +######### ######### +##################### +`); + +export function generateManor(): LoadedNewMap { + let map = new LoadedNewMap("manor", BASIC_PLAN.size); + let thralls = getThralls().getAll(); + + for (let y = 0; y < BASIC_PLAN.size.h; y++) { + for (let x = 0; x < BASIC_PLAN.size.w; x++) { + let xy = new Point(x, y); + let cell = map.get(xy); + + let placeThrall = (ix: number) => { + // TODO + cell.architecture = Architecture.Floor; + }; + let placeThrallPoster = (ix: number) => { + cell.architecture = Architecture.Floor; + cell.pickup = new ThrallPosterPickup(thralls[ix]); + }; + + switch (BASIC_PLAN.get(xy)) { + case '#': break + case '@': cell.architecture = Architecture.Floor; map.entrance = xy; break; + case 'L': cell.architecture = Architecture.Floor; cell.pickup = new LadderPickup(); break; + case ' ': cell.architecture = Architecture.Floor; break; + case 'a': placeThrall(0); break; + case 'b': placeThrall(1); break; + case 'c': placeThrall(2); break; + case 'd': placeThrall(3); break; + case 'e': placeThrall(4); break; + case 'f': placeThrall(5); break; + case 'A': placeThrallPoster(0); break; + case 'B': placeThrallPoster(1); break; + case 'C': placeThrallPoster(2); break; + case 'D': placeThrallPoster(3); break; + case 'E': placeThrallPoster(4); break; + case 'F': placeThrallPoster(5); break; + } + } + } + + return map; +} \ No newline at end of file diff --git a/src/pickups.ts b/src/pickups.ts index 2c5cb87..367df03 100644 --- a/src/pickups.ts +++ b/src/pickups.ts @@ -16,6 +16,7 @@ export type Pickup | ExperiencePickup | LadderPickup | ThrallPickup + | ThrallPosterPickup export class LockPickup { check: CheckData; @@ -148,4 +149,31 @@ export class ThrallPickup { getCheckModal().show(data.initialCheck, () => cell.pickup = null); return true; } -} \ No newline at end of file +} + +export class ThrallPosterPickup { + thrall: Thrall; + + constructor(thrall: Thrall) { + this.thrall = thrall; + } + + computeCostToClick() { return 0; } + + isObstructive() { return false; } + + drawFloor() { } + drawInAir(gridArt: GridArt) { + let data = getThralls().get(this.thrall); + D.drawSprite(data.sprite, gridArt.project(0.0), 2, { + xScale: 2.0, + yScale: 2.0, + }) + } + + onClick(cell: CellView): boolean { + let data = getThralls().get(this.thrall); + getCheckModal().show(data.posterCheck, () => cell.pickup = null); + return true; + } +} diff --git a/src/sprites.ts b/src/sprites.ts index c4c763f..65cc808 100644 --- a/src/sprites.ts +++ b/src/sprites.ts @@ -41,9 +41,9 @@ export let sprLock = new Sprite( ); -export let sprThrallBat = new Sprite(imgThrallBat, new Size(24, 24), new Point(12, 12), new Size(2, 1), 2); -export let sprThrallCharm = new Sprite(imgThrallCharm, new Size(24, 24), new Point(12, 12), new Size(2, 1), 2); -export let sprThrallLore = new Sprite(imgThrallLore, new Size(24, 24), new Point(12, 12), new Size(2, 1), 2); -export let sprThrallParty = new Sprite(imgThrallParty, new Size(24, 24), new Point(12, 12), new Size(2, 1), 2); -export let sprThrallStare = new Sprite(imgThrallStare, new Size(24, 24), new Point(12, 12), new Size(2, 1), 2); -export let sprThrallStealth = new Sprite(imgThrallStealth, new Size(24, 24), new Point(12, 12), new Size(2, 1), 2); +export let sprThrallBat = new Sprite(imgThrallBat, new Size(24, 24), new Point(12, 12), new Size(3, 1), 3); +export let sprThrallCharm = new Sprite(imgThrallCharm, new Size(24, 24), new Point(12, 12), new Size(3, 1), 3); +export let sprThrallLore = new Sprite(imgThrallLore, new Size(24, 24), new Point(12, 12), new Size(3, 1), 3); +export let sprThrallParty = new Sprite(imgThrallParty, new Size(24, 24), new Point(12, 12), new Size(3, 1), 3); +export let sprThrallStare = new Sprite(imgThrallStare, new Size(24, 24), new Point(12, 12), new Size(3, 1), 3); +export let sprThrallStealth = new Sprite(imgThrallStealth, new Size(24, 24), new Point(12, 12), new Size(3, 1), 3); diff --git a/src/statemanager.ts b/src/statemanager.ts index 89e7651..774b930 100644 --- a/src/statemanager.ts +++ b/src/statemanager.ts @@ -5,7 +5,7 @@ import {getVNModal} from "./vnmodal.ts"; import {getScorer} from "./scorer.ts"; import {getEndgameModal} from "./endgamemodal.ts"; import {SuccessorOption, Wish} from "./datatypes.ts"; -import {generateMap} from "./mapgen.ts"; +import {generateManor} from "./manormap.ts"; const N_TURNS: number = 9; @@ -22,7 +22,7 @@ export class StateManager { startGame(asSuccessor: SuccessorOption, withWish: Wish | null) { this.#turn = 1; - initHuntMode(new HuntMode(1, generateMap())); + initHuntMode(new HuntMode(1, generateManor())); initPlayerProgress(asSuccessor, withWish); } @@ -33,7 +33,7 @@ export class StateManager { this.#turn += 1; getPlayerProgress().applyEndOfTurn(); getPlayerProgress().refill(); - initHuntMode(new HuntMode(getHuntMode().depth, generateMap())); + initHuntMode(new HuntMode(getHuntMode().depth, generateManor())); } else { // TODO: Play a specific scene let ending = getScorer().pickEnding(); diff --git a/src/thralls.ts b/src/thralls.ts index bf1930e..47b7ca1 100644 --- a/src/thralls.ts +++ b/src/thralls.ts @@ -43,10 +43,19 @@ class ThrallsTable { get(thrall: Thrall): ThrallData { return this.#thralls[thrall.id] } + + getAll(): Thrall[] { + let thralls = []; + for (let id = 0; id < this.#thralls.length; id++) { + thralls.push({id}) + } + return thralls; + } } export type ThrallData = { label: string, sprite: Sprite, + posterCheck: CheckData, initialCheck: CheckData, } @@ -63,6 +72,10 @@ export function getThralls() { export let thrallParty = table.add({ label: "Garrett", sprite: sprThrallParty, + posterCheck: { + label: "This room would be perfect for someone with an ostensibly managed gambling addiction.", + options: [], + }, initialCheck: { label: "That's Garrett. He plays poker, but he goes to the zoo to cool down after he's lost a lot of chips. His ice cream cone has melted.", options: [ @@ -87,6 +100,10 @@ export let thrallParty = table.add({ export let thrallLore = table.add({ label: "Lupin", sprite: sprThrallLore, + posterCheck: { + label: "This room would be perfect for someone with a love of nature and screaming.", + options: [], + }, initialCheck: { label: "That's Lupin. He's a Wolf Scout, but hardcore about it. I'm not sure he knows he's a raccoon.", options: [ @@ -111,6 +128,10 @@ export let thrallLore = table.add({ export let thrallBat = table.add({ label: "Monica", sprite: sprThrallBat, + posterCheck: { + label: "This room would be perfect for some kind of television chef.", + options: [], + }, initialCheck: { label: "That's Monica. You've seen her cook on TV! Looks like she's enjoying a kiwi flan.", options: [ @@ -135,6 +156,10 @@ export let thrallBat = table.add({ export let thrallCharm = table.add({ label: "Renfield", sprite: sprThrallCharm, + posterCheck: { + label: "This room would be perfect for someone who likes vampires even more than you enjoy being a vampire.", + options: [], + }, initialCheck: { label: "Doesn't this guy seem a little creepy? His nametag says Renfield. Not sure you should trust him...", options: [ @@ -159,6 +184,10 @@ export let thrallCharm = table.add({ export let thrallStealth = table.add({ label: "Narthyss", sprite: sprThrallStealth, + posterCheck: { + label: "This room would be perfect for someone who can breathe fire.", + options: [], + }, initialCheck: { label: "Narthyss (dragon, heiress) actually owns the club, so she probably wouldn't talk to you... Would she?", options: [ @@ -183,6 +212,10 @@ export let thrallStealth = table.add({ export let thrallStare = table.add({ label: "Ridley", sprite: sprThrallStare, + posterCheck: { + label: "This room would be perfect for a soulless robot.", + options: [], + }, initialCheck: { label: "Ridley is the library's catalogue system. It can give you an incorrect answer to any question. (It has a couple gears loose.)", options: [