mirror of
https://github.com/Bubberstation/Bubberstation.git
synced 2025-12-28 02:21:53 +00:00
* Adds an extra malf AI ability: Remote emagging. Also tidies up emag code and coverts a lot of things to balloon alerts * Update communications.dm * Modular override * Some modular adjustments, removes 'emagged' vars in favor of obj_flags * whoops, mobs don't have obj_flags. --------- Co-authored-by: nikothedude <59709059+nikothedude@users.noreply.github.com> Co-authored-by: Giz <vinylspiders@gmail.com>
102 lines
3.9 KiB
Plaintext
102 lines
3.9 KiB
Plaintext
#define BALLOON_TEXT_WIDTH 200
|
|
#define BALLOON_TEXT_SPAWN_TIME (0.2 SECONDS)
|
|
#define BALLOON_TEXT_FADE_TIME (0.1 SECONDS)
|
|
#define BALLOON_TEXT_FULLY_VISIBLE_TIME (0.7 SECONDS)
|
|
#define BALLOON_TEXT_TOTAL_LIFETIME(mult) (BALLOON_TEXT_SPAWN_TIME + BALLOON_TEXT_FULLY_VISIBLE_TIME*mult + BALLOON_TEXT_FADE_TIME)
|
|
/// The increase in duration per character in seconds
|
|
#define BALLOON_TEXT_CHAR_LIFETIME_INCREASE_MULT (0.05)
|
|
/// The amount of characters needed before this increase takes into effect
|
|
#define BALLOON_TEXT_CHAR_LIFETIME_INCREASE_MIN 10
|
|
|
|
/**
|
|
* Creates text that will float from the atom upwards to the viewer.
|
|
*
|
|
* Args:
|
|
* * mob/viewer: The mob the text will be shown to. Nullable (But only in the form of it won't runtime).
|
|
* * text: The text to be shown to viewer. Must not be null.
|
|
*/
|
|
/atom/proc/balloon_alert(mob/viewer, text)
|
|
SHOULD_NOT_SLEEP(TRUE)
|
|
|
|
INVOKE_ASYNC(src, PROC_REF(balloon_alert_perform), viewer, text)
|
|
|
|
/// Create balloon alerts (text that floats up) to everything within range.
|
|
/// Will only display to people who can see.
|
|
/atom/proc/balloon_alert_to_viewers(message, self_message, vision_distance = DEFAULT_MESSAGE_RANGE, list/ignored_mobs)
|
|
SHOULD_NOT_SLEEP(TRUE)
|
|
|
|
var/list/hearers = get_hearers_in_view(vision_distance, src)
|
|
hearers -= ignored_mobs
|
|
|
|
for (var/mob/hearer in hearers)
|
|
if (hearer.is_blind())
|
|
continue
|
|
|
|
balloon_alert(hearer, (hearer == src && self_message) || message)
|
|
|
|
// Do not use.
|
|
// MeasureText blocks. I have no idea for how long.
|
|
// I would've made the maptext_height update on its own, but I don't know
|
|
// if this would look bad on laggy clients.
|
|
/atom/proc/balloon_alert_perform(mob/viewer, text)
|
|
|
|
var/client/viewer_client = viewer?.client
|
|
if (isnull(viewer_client))
|
|
return
|
|
|
|
var/bound_width = world.icon_size
|
|
if (ismovable(src))
|
|
var/atom/movable/movable_source = src
|
|
bound_width = movable_source.bound_width
|
|
|
|
var/image/balloon_alert = image(loc = isturf(src) ? src : get_atom_on_turf(src), layer = ABOVE_MOB_LAYER)
|
|
SET_PLANE_EXPLICIT(balloon_alert, BALLOON_CHAT_PLANE, src)
|
|
balloon_alert.alpha = 0
|
|
balloon_alert.appearance_flags = RESET_ALPHA|RESET_COLOR|RESET_TRANSFORM
|
|
balloon_alert.maptext = MAPTEXT("<span style='text-align: center; -dm-text-outline: 1px #0005'>[text]</span>")
|
|
balloon_alert.maptext_x = (BALLOON_TEXT_WIDTH - bound_width) * -0.5
|
|
WXH_TO_HEIGHT(viewer_client?.MeasureText(text, null, BALLOON_TEXT_WIDTH), balloon_alert.maptext_height)
|
|
balloon_alert.maptext_width = BALLOON_TEXT_WIDTH
|
|
|
|
viewer_client?.images += balloon_alert
|
|
|
|
var/length_mult = 1 + max(0, length(strip_html_full(text)) - BALLOON_TEXT_CHAR_LIFETIME_INCREASE_MIN) * BALLOON_TEXT_CHAR_LIFETIME_INCREASE_MULT
|
|
|
|
animate(
|
|
balloon_alert,
|
|
pixel_y = world.icon_size * 1.2,
|
|
time = BALLOON_TEXT_TOTAL_LIFETIME(length_mult),
|
|
easing = SINE_EASING | EASE_OUT,
|
|
)
|
|
|
|
animate(
|
|
alpha = 255,
|
|
time = BALLOON_TEXT_SPAWN_TIME,
|
|
easing = CUBIC_EASING | EASE_OUT,
|
|
flags = ANIMATION_PARALLEL,
|
|
)
|
|
|
|
animate(
|
|
alpha = 0,
|
|
time = BALLOON_TEXT_FULLY_VISIBLE_TIME * length_mult,
|
|
easing = CUBIC_EASING | EASE_IN,
|
|
)
|
|
|
|
LAZYADD(update_on_z, balloon_alert)
|
|
// These two timers are not the same
|
|
// One manages the relation to the atom that spawned us, the other to the client we're displaying to
|
|
// We could lose our loc, and still need to talk to our client, so they are done seperately
|
|
addtimer(CALLBACK(balloon_alert.loc, PROC_REF(forget_balloon_alert), balloon_alert), BALLOON_TEXT_TOTAL_LIFETIME(length_mult))
|
|
addtimer(CALLBACK(GLOBAL_PROC, GLOBAL_PROC_REF(remove_image_from_client), balloon_alert, viewer_client), BALLOON_TEXT_TOTAL_LIFETIME(length_mult))
|
|
|
|
/atom/proc/forget_balloon_alert(image/balloon_alert)
|
|
LAZYREMOVE(update_on_z, balloon_alert)
|
|
|
|
#undef BALLOON_TEXT_CHAR_LIFETIME_INCREASE_MIN
|
|
#undef BALLOON_TEXT_CHAR_LIFETIME_INCREASE_MULT
|
|
#undef BALLOON_TEXT_FADE_TIME
|
|
#undef BALLOON_TEXT_FULLY_VISIBLE_TIME
|
|
#undef BALLOON_TEXT_SPAWN_TIME
|
|
#undef BALLOON_TEXT_TOTAL_LIFETIME
|
|
#undef BALLOON_TEXT_WIDTH
|