diff --git a/code/__DEFINES/hud.dm b/code/__DEFINES/hud.dm index 8a695c99d5e..e762b406d1e 100644 --- a/code/__DEFINES/hud.dm +++ b/code/__DEFINES/hud.dm @@ -164,6 +164,8 @@ #define ui_ai_multicam "BOTTOM+1:6,LEFT+1" #define ui_ai_add_multicam "BOTTOM+1:6,LEFT" #define ui_ai_take_picture "BOTTOM+2:6,LEFT" +#define ui_ai_floor_indicator "BOTTOM+5,RIGHT" +#define ui_ai_godownup "BOTTOM+5,RIGHT-1" //pAI #define ui_pai_software "SOUTH:6,WEST" diff --git a/code/_onclick/hud/ai.dm b/code/_onclick/hud/ai.dm index 1d26c4916b0..e9650e35d1f 100644 --- a/code/_onclick/hud/ai.dm +++ b/code/_onclick/hud/ai.dm @@ -172,6 +172,66 @@ var/mob/living/silicon/ai/AI = usr AI.drop_new_multicam() +/atom/movable/screen/ai/floor_indicator + icon_state = "zindicator" + screen_loc = ui_ai_floor_indicator + +/atom/movable/screen/ai/floor_indicator/Initialize(mapload, datum/hud/hud_owner) + . = ..() + if(istype(hud_owner)) + RegisterSignal(hud_owner, COMSIG_HUD_OFFSET_CHANGED, PROC_REF(update_z)) + update_z() + +/atom/movable/screen/ai/floor_indicator/proc/update_z(datum/hud/source) + SIGNAL_HANDLER + var/mob/living/silicon/ai/ai = get_mob() //if you use this for anyone else i will find you + if(isnull(ai)) + return + var/turf/locturf = isturf(ai.loc) ? get_turf(ai.eyeobj) : get_turf(ai) //must be a var cuz error + var/ai_z = locturf.z + var/text = "Level
[ai_z]" + if(SSmapping.level_trait(ai_z, ZTRAIT_STATION)) + text = "Floor
[ai_z - 1]" + else if (SSmapping.level_trait(ai_z, ZTRAIT_NOPHASE)) + text = "ERROR" + maptext = MAPTEXT_TINY_UNICODE("
[text]
") + +/atom/movable/screen/ai/go_up + name = "go up" + icon_state = "up" + screen_loc = ui_ai_godownup + +/atom/movable/screen/ai/go_up/Initialize(mapload) + . = ..() + register_context() + +/atom/movable/screen/ai/go_up/add_context(atom/source, list/context, obj/item/held_item, mob/user) + . = ..() + context[SCREENTIP_CONTEXT_LMB] = "Go up a floor" + return CONTEXTUAL_SCREENTIP_SET + +/atom/movable/screen/ai/go_up/Click(location,control,params) + var/mob/ai = get_mob() //the core + flick("uppressed",src) + if(!isturf(ai.loc) || usr != ai) //aicard and stuff + return + ai.up() + +/atom/movable/screen/ai/go_up/down + name = "go down" + icon_state = "down" + +/atom/movable/screen/ai/go_up/down/add_context(atom/source, list/context, obj/item/held_item, mob/user) + . = ..() + context[SCREENTIP_CONTEXT_LMB] = "Go down a floor" + return CONTEXTUAL_SCREENTIP_SET + +/atom/movable/screen/ai/go_up/down/Click(location,control,params) + var/mob/ai = get_mob() //the core + flick("downpressed",src) + if(!isturf(ai.loc) || usr != ai) //aicard and stuff + return + ai.down() /datum/hud/ai ui_style = 'icons/hud/screen_ai.dmi' @@ -187,8 +247,11 @@ static_inventory += using // Z-level floor change - using = new /atom/movable/screen/floor_menu(null, src) - using.screen_loc = ui_ai_floor_menu + using = new /atom/movable/screen/ai/floor_indicator(null, src) //These come with their own predefined screen locs + static_inventory += using + using = new /atom/movable/screen/ai/go_up(null, src) + static_inventory += using + using = new /atom/movable/screen/ai/go_up/down(null, src) static_inventory += using //AI core diff --git a/icons/hud/screen_ai.dmi b/icons/hud/screen_ai.dmi index 8f8d30c6d8b..ea456ca3947 100644 Binary files a/icons/hud/screen_ai.dmi and b/icons/hud/screen_ai.dmi differ