//renwicks: fictional unit to describe shield strength
//a small meteor hit will deduct 1 renwick of strength from that shield tile
//light explosion range will do 1 renwick's damage
//medium explosion range will do 2 renwick's damage
//heavy explosion range will do 3 renwick's damage
//explosion damage is cumulative. if a tile is in range of light, medium and heavy damage, it will take a hit from all three
/obj/machinery/shield_gen
name = "shield generator"
desc = "Machine that generates an impenetrable field of energy when activated."
icon = 'code/WorkInProgress/Cael_Aislinn/ShieldGen/shielding.dmi'
icon_state = "generator0"
var/active = 0
var/field_radius = 3
var/list/field
density = 1
anchored = 1
var/locked = 0
var/average_field_strength = 0
var/strengthen_rate = 0.2
var/max_strengthen_rate = 0.2
var/powered = 0
var/check_powered = 1
var/obj/machinery/shield_capacitor/owned_capacitor
var/max_field_strength = 10
var/time_since_fail = 100
var/energy_conversion_rate = 0.01 //how many renwicks per watt?
//
use_power = 1 //0 use nothing
//1 use idle power
//2 use active power
idle_power_usage = 20
active_power_usage = 100
ghost_read=0
ghost_write=0
machine_flags = EMAGGABLE | WRENCHMOVE | FIXED2WORK
/obj/machinery/shield_gen/New()
spawn(10)
for(var/obj/machinery/shield_capacitor/possible_cap in range(1, src))
if(get_dir(possible_cap, src) == possible_cap.dir)
owned_capacitor = possible_cap
break
field = new/list()
..()
/obj/machinery/shield_gen/emag(mob/user)
if(prob(75))
src.locked = !src.locked
user << "Controls are now [src.locked ? "locked." : "unlocked."]"
updateDialog()
var/datum/effect/effect/system/spark_spread/s = new /datum/effect/effect/system/spark_spread
s.set_up(5, 1, src)
s.start()
return 1
playsound(get_turf(src), 'sound/effects/sparks4.ogg', 75, 1)
return
/obj/machinery/shield_gen/wrenchAnchor(mob/user)
if(..())
for(var/obj/machinery/shield_capacitor/cap in range(1, src))
if(!src.anchored && owned_capacitor == cap)
owned_capacitor = null
break
else if(src.anchored && !owned_capacitor)
owned_capacitor = cap
break
cap.updateDialog()
updateDialog()
return 1
return
/obj/machinery/shield_gen/attackby(obj/item/W, mob/user)
if(..())
return 1
else if(istype(W, /obj/item/weapon/card/id))
var/obj/item/weapon/card/id/C = W
if(access_captain in C.access || access_security in C.access || access_engine in C.access)
src.locked = !src.locked
user << "Controls are now [src.locked ? "locked." : "unlocked."]"
updateDialog()
else
user << "Access denied."
/obj/machinery/shield_gen/attack_paw(user as mob)
return src.attack_hand(user)
/obj/machinery/shield_gen/attack_ai(user as mob)
src.add_hiddenprint(user)
return src.attack_hand(user)
/obj/machinery/shield_gen/attack_hand(mob/user)
if(stat & (NOPOWER|BROKEN))
return
interact(user)
/obj/machinery/shield_gen/attack_ghost(mob/user)
if(isAdminGhost(user)) src.attack_hand(user)
return
/obj/machinery/shield_gen/interact(mob/user)
if ( (get_dist(src, user) > 1 ) || (stat & (BROKEN|NOPOWER)) )
if (!istype(user, /mob/living/silicon))
user.unset_machine()
user << browse(null, "window=shield_generator")
return
var/t = "Shield Generator Control Console
"
if(locked)
t += "Swipe your ID card to begin."
else
// AUTOFIXED BY fix_string_idiocy.py
// C:\Users\Rob\\documents\\\projects\vgstation13\code\WorkInProgress\Cael_Aislinn\ShieldGen\shield_gen.dm:102: t += "[owned_capacitor ? "Charge capacitor connected." : "Unable to locate charge capacitor!"]
"
t += {"[owned_capacitor ? "Charge capacitor connected." : "Unable to locate charge capacitor!"]
This generator is: [active ? "Online" : "Offline" ] [active ? "\[Deactivate\]" : "\[Activate\]"]
[time_since_fail > 2 ? "Field is stable." : "Warning, field is unstable!"]
Coverage radius (restart required):
--
-
[field_radius * 2]m
+
++
Overall field strength: [average_field_strength] Renwicks ([max_field_strength ? 100 * average_field_strength / max_field_strength : "NA"]%)
Charge rate: --
-
[strengthen_rate] Renwicks/sec \
+
++
Upkeep energy: [field.len * average_field_strength / energy_conversion_rate] Watts/sec
Additional energy required to charge: [field.len * strengthen_rate / energy_conversion_rate] Watts/sec
Maximum field strength:
\[min\]
--
-
[max_field_strength] Renwicks
+
++
\[max\]
"}
// END NOT-AUTOFIX
// AUTOFIXED BY fix_string_idiocy.py
// C:\Users\Rob\\documents\\\projects\vgstation13\code\WorkInProgress\Cael_Aislinn\ShieldGen\shield_gen.dm:127: t += "