mirror of
https://github.com/CHOMPStation2/CHOMPStation2.git
synced 2025-12-10 02:09:41 +00:00
240 lines
7.3 KiB
Plaintext
240 lines
7.3 KiB
Plaintext
/obj/machinery/recharge_station
|
|
name = "cyborg recharging station"
|
|
desc = "A heavy duty rapid charging system, designed to quickly recharge cyborg power reserves."
|
|
icon = 'icons/obj/objects.dmi'
|
|
icon_state = "borgcharger0"
|
|
density = 1
|
|
anchored = 1
|
|
use_power = 1
|
|
idle_power_usage = 50
|
|
var/mob/occupant = null
|
|
var/obj/item/weapon/cell/cell = null
|
|
var/icon_update_tick = 0 // Used to rebuild the overlay only once every 10 ticks
|
|
var/charging = 0
|
|
|
|
var/charging_power // W. Power rating used for charging the cyborg. 120 kW if un-upgraded
|
|
var/restore_power_active // W. Power drawn from APC when an occupant is charging. 40 kW if un-upgraded
|
|
var/restore_power_passive // W. Power drawn from APC when idle. 7 kW if un-upgraded
|
|
var/weld_rate = 0 // How much brute damage is repaired per tick
|
|
var/wire_rate = 0 // How much burn damage is repaired per tick
|
|
|
|
var/weld_power_use = 2300 // power used per point of brute damage repaired. 2.3 kW ~ about the same power usage of a handheld arc welder
|
|
var/wire_power_use = 500 // power used per point of burn damage repaired.
|
|
|
|
/obj/machinery/recharge_station/New()
|
|
..()
|
|
|
|
component_parts = list()
|
|
component_parts += new /obj/item/weapon/circuitboard/recharge_station(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/manipulator(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/manipulator(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/capacitor(src)
|
|
component_parts += new /obj/item/weapon/stock_parts/capacitor(src)
|
|
component_parts += new /obj/item/weapon/cell/high(src)
|
|
component_parts += new /obj/item/stack/cable_coil(src, 5)
|
|
|
|
RefreshParts()
|
|
|
|
update_icon()
|
|
|
|
/obj/machinery/recharge_station/proc/has_cell_power()
|
|
return cell && cell.percent() > 0
|
|
|
|
/obj/machinery/recharge_station/process()
|
|
if(stat & (BROKEN))
|
|
return
|
|
if(!cell) // Shouldn't be possible, but sanity check
|
|
return
|
|
|
|
if((stat & NOPOWER) && !has_cell_power()) // No power and cell is dead.
|
|
if(icon_update_tick)
|
|
icon_update_tick = 0 //just rebuild the overlay once more only
|
|
update_icon()
|
|
return
|
|
|
|
//First, draw from the internal power cell to recharge/repair/etc the occupant
|
|
if(occupant)
|
|
process_occupant()
|
|
|
|
//Then, if external power is available, recharge the internal cell
|
|
var/recharge_amount = 0
|
|
if(!(stat & NOPOWER))
|
|
// Calculating amount of power to draw
|
|
recharge_amount = (occupant ? restore_power_active : restore_power_passive) * CELLRATE
|
|
|
|
recharge_amount = cell.give(recharge_amount)
|
|
use_power(recharge_amount / CELLRATE)
|
|
|
|
if(icon_update_tick >= 10)
|
|
icon_update_tick = 0
|
|
else
|
|
icon_update_tick++
|
|
|
|
if(occupant || recharge_amount)
|
|
update_icon()
|
|
|
|
//since the recharge station can still be on even with NOPOWER. Instead it draws from the internal cell.
|
|
/obj/machinery/recharge_station/auto_use_power()
|
|
if(!(stat & NOPOWER))
|
|
return ..()
|
|
|
|
if(!has_cell_power())
|
|
return 0
|
|
if(src.use_power == 1)
|
|
cell.use(idle_power_usage * CELLRATE)
|
|
else if(src.use_power >= 2)
|
|
cell.use(active_power_usage * CELLRATE)
|
|
return 1
|
|
|
|
//Processes the occupant, drawing from the internal power cell if needed.
|
|
/obj/machinery/recharge_station/proc/process_occupant()
|
|
if(istype(occupant, /mob/living/silicon/robot))
|
|
var/mob/living/silicon/robot/R = occupant
|
|
|
|
if(R.module)
|
|
R.module.respawn_consumable(R, charging_power * CELLRATE / 250) //consumables are magical, apparently
|
|
if(R.cell && !R.cell.fully_charged())
|
|
var/diff = min(R.cell.maxcharge - R.cell.charge, charging_power * CELLRATE) // Capped by charging_power / tick
|
|
var/charge_used = cell.use(diff)
|
|
R.cell.give(charge_used)
|
|
|
|
//Lastly, attempt to repair the cyborg if enabled
|
|
if(weld_rate && R.getBruteLoss() && cell.checked_use(weld_power_use * weld_rate * CELLRATE))
|
|
R.adjustBruteLoss(-weld_rate)
|
|
if(wire_rate && R.getFireLoss() && cell.checked_use(wire_power_use * wire_rate * CELLRATE))
|
|
R.adjustFireLoss(-wire_rate)
|
|
|
|
/obj/machinery/recharge_station/examine(mob/user)
|
|
..(user)
|
|
user << "The charge meter reads: [round(chargepercentage())]%"
|
|
|
|
/obj/machinery/recharge_station/proc/chargepercentage()
|
|
if(!cell)
|
|
return 0
|
|
return cell.percent()
|
|
|
|
/obj/machinery/recharge_station/relaymove(mob/user as mob)
|
|
if(user.stat)
|
|
return
|
|
go_out()
|
|
return
|
|
|
|
/obj/machinery/recharge_station/emp_act(severity)
|
|
if(occupant)
|
|
occupant.emp_act(severity)
|
|
go_out()
|
|
if(cell)
|
|
cell.emp_act(severity)
|
|
..(severity)
|
|
|
|
/obj/machinery/recharge_station/attackby(var/obj/item/O as obj, var/mob/user as mob)
|
|
if(!occupant)
|
|
if(default_deconstruction_screwdriver(user, O))
|
|
return
|
|
if(default_deconstruction_crowbar(user, O))
|
|
return
|
|
if(default_part_replacement(user, O))
|
|
return
|
|
|
|
..()
|
|
|
|
/obj/machinery/recharge_station/RefreshParts()
|
|
..()
|
|
var/man_rating = 0
|
|
var/cap_rating = 0
|
|
|
|
for(var/obj/item/weapon/stock_parts/P in component_parts)
|
|
if(istype(P, /obj/item/weapon/stock_parts/capacitor))
|
|
cap_rating += P.rating
|
|
if(istype(P, /obj/item/weapon/stock_parts/manipulator))
|
|
man_rating += P.rating
|
|
cell = locate(/obj/item/weapon/cell) in component_parts
|
|
|
|
charging_power = 40000 + 40000 * cap_rating
|
|
restore_power_active = 10000 + 15000 * cap_rating
|
|
restore_power_passive = 5000 + 1000 * cap_rating
|
|
weld_rate = max(0, man_rating - 3)
|
|
wire_rate = max(0, man_rating - 5)
|
|
|
|
desc = initial(desc)
|
|
desc += " Uses a dedicated internal power cell to deliver [charging_power]W when in use."
|
|
if(weld_rate)
|
|
desc += "<br>It is capable of repairing structural damage."
|
|
if(wire_rate)
|
|
desc += "<br>It is capable of repairing burn damage."
|
|
|
|
/obj/machinery/recharge_station/proc/build_overlays()
|
|
overlays.Cut()
|
|
switch(round(chargepercentage()))
|
|
if(1 to 20)
|
|
overlays += image('icons/obj/objects.dmi', "statn_c0")
|
|
if(21 to 40)
|
|
overlays += image('icons/obj/objects.dmi', "statn_c20")
|
|
if(41 to 60)
|
|
overlays += image('icons/obj/objects.dmi', "statn_c40")
|
|
if(61 to 80)
|
|
overlays += image('icons/obj/objects.dmi', "statn_c60")
|
|
if(81 to 98)
|
|
overlays += image('icons/obj/objects.dmi', "statn_c80")
|
|
if(99 to 110)
|
|
overlays += image('icons/obj/objects.dmi', "statn_c100")
|
|
|
|
/obj/machinery/recharge_station/update_icon()
|
|
..()
|
|
if(stat & BROKEN)
|
|
icon_state = "borgcharger0"
|
|
return
|
|
|
|
if(occupant)
|
|
if((stat & NOPOWER) && !has_cell_power())
|
|
icon_state = "borgcharger2"
|
|
else
|
|
icon_state = "borgcharger1"
|
|
else
|
|
icon_state = "borgcharger0"
|
|
|
|
if(icon_update_tick == 0)
|
|
build_overlays()
|
|
|
|
/obj/machinery/recharge_station/proc/go_out()
|
|
if(!(occupant))
|
|
return
|
|
occupant.loc = loc
|
|
occupant.reset_view()
|
|
occupant = null
|
|
update_icon()
|
|
return
|
|
|
|
/obj/machinery/recharge_station/verb/move_eject()
|
|
set category = "Object"
|
|
set src in oview(1)
|
|
if(usr.stat != 0)
|
|
return
|
|
go_out()
|
|
add_fingerprint(usr)
|
|
return
|
|
|
|
/obj/machinery/recharge_station/verb/move_inside()
|
|
set category = "Object"
|
|
set src in oview(1)
|
|
|
|
if(usr.stat == DEAD)
|
|
return
|
|
if(occupant)
|
|
usr << "<span class='notice'>\The [src] is already occupied!</span>"
|
|
return
|
|
|
|
var/mob/living/silicon/robot/R = usr
|
|
if(!istype(R))
|
|
usr << "<span class='notice'>Only synthetics may enter the recharger!</span>"
|
|
return
|
|
if(!R.cell)
|
|
usr << "<span class='notice'>Without a powercell, you can't be recharged.</span>"
|
|
return
|
|
|
|
usr.reset_view(src)
|
|
usr.loc = src
|
|
occupant = usr
|
|
add_fingerprint(usr)
|
|
update_icon()
|