summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--npc/017-0/_import.txt1
-rw-r--r--npc/functions/dungeon.txt87
2 files changed, 88 insertions, 0 deletions
diff --git a/npc/017-0/_import.txt b/npc/017-0/_import.txt
index 8597a6931..dafb0216f 100644
--- a/npc/017-0/_import.txt
+++ b/npc/017-0/_import.txt
@@ -1,5 +1,6 @@
// Map 017-0: Mystic Forest
// This file is generated automatically. All manually added changes will be removed when running the Converter.
+"npc/017-0/_config.txt",
"npc/017-0/_mobs.txt",
"npc/017-0/_warps.txt",
"npc/017-0/wizard.txt",
diff --git a/npc/functions/dungeon.txt b/npc/functions/dungeon.txt
index a9d2d5003..a9165aa32 100644
--- a/npc/functions/dungeon.txt
+++ b/npc/functions/dungeon.txt
@@ -13,6 +13,7 @@ OnInit:
setarray .cursemap$, "006-4", "006-4-1", "025-1", "026-2";
setarray .sickmap$, "029-5";
setarray .bleedmap$, "006-9", "026-6", "026-7";
+ setarray .clockmap$, "017-0";
end;
/////////////////////////////////////////
@@ -146,6 +147,92 @@ OnBleed:
end;
+/////////////////////////////////////////
+// Heartbeat for Clocked effects
+function syndroCheck {
+ .@k = getarg(0);
+ .@t = getarg(1, 2000);
+ sleep2(.@t);
+ if (!playerattached()) return false;
+ if (BaseExp != .@k) return true;
+ return false;
+}
+
+OnClocked:
+ // Not Applicable
+ if ($CAPTCHA & 4)
+ end;
+
+ // Did you left?
+ .@i=array_find(.clockmap$, getmap());
+ if (.@i < 0) {
+ @clocked$="";
+ end;
+ }
+
+ // First time seeing this
+ if (@clocked$ != getmap()) {
+ @clocked$=getmap();
+ dispbottom l("This is an OverClocked map, excessive combat will cause Botter's Syndrome Disease, which reduces EXP Gain and drops.");
+ }
+ // Prepare the variables we'll be studying
+ .@mpk = MONSTERS_KILLED; .@k = BaseExp;
+ // We'll now wait in some intervals. Killing in them cause
+ // the K variables to be set, and contribute towards bot score.
+ .@k1 = syndroCheck(.@k); .@k = BaseExp;
+ .@k2 = syndroCheck(.@k); .@k = BaseExp;
+ .@k3 = syndroCheck(.@k); .@k = BaseExp;
+ .@k4 = syndroCheck(.@k); .@k = BaseExp;
+ .@k5 = syndroCheck(.@k); .@k = BaseExp;
+ .@k6 = syndroCheck(.@k); .@k = BaseExp;
+ .@k7 = syndroCheck(.@k); .@k = BaseExp;
+ .@k8 = syndroCheck(.@k); .@k = BaseExp;
+ // Determine if you'll be afflicted, base chance is 100%
+ .@chance = 100;
+ // Every 2 seconds you spent without killing is -10%
+ if (!.@k1)
+ .@chance -= 10;
+ if (!.@k2)
+ .@chance -= 10;
+ if (!.@k3)
+ .@chance -= 10;
+ if (!.@k4)
+ .@chance -= 10;
+ if (!.@k5)
+ .@chance -= 10;
+ if (!.@k6)
+ .@chance -= 10;
+ if (!.@k7)
+ .@chance -= 10;
+ if (!.@k8)
+ .@chance -= 10;
+ // You killed less than 7 monsters, so zero the chance
+ if (.@mpk + 7 > MONSTERS_KILLED)
+ .@chance -= 20;
+ // (If you killed less than 12 monsters, potentially go to 10%
+ else if (.@mpk + 12 > MONSTERS_KILLED)
+ .@chance -= 10;
+
+ // Determine whenever you'll be afflicted with the Syndrome
+ // The syndrome duration is 30 seconds
+ if (rand2(100) < .@chance) {
+ // Calculate the effect based on your score (5~15%)
+ .@eff = 5 + (.@chance / 10);
+ // If you already have one running (!!), increase the effect
+ if (getstatus(SC_BOTTER_SYNDROME)) {
+ .@t = 1 + getstatus(SC_BOTTER_SYNDROME, 5) / 3600000;
+ .@eff += .@t + min(100, getstatus(SC_BOTTER_SYNDROME, 1));
+ }
+ // Sanitize the effect (it cannot go past 75%)
+ .@eff = min(75, .@eff);
+ SC_Bonus(30, SC_BOTTER_SYNDROME, .@eff);
+ }
+
+ // New tick (15~30 seconds fixed cycle)
+ addtimer2 rand(15000,30000), .name$+"::OnClocked";
+ end;
+
+
}