diff options
Diffstat (limited to 'npc/018-3/treasure.txt')
-rw-r--r-- | npc/018-3/treasure.txt | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/npc/018-3/treasure.txt b/npc/018-3/treasure.txt new file mode 100644 index 000000000..002f16b67 --- /dev/null +++ b/npc/018-3/treasure.txt @@ -0,0 +1,65 @@ +// TMW2 Script + +// (Random) Treasure Chest +// Authored by Jesusalva +// Regenerates every 6 hours + +018-3,0,0,0 script #chest_01830 NPC_CHEST,{ + + if (!.busy && !.empty) { + TreasureBox(); + + .empty=true; + specialeffect(.dir == 0 ? 24 : 25, AREA, getnpcid()); // closed ? opening : closing + .dir = .dir == 0 ? 2 : 6; // closed ? opening : closing + .busy = true; // lock until available again + initnpctimer; + } else if (!.busy) { + mesc l("Someone looted this treasure box already..."); + } else { + end; + } + close; + +OnTimer160: + .dir = .dir == 6 ? 0 : 4; // closing ? closed : open + end; + +OnTimer500: + .busy = false; // unlock + if (.dir == 0 || .dir == 4) + stopnpctimer; // stop here if the chest is closed + end; + +OnInit: + .busy = false; + .distance = 2; + .empty = false; + +OnClock0156: +OnClock0756: +OnClock1356: +OnClock1956: + // Try to warp randomly to a walkable spot, up to 20 attempts + // Otherwise, it'll stay where it already is (but will close and refill). + .@e=0; .@x=0; .@y=0; + while (!checkcell(.map$, .@x, .@y, cell_chkpass)) + { + if (.@e == 20) { + .@x=.x; + .@y=.y; + break; + } + // Remember the +20 -20 margin adjustment + .@x = rand(20, 130); + .@y = rand(20, 130); + ++.@e; + } + .busy=false; + .empty=false; + movenpc .name$, .@x, .@y, 0; + end; +} + +018-3,0,0,0 duplicate(#chest_01830) #chest_01831 NPC_CHEST + |