From 653f63696c9712c67b8f170960e0aa82f1a017d3 Mon Sep 17 00:00:00 2001 From: ZephyrTFA Date: Wed, 8 Nov 2023 03:02:50 -0500 Subject: [PATCH] updoot --- .../shuttle/shield/ship_shield_generator.dm | 165 ++++++++++++++++++ .../overmap/ships/controlled_ship_datum.dm | 19 ++ icons/obj/machines/shield_generator.dmi | Bin 0 -> 2206 bytes shiptest.dme | 1 + 4 files changed, 185 insertions(+) create mode 100644 code/game/machinery/shuttle/shield/ship_shield_generator.dm create mode 100644 icons/obj/machines/shield_generator.dmi diff --git a/code/game/machinery/shuttle/shield/ship_shield_generator.dm b/code/game/machinery/shuttle/shield/ship_shield_generator.dm new file mode 100644 index 000000000000..46d65d1522cf --- /dev/null +++ b/code/game/machinery/shuttle/shield/ship_shield_generator.dm @@ -0,0 +1,165 @@ +// magnetocore - the core of the shield generator +// magnetosphere - the shield itself, on the ship + +// now you might be thinking, if its a magnetosphere doesnt it only protect from magnetic materials? +// cope about it it sounds cool + +/obj/machinery/power/ship_shield_generator + name = "shield generator" + desc = "A high complex machinery which uses an projected electromagnetic field to protect the ship from damage." + icon = 'icons/obj/machines/shield_generator.dmi' + icon_state = "core-off" + // we only need power to spool up the shield, no power is used if the core is already charged + active_power_usage = 2000 + use_power = ACTIVE_POWER_USE + power_channel = AREA_USAGE_EQUIP + + max_integrity = 1000 + integrity_failure = 250 + var/repair_integrity = 125 + + /// The ship we are linked to. + var/datum/overmap/ship/controlled/linked_ship + /// The apc we are drawing power from. + var/obj/machinery/power/apc/linked_apc + + /// The rate of charge per tick. + var/charge_rate + /// The maximum charge of the core. + var/charge_max + /// The current charge of the core. + var/charge + /// The ratio of power to charge + var/charge_ratio = 2 + + /// The rate of spooling per tick. + var/spool_rate + /// The current spool percent. + var/spool_percent + /// The penalty for spooling while inoperable. + var/spool_inoperable_penalty = 0.8 + + var/inoperable_announced = FALSE + +/obj/machinery/power/ship_shield_generator/update_icon_state() + ..() + if(!is_operational || isnull(powernet)) + icon_state = "core-depower" + else if(!spool_percent) + icon_state = "core-off" + else if(spool_percent < 100) + icon_state = "core-spool" + else + icon_state = "core-stable" + +/obj/machinery/power/ship_shield_generator/update_overlays() + . = ..() + switch(spool_percent) + if(0) + return + if(1 to 33) + . += "startup" + if(34 to 66) + . += "idle" + if(67 to 99) + . += "activating" + if(100) + . += "actived" + +/obj/machinery/power/ship_shield_generator/update_overlays() + . = ..() + if(!is_operational) + return + +/obj/machinery/power/ship_shield_generator/connect_to_shuttle(obj/docking_port/mobile/port, obj/docking_port/stationary/dock) + var/datum/overmap/ship/controlled/port_ship = port.current_ship + if(isnull(port_ship)) + return + + if(!isnull(port_ship.shield_generator) && port_ship.shield_generator != src) + say("Unable to link to ship magnetosphere array, interference detected.") + return + + port_ship.shield_generator = src + linked_ship = port_ship + linked_ship.broadcast("Link established to ship magnetosphere array.") + +/obj/machinery/power/ship_shield_generator/process() + if(isnull(linked_ship)) + return PROCESS_KILL + + if(spool_percent < 100) + process_spooling() + return + + if(charge >= charge_max) + return + process_charge() + +/obj/machinery/power/ship_shield_generator/proc/update_charge(new_charge) + if(new_charge > charge_max) + new_charge = charge_max + charge = new_charge + update_appearance() + +/obj/machinery/power/ship_shield_generator/proc/process_spooling() + if(!is_operational || isnull(powernet)) // you are very punished for not powering this + spool_percent = max((spool_percent * spool_inoperable_penalty) - spool_rate, 0) + if(!inoperable_announced) + linked_ship.broadcast("Magenetocore power failure.") + inoperable_announced = TRUE + + else + spool_percent += spool_rate + + if(spool_percent >= 100) + spool_percent = 100 + use_power = NO_POWER_USE + linked_ship.broadcast("Ferrofluid magnetocore at maximum velocity. Shield operational.") + inoperable_announced = FALSE + update_appearance() + +/obj/machinery/power/ship_shield_generator/proc/process_charge() + var/wanted_charge = min(charge_max - charge, charge_rate) + var/wanted_power = min(wanted_charge * charge_ratio, powernet.avail) + var/actual_charge = wanted_power / charge_ratio + use_power(wanted_power) + update_charge(charge + actual_charge) + +/// Call this when the shield is hit with enough force to outright break it +/obj/machinery/power/ship_shield_generator/proc/charge_depleted() + set_machine_stat(machine_stat|BROKEN) + linked_ship.broadcast("Critical failure in magnetocore, unable to error correct.") + spool_percent = 0 + playsound(src, 'sound/mecha/mech_shield_drop.ogg', 50) + +/obj/machinery/power/ship_shield_generator/welder_act(mob/living/user, obj/item/weldingtool/welder) + if(obj_integrity >= max_integrity) + return + + if(!welder.isOn()) + balloon_alert(user, "welder off!") + return TRUE + + if(welder.get_fuel() < 2) + balloon_alert(user, "not enough fuel!") + return TRUE + + var/repair_time = 2 SECONDS + balloon_alert(user, "repairing...") + while(do_after(user, repair_time, target = src)) + if(!welder.use(2)) + balloon_alert(user, "not enough fuel!") + return TRUE + + obj_integrity = min(obj_integrity + repair_integrity, max_integrity) + if(obj_integrity >= max_integrity) + balloon_alert(user, "repaired.") + set_machine_stat(machine_stat & ~BROKEN) + return TRUE + + if(repair_time > 0.5 SECONDS) + repair_time -= 0.5 SECONDS + + balloon_alert(user, "stopped!") + return TRUE diff --git a/code/modules/overmap/ships/controlled_ship_datum.dm b/code/modules/overmap/ships/controlled_ship_datum.dm index cfdf87d44bdd..baf1e3a63fa3 100644 --- a/code/modules/overmap/ships/controlled_ship_datum.dm +++ b/code/modules/overmap/ships/controlled_ship_datum.dm @@ -63,6 +63,11 @@ ///Time that next job slot change can occur COOLDOWN_DECLARE(job_slot_adjustment_cooldown) + /// The ship's shield generator + var/obj/machinery/power/ship_shield_generator/shield_generator + /// The frequency that the ship's radio uses + var/ship_radio_frequency = FREQ_COMMON + /datum/overmap/ship/controlled/Rename(new_name, force = FALSE) var/oldname = name if(!..() || (!COOLDOWN_FINISHED(src, rename_cooldown) && !force)) @@ -448,3 +453,17 @@ master_ship.attempt_key_usage(user, src, src) // hello I am a helm console I promise return TRUE + +/datum/overmap/ship/controlled/proc/broadcast(atom/movable/speaker, message) + set waitfor = FALSE + + var/datum/signal/subspace/vocal/signal = new( + speaker, + ship_radio_frequency, + new /atom/movable/virtualspeaker(null, speaker), + /datum/language/common, + message, + list(SPAN_ROBOT, SPAN_COMMAND), + list(MODE_CUSTOM_SAY_EMOTE = "coldly states"), + ) + signal.send_to_receivers() diff --git a/icons/obj/machines/shield_generator.dmi b/icons/obj/machines/shield_generator.dmi new file mode 100644 index 0000000000000000000000000000000000000000..e42b8ee931dd976d238e00dab9924ea434fa11d5 GIT binary patch literal 2206 zcmV;P2x0e$P)GLvel@3QdIf!L*D+ylz=x4 z`>6l`2UAHzK~#90?Oa=u>?RBaJPQC^^N;Bb*xfb%_a_UuHR)spxmiJSw;$d}@~hqU z%-mG@R3&MdhXe?r15;t_e+B;03glsxHubPDuBoE^27En^AH&L|D!Jx9TfIw>CZs(# zw1F)DN;PB@pPCD&O%MyZ9@miAF2e@3tZZTi3~V8WvAM8I<@->uyRKL<4_JZLw&T{W zf02J{SF8*y6;f=PPGLqmTPzD%N5r)8V?v8)@T^a$z~aqVC^nXLxjP=FPos5|lC@x6 zvd_$ex}pE4m$Oy4^%hne8x|d_pc{=~9Y_IndoiwxY<9|3qv`3MydgZTA{HA4#hq9v2Lj{(GDWuZD|l=oO&S~Gr; ze0}312<*3hv~?T!zAOyjE}FyfGOnQk>ljBm!{{DSw<`JZH)x|PSHFE+LznC{r9D>X zzmJ@76d5-hQ8Tl@X;s9!!qqbs#u8qugOCT*ZN#$jRJseq@a9o zt$Z_I+%>D)`J#hq=q#C)iACib`Jyl2c-q&}m7RQ%2LcGs(Fs0?u#+!xN3{%2bqOCF zVIN=g20Q*&Hx!LqUg_+sfLHXHFlg57+v)S4?> zYa6kV#gER5jo88$$7`~E6(>r6ExtJO^`Vh&=8GT3p?*QW_|cfPXP=Xv_!I~`kx8y& zzDG#-$u zq))siQY-I!gpFDBpAqW!pw}9e^v&3m!2=Rck;fs!WXRp zW>won_zaBky$A!cH&g4v_q}a=u?$eMYt)Y_i>ici1Ab!i^Z;MXJQ`%2f{m`XIY<|o z$V$lj-a21|Wnjt#bv*aG2NqPL$@|_GzR3HkkWYBJfpyEQk@r0gYXPNGpsZ;rYM|_R z{J!@XUqox>FAuIjZoL6u$VCTWKM(Uo0m^|w4$h5+kzG1B{6)UFG-ndUuhFluCy*nl}xxXo+pLpM!=Zj5>P|cN1 z0a_}F!m=!K-0cEiEGPM-Lf}Ncg@zGhs6R*Vd#3&*TiMM^6Bc16z*esb&ev6Uzp8Pa zf@Qwg8*r&m}0IT=B10^EN&03i$a%}GEqaJvLYI`TUUk& z69qTPH$#nhbmz^X74t)1D;zOnC!NKKKl1Qf59>n^Jw#p{U*=(euft2<4o< zK`O3pCQ3eAzNr>Iw#b{Zx;soGS3dR#S$2-Tgs(9IbH8y1rf&UVf05AI7*umu=RVI? zH8*y@{o{w*TL;}G#gTERIR0pR-@SjrisiCTdbK%3A2TUg=P_~0Ts+4}c8Lldy*Wl< zJs?HkZ(X@ujqz92WM}z3>QM}3VPf)K^s{(50D|(fPd5l0ocjtVQ;I4qbZeKw+F{6d zRW*R$q5-wS5pyabG3?>FodyRkl{VhnPeT!fuu~G_SU%ubJ!Ac|f{yHl|g$=J)B0+&u-c*^3e9^Mh z;hI4xUJ-@ir4GoIC4(u7GMPd;#b61*Wlc!YDeFV`EG6~Z;WVhjz;yA|66Nsw0l2%L zK7OfkI2d7cIYeP!cba#aI>+%IG=`h>Drl-40Xe5>MMJ5TtqQGVOf9;&zAa zZra}Ft^}SzPuQu__*zn3uHs02Cr+F=apJ@;i5;o?Q!=|#ezzk3_<`l0Kex4ixhrJC ziz0OEkH4_|_rF;F=T9vE{u`F>xWBOiYQWJ7KYdC+-)T;qIC0{{i4!MIoH+3r_;P;u z{)Xi%c|qvN|2RaGzsi_@% literal 0 HcmV?d00001 diff --git a/shiptest.dme b/shiptest.dme index c6f4d56048db..cc534d685231 100644 --- a/shiptest.dme +++ b/shiptest.dme @@ -957,6 +957,7 @@ #include "code\game\machinery\shuttle\shuttle_engine.dm" #include "code\game\machinery\shuttle\shuttle_engine_types.dm" #include "code\game\machinery\shuttle\shuttle_heater.dm" +#include "code\game\machinery\shuttle\shield\ship_shield_generator.dm" #include "code\game\machinery\telecomms\broadcasting.dm" #include "code\game\machinery\telecomms\machine_interactions.dm" #include "code\game\machinery\telecomms\telecomunications.dm"