From b4a802987b0eb6387d67b1d9d7972777e8af69d2 Mon Sep 17 00:00:00 2001 From: Helg2 Date: Sun, 22 Dec 2024 00:23:59 +0200 Subject: [PATCH 1/2] Update cinematic.dm --- code/datums/cinematic.dm | 51 +++++++++++----------------------------- 1 file changed, 14 insertions(+), 37 deletions(-) diff --git a/code/datums/cinematic.dm b/code/datums/cinematic.dm index 004f93345bf..ae4f101d6bb 100644 --- a/code/datums/cinematic.dm +++ b/code/datums/cinematic.dm @@ -19,7 +19,6 @@ GLOBAL_LIST_EMPTY(cinematics) watcher = GLOB.mob_list playing.play(watcher) - /atom/movable/screen/cinematic icon = 'icons/effects/station_explosion.dmi' icon_state = "station_intact" @@ -28,24 +27,28 @@ GLOBAL_LIST_EMPTY(cinematics) mouse_opacity = MOUSE_OPACITY_TRANSPARENT screen_loc = "CENTER-7,CENTER-7" - /datum/cinematic var/id = CINEMATIC_DEFAULT - var/list/watching = list() //List of clients watching this - var/list/locked = list() //Who had notransform set during the cinematic - var/is_global = FALSE //Global cinematics will override mob-specific ones + ///List of clients watching this + var/list/watching = list() + ///Who had notransform set during the cinematic + var/list/locked = list() + ///Global cinematics will override mob-specific ones + var/is_global = FALSE var/atom/movable/screen/cinematic/screen - var/datum/callback/special_callback //For special effects synced with animation (explosions after the countdown etc) - var/runtime = 5 SECONDS //How long it runs for - var/cleanup_time = 30 SECONDS //How long for the final screen to remain - var/stop_ooc = TRUE //Turns off ooc when played globally. - + ///For special effects synced with animation (explosions after the countdown etc) + var/datum/callback/special_callback + ///How long it runs for + var/runtime = 5 SECONDS + ///How long for the final screen to remain + var/cleanup_time = 30 SECONDS + ///Turns off ooc when played globally. + var/stop_ooc = TRUE /datum/cinematic/New() GLOB.cinematics += src screen = new(src) - /datum/cinematic/Destroy() GLOB.cinematics -= src QDEL_NULL(screen) @@ -53,7 +56,6 @@ GLOBAL_LIST_EMPTY(cinematics) M.notransform = FALSE return ..() - /datum/cinematic/proc/play(watchers) //Check if you can actually play it (stop mob cinematics for global ones) and create screen objects for(var/A in GLOB.cinematics) @@ -73,7 +75,6 @@ GLOBAL_LIST_EMPTY(cinematics) ooc_toggled = TRUE GLOB.ooc_allowed = FALSE - for(var/i in GLOB.mob_list) var/mob/M = i if(M in watchers) @@ -98,7 +99,6 @@ GLOBAL_LIST_EMPTY(cinematics) qdel(src) - //Sound helper /datum/cinematic/proc/cinematic_sound(s) if(is_global) @@ -107,23 +107,19 @@ GLOBAL_LIST_EMPTY(cinematics) for(var/C in watching) SEND_SOUND(C, s) - //Fire up special callback for actual effects synchronized with animation (eg real nuke explosion happens midway) /datum/cinematic/proc/special() if(special_callback) special_callback.Invoke() - //Actual cinematic goes in here /datum/cinematic/proc/content() sleep(runtime) - /datum/cinematic/nuke_win id = CINEMATIC_NUKE_WIN runtime = 3.5 SECONDS - /datum/cinematic/nuke_win/content() flick("intro_nuke", screen) sleep(runtime) @@ -132,12 +128,10 @@ GLOBAL_LIST_EMPTY(cinematics) special() screen.icon_state = "summary_nukewin" - /datum/cinematic/nuke_miss id = CINEMATIC_NUKE_MISS runtime = 3.5 SECONDS - /datum/cinematic/nuke_miss/content() flick("intro_nuke", screen) sleep(runtime) @@ -146,12 +140,10 @@ GLOBAL_LIST_EMPTY(cinematics) flick("station_intact_fade_red", screen) screen.icon_state = "summary_nukefail" - /datum/cinematic/nuke_selfdestruct id = CINEMATIC_SELFDESTRUCT runtime = 3.5 SECONDS - /datum/cinematic/nuke_selfdestruct/content() flick("intro_nuke", screen) sleep(runtime) @@ -160,12 +152,10 @@ GLOBAL_LIST_EMPTY(cinematics) special() screen.icon_state = "summary_selfdes" - /datum/cinematic/nuke_selfdestruct_miss id = CINEMATIC_SELFDESTRUCT_MISS runtime = 3.5 SECONDS - /datum/cinematic/nuke_selfdestruct_miss/content() flick("intro_nuke", screen) sleep(runtime) @@ -173,12 +163,10 @@ GLOBAL_LIST_EMPTY(cinematics) special() screen.icon_state = "station_intact" - /datum/cinematic/malf id = CINEMATIC_MALF runtime = 7.6 SECONDS - /datum/cinematic/malf/content() flick("intro_malf", screen) sleep(runtime) @@ -187,12 +175,10 @@ GLOBAL_LIST_EMPTY(cinematics) special() screen.icon_state = "summary_malf" - /datum/cinematic/nuke_annihilation id = CINEMATIC_ANNIHILATION runtime = 3.5 SECONDS - /datum/cinematic/nuke_annihilation/content() flick("intro_nuke", screen) sleep(runtime) @@ -201,13 +187,11 @@ GLOBAL_LIST_EMPTY(cinematics) special() screen.icon_state = "summary_totala" - /datum/cinematic/fake id = CINEMATIC_NUKE_FAKE cleanup_time = 10 SECONDS runtime = 3.5 SECONDS - /datum/cinematic/fake/content() flick("intro_nuke", screen) sleep(runtime) @@ -215,37 +199,30 @@ GLOBAL_LIST_EMPTY(cinematics) flick("summary_selfdes", screen) special() - /datum/cinematic/no_core id = CINEMATIC_NUKE_NO_CORE cleanup_time = 10 SECONDS runtime = 3.5 SECONDS - /datum/cinematic/no_core/content() flick("intro_nuke", screen) sleep(runtime) flick("station_intact", screen) cinematic_sound(sound('sound/ambience/signal.ogg', channel = CHANNEL_CINEMATIC)) - /datum/cinematic/nuke_far id = CINEMATIC_NUKE_FAR cleanup_time = 0 - /datum/cinematic/nuke_far/content() cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) special() - - /datum/cinematic/crash_nuke id = CINEMATIC_CRASH_NUKE runtime = 7 SECONDS cleanup_time = 15 SECONDS - /datum/cinematic/crash_nuke/content() screen.icon_state = "planet_start" flick("intro_nuke", screen) // 3.5 seconds From 449a07621a3625bf334525a26c44cf60abce30db Mon Sep 17 00:00:00 2001 From: Helg2 Date: Sun, 22 Dec 2024 01:04:05 +0200 Subject: [PATCH 2/2] mhm --- code/datums/cinematic.dm | 147 ++++++++++++--------------- code/datums/gamemodes/infestation.dm | 2 +- 2 files changed, 64 insertions(+), 85 deletions(-) diff --git a/code/datums/cinematic.dm b/code/datums/cinematic.dm index ae4f101d6bb..2ca21195340 100644 --- a/code/datums/cinematic.dm +++ b/code/datums/cinematic.dm @@ -88,18 +88,12 @@ GLOBAL_LIST_EMPTY(cinematics) locked += M //Actually play it - content() + pre_content() //Cleanup - sleep(cleanup_time) - - //Restore OOC - if(ooc_toggled) - GLOB.ooc_allowed = TRUE + addtimer(CALLBACK(src, PROC_REF(cleanup_content), ooc_toggled), cleanup_time) - qdel(src) - -//Sound helper +///Sound helper /datum/cinematic/proc/cinematic_sound(s) if(is_global) SEND_SOUND(world, s) @@ -107,106 +101,81 @@ GLOBAL_LIST_EMPTY(cinematics) for(var/C in watching) SEND_SOUND(C, s) -//Fire up special callback for actual effects synchronized with animation (eg real nuke explosion happens midway) +///Fire up special callback for actual effects synchronized with animation (eg real nuke explosion happens midway) /datum/cinematic/proc/special() - if(special_callback) - special_callback.Invoke() + if(!special_callback) + return + special_callback.Invoke() + +///Prepare for the content() proc +/datum/cinematic/proc/pre_content() + content() -//Actual cinematic goes in here +///Actual cinematic goes in here /datum/cinematic/proc/content() sleep(runtime) -/datum/cinematic/nuke_win - id = CINEMATIC_NUKE_WIN +///Cleanup after the content +/datum/cinematic/proc/cleanup_content(ooc_toggled = FALSE) + //Restore OOC + if(ooc_toggled) + GLOB.ooc_allowed = TRUE + qdel(src) + +/datum/cinematic/nuke runtime = 3.5 SECONDS + var/icon_to_flick = "station_explode_fade_red" + var/sound_to_play = 'sound/effects/explosion/far0.ogg' + var/summary_icon_state = "summary_nukewin" -/datum/cinematic/nuke_win/content() +/datum/cinematic/nuke/pre_content() flick("intro_nuke", screen) - sleep(runtime) - flick("station_explode_fade_red", screen) - cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) + addtimer(CALLBACK(src, PROC_REF(content)), runtime) + +/datum/cinematic/nuke/content() + flick(icon_to_flick, screen) + cinematic_sound(sound(sound_to_play, channel = CHANNEL_CINEMATIC)) special() - screen.icon_state = "summary_nukewin" + screen.icon_state = summary_icon_state -/datum/cinematic/nuke_miss - id = CINEMATIC_NUKE_MISS - runtime = 3.5 SECONDS +/datum/cinematic/nuke/win + id = CINEMATIC_NUKE_WIN -/datum/cinematic/nuke_miss/content() - flick("intro_nuke", screen) - sleep(runtime) - cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) - special() - flick("station_intact_fade_red", screen) - screen.icon_state = "summary_nukefail" +/datum/cinematic/nuke/miss + id = CINEMATIC_NUKE_MISS + icon_to_flick = "station_intact_fade_red" + summary_icon_state = "summary_nukefail" -/datum/cinematic/nuke_selfdestruct +/datum/cinematic/nuke/selfdestruct id = CINEMATIC_SELFDESTRUCT - runtime = 3.5 SECONDS + summary_icon_state = "summary_selfdes" -/datum/cinematic/nuke_selfdestruct/content() - flick("intro_nuke", screen) - sleep(runtime) - flick("station_explode_fade_red", screen) - cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) - special() - screen.icon_state = "summary_selfdes" - -/datum/cinematic/nuke_selfdestruct_miss +/datum/cinematic/nuke/selfdestruct_miss id = CINEMATIC_SELFDESTRUCT_MISS - runtime = 3.5 SECONDS -/datum/cinematic/nuke_selfdestruct_miss/content() - flick("intro_nuke", screen) - sleep(runtime) +/datum/cinematic/nuke/selfdestruct_miss/content() cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) special() screen.icon_state = "station_intact" -/datum/cinematic/malf - id = CINEMATIC_MALF - runtime = 7.6 SECONDS - -/datum/cinematic/malf/content() - flick("intro_malf", screen) - sleep(runtime) - flick("station_explode_fade_red", screen) - cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) - special() - screen.icon_state = "summary_malf" - -/datum/cinematic/nuke_annihilation +/datum/cinematic/nuke/annihilation id = CINEMATIC_ANNIHILATION - runtime = 3.5 SECONDS + summary_icon_state = "summary_totala" -/datum/cinematic/nuke_annihilation/content() - flick("intro_nuke", screen) - sleep(runtime) - flick("station_explode_fade_red", screen) - cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) - special() - screen.icon_state = "summary_totala" - -/datum/cinematic/fake +/datum/cinematic/nuke/fake id = CINEMATIC_NUKE_FAKE cleanup_time = 10 SECONDS - runtime = 3.5 SECONDS -/datum/cinematic/fake/content() - flick("intro_nuke", screen) - sleep(runtime) +/datum/cinematic/nuke/fake/content() cinematic_sound(sound('sound/items/bikehorn.ogg', channel = CHANNEL_CINEMATIC)) flick("summary_selfdes", screen) special() -/datum/cinematic/no_core +/datum/cinematic/nuke/no_core id = CINEMATIC_NUKE_NO_CORE cleanup_time = 10 SECONDS - runtime = 3.5 SECONDS -/datum/cinematic/no_core/content() - flick("intro_nuke", screen) - sleep(runtime) +/datum/cinematic/nuke/no_core/content() flick("station_intact", screen) cinematic_sound(sound('sound/ambience/signal.ogg', channel = CHANNEL_CINEMATIC)) @@ -218,16 +187,26 @@ GLOBAL_LIST_EMPTY(cinematics) cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) special() -/datum/cinematic/crash_nuke +/datum/cinematic/nuke/crash id = CINEMATIC_CRASH_NUKE - runtime = 7 SECONDS cleanup_time = 15 SECONDS + icon_to_flick = "planet_nuke" + summary_icon_state = "planet_end" -/datum/cinematic/crash_nuke/content() +/datum/cinematic/nuke/crash/pre_content() screen.icon_state = "planet_start" - flick("intro_nuke", screen) // 3.5 seconds - sleep(5.5 SECONDS) - flick("planet_nuke", screen) // About 1.5 seconds length + return ..() + +/datum/cinematic/malf + id = CINEMATIC_MALF + runtime = 7.6 SECONDS + +/datum/cinematic/malf/pre_content() + flick("intro_malf", screen) + addtimer(CALLBACK(src, PROC_REF(content)), runtime) + +/datum/cinematic/malf/content() + flick("station_explode_fade_red", screen) cinematic_sound(sound('sound/effects/explosion/far0.ogg', channel = CHANNEL_CINEMATIC)) special() - screen.icon_state = "planet_end" + screen.icon_state = "summary_malf" diff --git a/code/datums/gamemodes/infestation.dm b/code/datums/gamemodes/infestation.dm index 1b9ed72787b..f06a82150ac 100644 --- a/code/datums/gamemodes/infestation.dm +++ b/code/datums/gamemodes/infestation.dm @@ -357,7 +357,7 @@ if(M.z == z_level) shake_camera(M, 110, 4) - var/datum/cinematic/crash_nuke/C = /datum/cinematic/crash_nuke + var/datum/cinematic/nuke/crash/C var/nuketime = initial(C.runtime) + initial(C.cleanup_time) addtimer(CALLBACK(src, PROC_REF(do_nuke_z_level), z_level), nuketime * 0.5)