diff --git a/_maps/map_files/Aetherwhisp/Aetherwhisp2.dmm b/_maps/map_files/Aetherwhisp/Aetherwhisp2.dmm index 2058d99929b..bcd941f187c 100644 --- a/_maps/map_files/Aetherwhisp/Aetherwhisp2.dmm +++ b/_maps/map_files/Aetherwhisp/Aetherwhisp2.dmm @@ -1625,18 +1625,7 @@ /obj/effect/turf_decal/stripes/line{ dir = 4 }, -/obj/structure/window/reinforced{ - dir = 4 - }, -/obj/structure/window/reinforced{ - layer = 2.89 - }, -/obj/structure/table, -/obj/item/multitool{ - pixel_x = 4; - pixel_y = -1 - }, -/obj/item/screwdriver, +/obj/machinery/cooling/storage, /turf/open/floor/engine, /area/nsv/weapons/starboard) "bfj" = ( @@ -8625,6 +8614,7 @@ /obj/structure/cable/white{ icon_state = "1-2" }, +/obj/machinery/cooling/cooler, /turf/open/floor/carpet/ship/orange_carpet, /area/nsv/weapons/starboard) "fLO" = ( @@ -14517,6 +14507,7 @@ /obj/structure/cable/white{ icon_state = "1-8" }, +/obj/machinery/cooling/cooler, /turf/open/floor/carpet/ship/orange_carpet, /area/nsv/weapons/starboard) "jNL" = ( @@ -21004,6 +20995,11 @@ pixel_y = 26 }, /obj/structure/table, +/obj/item/multitool{ + pixel_x = 4; + pixel_y = -1 + }, +/obj/item/screwdriver, /turf/open/floor/engine, /area/nsv/weapons/starboard) "ovd" = ( @@ -27743,6 +27739,10 @@ /obj/machinery/atmospherics/pipe/simple/scrubbers/hidden/layer4, /turf/open/floor/wood, /area/library) +"sGF" = ( +/obj/machinery/cooling/storage, +/turf/open/floor/carpet/ship/orange_carpet, +/area/nsv/weapons/starboard) "sGH" = ( /obj/machinery/chem_dispenser, /turf/open/floor/plating, @@ -30306,6 +30306,10 @@ /obj/effect/landmark/start/cyborg, /turf/open/floor/carpet/ship/purple_carpet, /area/science/robotics/lab) +"uNg" = ( +/obj/machinery/cooling/cooler, +/turf/open/floor/carpet/ship/orange_carpet, +/area/nsv/weapons/starboard) "uNA" = ( /obj/structure/cable{ icon_state = "1-2" @@ -80758,7 +80762,7 @@ xjr ouM beV gKC -gKC +beV gKC iRW gKC @@ -81526,13 +81530,13 @@ nZT nZT hbT xjr +uNg wrq wrq wrq wrq wrq -wrq -wrq +sGF seW iyw xMP diff --git a/nsv13/code/game/objects/items/nsv_circuitboards.dm b/nsv13/code/game/objects/items/nsv_circuitboards.dm index 7196fd366b5..6a526f864d2 100644 --- a/nsv13/code/game/objects/items/nsv_circuitboards.dm +++ b/nsv13/code/game/objects/items/nsv_circuitboards.dm @@ -481,29 +481,25 @@ //energy weapon cooling /obj/item/circuitboard/machine/cooling name = "subspace cooling unit circuit board" - icon = 'icons/obj/module.dmi' - icon_state = "command" - materials = list(/datum/material/glass=1000) - w_class = WEIGHT_CLASS_SMALL + materials = list(/datum/material/glass=1000, /datum/material/copper=15000) + build_path = /obj/machinery/cooling/cooler req_components = list( /obj/item/stack/cable_coil = 30, /obj/item/stock_parts/matter_bin = 1, - /obj/item/stack/sheet/mineral/copper = 15, /obj/item/stock_parts/capacitor = 4, /obj/item/stock_parts/micro_laser = 4, - /obj/item/stack/ore/bluespace_crystal = 1) + /obj/item/stock_parts/subspace/ansible = 1, + /obj/item/stock_parts/subspace/crystal =1) /obj/item/circuitboard/machine/cooling/storage name = "subspace heatsink unit circuit board" - icon = 'icons/obj/module.dmi' - icon_state = "command" - materials = list(/datum/material/glass=1000) - w_class = WEIGHT_CLASS_SMALL + materials = list(/datum/material/glass=1000, /datum/material/copper=15000) + build_path = /obj/machinery/cooling/storage req_components = list( /obj/item/stack/cable_coil = 30, /obj/item/stock_parts/matter_bin = 4, - /obj/item/stack/sheet/mineral/copper = 30, /obj/item/stock_parts/capacitor = 2, /obj/item/stock_parts/micro_laser = 2, - /obj/item/stack/ore/bluespace_crystal = 1) + /obj/item/stock_parts/subspace/ansible = 1, + /obj/item/stock_parts/subspace/crystal =1) diff --git a/nsv13/code/modules/munitions/ship_weapons/energy_weapons/phaser.dm b/nsv13/code/modules/munitions/ship_weapons/energy_weapons/phaser.dm index b53c27e8b91..a03c0f36d65 100644 --- a/nsv13/code/modules/munitions/ship_weapons/energy_weapons/phaser.dm +++ b/nsv13/code/modules/munitions/ship_weapons/energy_weapons/phaser.dm @@ -33,8 +33,7 @@ var/combo = null var/combocount = 0 //How far into the combo are they? var/overheat_sound = 'sound/effects/smoke.ogg' - var/list/coolers = list() - var/list/storages = list() + var/list/cooling = list() var/cooling_amount = 0 var/storage_amount = 0 var/storage_rate = 100 @@ -45,7 +44,7 @@ var/heat = 0 var/charge_rate = 430000 //How quickly do we charge? var/charge_per_shot = 660000 //How much power per shot do we have to use? - var/heat_per_shot = 100 //how much heat do we make per shot + var/heat_per_shot = 250 //how much heat do we make per shot var/heat_rate = 10 // how fast do we discharge heat var/max_heat = 1000 //how much heat before ::fun:: happens var/overloaded = 0 //have we cooked ourself @@ -60,11 +59,11 @@ energy_weapon_type = /datum/ship_weapon/phaser circuit = /obj/item/circuitboard/machine/phase_cannon charge_rate = 800000 // At power level 5, requires 3MW per tick to charge(this is wrong. but I don't have the proper numbers) - charge_per_shot = 4000000 // At power level 5, requires 20MW total to fire, takes about 12 seconds to gain 1 charge (ditto) + charge_per_shot = 3800000 // At power level 5, requires 20MW total to fire, takes about 12 seconds to gain 1 charge (ditto). I'm actually making this less demanding so that heat becomes the limiting factor, especially for this one. max_charge = 8000000 // Store 2 charges power_modifier_cap = 5 //Allows you to do insanely powerful oneshot lasers. Maximum theoretical damage of 500. max_heat = 2000 - heat_per_shot = 800 + heat_per_shot = 1200 heat_rate = 5 storage_rate = 140 @@ -75,7 +74,7 @@ /obj/machinery/ship_weapon/energy/examine(mob/user) . = ..() - . += "The Thermal Transceiver is currently at [length(storages)+length(coolers)]0% connection capacity." + . += "The Thermal Transceiver is currently at [length(cooling)]0% connection capacity." if(in_range(user, src) || isobserver(user)) . += "The heatsink display reads [(heat)] out of [(max_heat)]." if(maint_state != MSTATE_CLOSED) @@ -101,7 +100,7 @@ ui.set_autoupdate(TRUE) /obj/machinery/ship_weapon/energy/proc/vent() - if(heat > max_heat/4) + if(heat > max_heat*0.25) weapon_state = STATE_VENTING ventnumber = max_heat*0.25 else @@ -265,11 +264,12 @@ /obj/machinery/ship_weapon/energy/proc/process_heat()//heat management. don't push your weapons too hard. actual heat generation is in _ship_weapons.dm - - for(var/obj/machinery/cooling/cooler/C in coolers) + cooling_amount = 0 + for(var/obj/machinery/cooling/cooler/C in cooling) if(!(C.machine_stat & (BROKEN|NOPOWER|MAINT))) cooling_amount++ - for(var/obj/machinery/cooling/storage/C in storages) + storage_amount = 0 + for(var/obj/machinery/cooling/storage/C in cooling) if(!(C.machine_stat & (BROKEN|NOPOWER|MAINT))) storage_amount++ max_heat = initial(max_heat) + (storage_amount*storage_rate) @@ -283,10 +283,10 @@ else return if(STATE_VENTING) - if(heat <= max_heat-ventnumber) + if(heat <= ventnumber) weapon_state = STATE_NOTHING return - heat = max(heat-(H+H*0.2),0) + heat = max(heat-(cooling_amount*(heat_rate+(0.25*heat_rate))),0) return if(heat >= max_heat) overload() @@ -404,6 +404,6 @@ return ..() /obj/machinery/ship_weapon/energy/Destroy() - for(var/obj/machinery/cooling/E in storages | coolers) + for(var/obj/machinery/cooling/E in cooling) E.parent = null . = ..() diff --git a/nsv13/code/modules/munitions/ship_weapons/energy_weapons/subspacecooling.dm b/nsv13/code/modules/munitions/ship_weapons/energy_weapons/subspacecooling.dm index b88406d68d0..55d80081a50 100644 --- a/nsv13/code/modules/munitions/ship_weapons/energy_weapons/subspacecooling.dm +++ b/nsv13/code/modules/munitions/ship_weapons/energy_weapons/subspacecooling.dm @@ -3,7 +3,6 @@ desc = "A subspace unit." icon = 'nsv13/icons/obj/subspace.dmi' icon_state = "cooler" - circuit = /obj/item/circuitboard/machine bound_width = 32 pixel_x = 0 pixel_y = 0 @@ -11,7 +10,6 @@ var/obj/machinery/ship_weapon/energy/parent var/on = FALSE density = TRUE - critical_machine = TRUE /obj/machinery/cooling/cooler name = "subspace cooling unit" @@ -20,26 +18,11 @@ -/obj/machinery/cooling/cooler/Initialize(mapload) - . = ..() - var/obj/machinery/ship_weapon/energy/E = locate(/obj/machinery/ship_weapon/energy) in orange(1, src) //I have no idea what I'm doing and this causes errors so - E.coolers |= src - parent = E - -/obj/machinery/cooling/storage/Initialize(mapload) - . = ..() - var/obj/machinery/ship_weapon/energy/E = locate(/obj/machinery/ship_weapon/energy) in orange(1, src) - E.storages |= src - parent = E - - -/obj/machinery/cooling/cooler/Destroy() - parent.coolers -= src +/obj/machinery/cooling/Destroy() + if(parent) + parent.cooling -= src . = ..() -/obj/machinery/cooling/storage/Destroy() - parent.storages -= src - . = ..() /obj/machinery/cooling/attack_hand(mob/user) . = ..() @@ -87,23 +70,15 @@ to_chat(user, "-% Cannot link machines across power zones. %-") return - - if(istype(src,/obj/machinery/cooling/cooler)) - parent.coolers -= src - parent = null - parent = P.buffer - .=TRUE - parent.coolers |= src - to_chat(user, "-% Successfully linked [P.buffer] with [src] %-") - if(istype(src,/obj/machinery/cooling/storage)) - parent.storages -= src + if(parent) + parent.cooling -= src parent = null - parent = P.buffer - .=TRUE - parent.storages |= src - to_chat(user, "-% Successfully linked [P.buffer] with [src] %-") - if(length(parent.storages)+length(parent.coolers) >= 11) - var/E = pick(parent.storages+parent.coolers) + parent = P.buffer + .=TRUE + parent.cooling |= src + to_chat(user, "-% Successfully linked [P.buffer] with [src] %-") + if(length(parent.cooling) >= 11) + var/E = pick(parent.cooling) explosion(get_turf(E), 0, 1, 3, 5, flame_range = 4) return