summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJesusaves <cpntb1@ymail.com>2022-01-02 09:37:38 -0300
committerJesusaves <cpntb1@ymail.com>2022-01-02 09:37:38 -0300
commitd2638ee465bbcc53dd8b12653c0e55e4c440e564 (patch)
tree3296ce57a55dfd0f195b93f17438d3b2f17b50c9
parentc9b5bbb2a50b8eaab0ff6c6693dff78c7df6fcb6 (diff)
downloadserverdata-d2638ee465bbcc53dd8b12653c0e55e4c440e564.tar.gz
serverdata-d2638ee465bbcc53dd8b12653c0e55e4c440e564.tar.bz2
serverdata-d2638ee465bbcc53dd8b12653c0e55e4c440e564.tar.xz
serverdata-d2638ee465bbcc53dd8b12653c0e55e4c440e564.zip
Prepare new dungeon effect: Bleeding Map
-rw-r--r--npc/functions/dungeon.txt33
1 files changed, 33 insertions, 0 deletions
diff --git a/npc/functions/dungeon.txt b/npc/functions/dungeon.txt
index 822246974..2ae34f912 100644
--- a/npc/functions/dungeon.txt
+++ b/npc/functions/dungeon.txt
@@ -12,6 +12,7 @@ OnInit:
setarray .heatmap$, "007-2";
setarray .cursemap$, "006-4", "006-4-1", "025-1";
setarray .sickmap$, "029-5";
+ setarray .bleedmap$, "008-2"; // Placeholder
end;
/////////////////////////////////////////
@@ -113,6 +114,38 @@ OnSick:
addtimer2 10000, .name$+"::OnSick";
end;
+
+/////////////////////////////////////////
+// Heartbeat for Bleed effects
+OnBleed:
+ // Did you left?
+ .@i=array_find(.bleedmap$, getmap());
+ if (.@i < 0) {
+ @bleed$="";
+ end;
+ }
+
+ // First time seeing this
+ if (@bleed$ != getmap()) {
+ @bleed$=getmap();
+ dispbottom l("This is a bleeding map, HP won't recover naturally, and bleeding may start.");
+ }
+
+ // You are in a BLEEDMAP$, HP regeneration is disabled
+ if (@bleedio > gettimetick(2))
+ sc_end SC_HALT_REGENERATION;
+ else
+ SC_Bonus(15, SC_HALT_REGENERATION, 1);
+
+ // You may bleed at 2% chance per 15 seconds
+ if (rand2(50) == 25 && @bleedio < gettimetick(2))
+ SC_Bonus(15, SC_BLOODING, 1);
+
+ // New tick
+ addtimer2 15000, .name$+"::OnBleed";
+ end;
+
+
}