diff --git a/code/game/objects/effects/effect_system/effects_foam.dm b/code/game/objects/effects/effect_system/effects_foam.dm index 4fd882aae22b..7c2a3801caf2 100644 --- a/code/game/objects/effects/effect_system/effects_foam.dm +++ b/code/game/objects/effects/effect_system/effects_foam.dm @@ -71,6 +71,8 @@ lifetime = 80 amount = 0 //no spread slippery_foam = FALSE + color = "#A6FAFF55" + /obj/effect/particle_effect/foam/antirad/process() ..() @@ -78,16 +80,17 @@ var/turf/open/T = get_turf(src) var/obj/effect/radiation/rads = (locate(/obj/effect/radiation) in T) if(rads && istype(T)) - qdel(rads) + rads.rad_power = rads.rad_power * rand(0.8, 0.95) + if (rads.rad_power <= RAD_BACKGROUND_RADIATION) + qdel(rads) + for(var/obj/things in get_turf(src)) + things.wash(CLEAN_RAD) /obj/effect/particle_effect/foam/antirad/kill_foam() STOP_PROCESSING(SSfastprocess, src) flick("[icon_state]-disolve", src) QDEL_IN(src, 5) -/obj/effect/particle_effect/foam/antirad/foam_mob(mob/living/L) - for() - /obj/effect/particle_effect/foam/metal name = "aluminium foam" metal = ALUMINIUM_FOAM diff --git a/code/game/objects/items/tanks/watertank.dm b/code/game/objects/items/tanks/watertank.dm index 50f709dcd65f..23fe0852c353 100644 --- a/code/game/objects/items/tanks/watertank.dm +++ b/code/game/objects/items/tanks/watertank.dm @@ -175,6 +175,39 @@ amount_per_transfer_from_this = (amount_per_transfer_from_this == 10 ? 5 : 10) to_chat(user, "You [amount_per_transfer_from_this == 10 ? "remove" : "fix"] the nozzle. You'll now use [amount_per_transfer_from_this] units per spray.") +//radiation cleanup pack + +/obj/item/watertank/anti_rad + name = "radiation foam pack" + desc = "A pressurized backpack tank with sprayer nozzle, intended to clean up radioactive hazards." + item_state = "waterbackpackatmos" + icon_state = "waterbackpackatmos" + volume = 200 + slowdown = 0.3 + +/obj/item/watertank/anti_rad/Initialize() + . = ..() + reagents.add_reagent(/datum/reagent/anti_radiation_foam, 200) + + +/obj/item/reagent_containers/spray/mister/anti_rad + name = "spray nozzle" + desc = "A heavy duty nozzle attached to a radiation foam tank." + icon_state = "atmos_nozzle" + item_state = "nozzleatmos" + amount_per_transfer_from_this = 5 + possible_transfer_amounts = list() + current_range = 6 + spray_range = 6 + + +/obj/item/watertank/anti_rad/make_noz() + return new /obj/item/reagent_containers/spray/mister/anti_rad(src) + +/obj/item/reagent_containers/spray/mister/anti_rad/attack_self(mob/user) + amount_per_transfer_from_this = (amount_per_transfer_from_this == 10 ? 5 : 10) + to_chat(user, "You [amount_per_transfer_from_this == 10 ? "tigten" : "loosen"] the nozzle. You'll now use [amount_per_transfer_from_this] units per spray.") + //ATMOS FIRE FIGHTING BACKPACK #define EXTINGUISHER 0 diff --git a/code/modules/cargo/packs/tools.dm b/code/modules/cargo/packs/tools.dm index 6b43448a5d81..1b3b8d571a5c 100644 --- a/code/modules/cargo/packs/tools.dm +++ b/code/modules/cargo/packs/tools.dm @@ -140,3 +140,14 @@ contains = list(/obj/structure/reagent_dispensers/foamtank) crate_name = "foam tank crate" crate_type = /obj/structure/closet/crate/large + +/datum/supply_pack/tools/radfoamtank + name = "Radiation Foam Tank Crate" + desc = "Contains a tank of anti-radiation foam. Pressurized sprayer included!" + cost = 1500 + contains = list( + /obj/item/watertank/anti_rad, + /obj/structure/reagent_dispensers/foamtank/antirad + ) + crate_name = "foam tank crate" + crate_type = /obj/structure/closet/crate/large diff --git a/code/modules/reagents/chemistry/reagents/other_reagents.dm b/code/modules/reagents/chemistry/reagents/other_reagents.dm index 7db9a85b20d3..2dbeeadad021 100644 --- a/code/modules/reagents/chemistry/reagents/other_reagents.dm +++ b/code/modules/reagents/chemistry/reagents/other_reagents.dm @@ -2539,7 +2539,7 @@ color = "#A6FAFF55" taste_description = "the inside of a fire extinguisher" -/datum/reagent/firefighting_foam/expose_turf(turf/open/T, reac_volume) +/datum/reagent/anti_radiation_foam/expose_turf(turf/open/T, reac_volume) if (!istype(T)) return @@ -2548,16 +2548,12 @@ if(!F) F = new(T) else if(istype(F)) - F.lifetime = initial(F.lifetime) //reduce object churn a little bit when using smoke by keeping existing foam alive a bit longer + F.lifetime = initial(F.lifetime) //the foam is what does the cleaning here - var/obj/effect/radiation/rads = (locate(/obj/effect/radiation) in T) - if(rads && istype(T)) - qdel(rads) - -/datum/reagent/firefighting_foam/expose_obj(obj/O, reac_volume) +/datum/reagent/anti_radiation_foam/expose_obj(obj/O, reac_volume) O.wash(CLEAN_RAD) -/datum/reagent/firefighting_foam/expose_mob(mob/living/M, method=TOUCH, reac_volume) +/datum/reagent/anti_radiation_foam/expose_mob(mob/living/M, method=TOUCH, reac_volume) if(method in list(TOUCH)) M.radiation = M.radiation - rand(max(M.radiation * 0.95, M.radiation)) //get the hose M.ExtinguishMob() diff --git a/code/modules/reagents/reagent_dispenser.dm b/code/modules/reagents/reagent_dispenser.dm index fafd67305c9c..8ee3d2100322 100644 --- a/code/modules/reagents/reagent_dispenser.dm +++ b/code/modules/reagents/reagent_dispenser.dm @@ -58,6 +58,10 @@ reagent_id = /datum/reagent/firefighting_foam tank_volume = 500 +/obj/structure/reagent_dispensers/foamtank/antirad + reagent_id = /datum/reagent/anti_radiation_foam + tank_volume = 1000 + /obj/structure/reagent_dispensers/fueltank name = "fuel tank" desc = "A tank full of industrial welding fuel. Do not consume." diff --git a/shiptest.dme b/shiptest.dme index 55ad11a800d5..b6fc9860ba42 100644 --- a/shiptest.dme +++ b/shiptest.dme @@ -1944,7 +1944,6 @@ #include "code\modules\cargo\packs\gun.dm" #include "code\modules\cargo\packs\machinery.dm" #include "code\modules\cargo\packs\material.dm" -#include "code\modules\cargo\packs\mechs.dm" #include "code\modules\cargo\packs\medical.dm" #include "code\modules\cargo\packs\sec_supply.dm" #include "code\modules\cargo\packs\spacesuit_armor.dm"