2019-03-15 04:55:52 +00:00
|
|
|
mod chat;
|
|
|
|
|
|
|
|
use crate::{
|
|
|
|
render::Renderer,
|
2019-04-15 06:07:56 +00:00
|
|
|
ui::{self, ScaleMode, ToggleButton, Ui},
|
2019-04-01 20:31:29 +00:00
|
|
|
window::{Event as WinEvent, Key, Window},
|
2019-04-20 18:08:39 +00:00
|
|
|
GlobalState,
|
2019-03-15 04:55:52 +00:00
|
|
|
};
|
2019-04-24 19:55:22 +00:00
|
|
|
use common::{
|
|
|
|
assets,
|
|
|
|
figure::Segment};
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
use conrod_core::{
|
2019-04-10 20:23:49 +00:00
|
|
|
color,
|
2019-03-15 04:55:52 +00:00
|
|
|
image::Id as ImgId,
|
|
|
|
text::font::Id as FontId,
|
2019-04-01 23:26:42 +00:00
|
|
|
widget::{Button, Image, Rectangle, Scrollbar, Text},
|
2019-04-10 20:23:49 +00:00
|
|
|
widget_ids, Color, Colorable, Labelable, Positionable, Sizeable, Widget,
|
2019-03-15 04:55:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
widget_ids! {
|
|
|
|
struct Ids {
|
2019-04-02 04:54:27 +00:00
|
|
|
// Test
|
|
|
|
bag_space_add,
|
2019-04-02 14:25:14 +00:00
|
|
|
inventorytest_button,
|
|
|
|
inventorytest_button_label,
|
2019-04-24 19:55:22 +00:00
|
|
|
//Debug
|
2019-04-22 18:47:22 +00:00
|
|
|
debug_bg,
|
|
|
|
debug_button,
|
|
|
|
debug_button_label,
|
|
|
|
fps_counter,
|
2019-04-17 20:38:52 +00:00
|
|
|
// Logo
|
|
|
|
v_logo,
|
2019-04-02 14:25:14 +00:00
|
|
|
|
2019-04-02 04:54:27 +00:00
|
|
|
// Bag and Inventory
|
2019-03-15 04:55:52 +00:00
|
|
|
bag,
|
|
|
|
bag_contents,
|
|
|
|
bag_close,
|
|
|
|
bag_map_open,
|
2019-04-01 20:31:29 +00:00
|
|
|
inv_alignment,
|
2019-04-25 20:33:14 +00:00
|
|
|
inv_grid_1,
|
|
|
|
inv_grid_2,
|
2019-04-01 23:26:42 +00:00
|
|
|
inv_scrollbar,
|
2019-04-04 13:51:36 +00:00
|
|
|
inv_slot_0,
|
2019-04-02 04:54:27 +00:00
|
|
|
inv_slot[],
|
2019-04-24 19:55:22 +00:00
|
|
|
|
|
|
|
// Buttons
|
|
|
|
settings_button,
|
|
|
|
social_button,
|
|
|
|
map_button,
|
|
|
|
spellbook_button,
|
|
|
|
character_button,
|
|
|
|
qlog_button,
|
|
|
|
social_button_bg,
|
|
|
|
spellbook_button_bg,
|
|
|
|
character_button_bg,
|
|
|
|
qlog_button_bg,
|
|
|
|
bag_text,
|
2019-03-28 02:25:08 +00:00
|
|
|
//help
|
|
|
|
help,
|
|
|
|
help_bg,
|
2019-03-15 04:55:52 +00:00
|
|
|
//ESC-Menu
|
|
|
|
esc_bg,
|
|
|
|
fireplace,
|
|
|
|
menu_button_1,
|
|
|
|
menu_button_2,
|
|
|
|
menu_button_3,
|
|
|
|
menu_button_4,
|
|
|
|
menu_button_5,
|
|
|
|
//Mini-Map
|
|
|
|
mmap_frame,
|
|
|
|
mmap_frame_bg,
|
|
|
|
mmap_location,
|
|
|
|
//Action-Bar
|
|
|
|
xp_bar,
|
|
|
|
l_click,
|
|
|
|
r_click,
|
|
|
|
health_bar,
|
|
|
|
mana_bar,
|
|
|
|
sb_grid_l,
|
|
|
|
sb_grid_r,
|
|
|
|
sb_grid_bg_l,
|
|
|
|
sb_grid_bg_r,
|
2019-04-05 22:36:04 +00:00
|
|
|
xp_bar_progress,
|
|
|
|
health_bar_color,
|
|
|
|
mana_bar_color,
|
2019-04-01 20:31:29 +00:00
|
|
|
// Level Display
|
|
|
|
level_text,
|
|
|
|
next_level_text,
|
2019-03-15 04:55:52 +00:00
|
|
|
//Window Frames
|
|
|
|
window_frame_0,
|
|
|
|
window_frame_1,
|
|
|
|
window_frame_2,
|
|
|
|
window_frame_3,
|
|
|
|
window_frame_4,
|
|
|
|
window_frame_5,
|
|
|
|
//0 Settings-Window
|
|
|
|
settings_bg,
|
|
|
|
settings_icon,
|
|
|
|
settings_button_mo,
|
|
|
|
settings_close,
|
|
|
|
settings_title,
|
2019-03-16 02:03:21 +00:00
|
|
|
//Contents
|
|
|
|
button_help,
|
|
|
|
button_help2,
|
|
|
|
show_help_label,
|
|
|
|
interface,
|
|
|
|
video,
|
|
|
|
sound,
|
|
|
|
gameplay,
|
|
|
|
controls,
|
2019-03-28 02:25:08 +00:00
|
|
|
rectangle,
|
2019-03-15 04:55:52 +00:00
|
|
|
//1 Social
|
|
|
|
social_frame,
|
|
|
|
social_bg,
|
|
|
|
social_icon,
|
|
|
|
social_close,
|
|
|
|
social_title,
|
|
|
|
//2 Map
|
|
|
|
map_frame,
|
|
|
|
map_bg,
|
|
|
|
map_icon,
|
|
|
|
map_close,
|
|
|
|
map_title,
|
2019-04-24 19:55:22 +00:00
|
|
|
map_frame_l,
|
|
|
|
map_frame_r,
|
2019-03-15 04:55:52 +00:00
|
|
|
//3 Spellbook
|
|
|
|
spellbook_frame,
|
|
|
|
spellbook_bg,
|
|
|
|
spellbook_icon,
|
|
|
|
spellbook_close,
|
|
|
|
spellbook_title,
|
|
|
|
//4 Charwindow
|
|
|
|
charwindow_frame,
|
2019-04-05 22:36:04 +00:00
|
|
|
charwindow,
|
2019-03-15 04:55:52 +00:00
|
|
|
charwindow_bg,
|
|
|
|
charwindow_icon,
|
|
|
|
charwindow_close,
|
|
|
|
charwindow_title,
|
2019-04-04 17:35:33 +00:00
|
|
|
charwindow_tab_bg,
|
|
|
|
charwindow_tab1,
|
|
|
|
charwindow_tab1_title,
|
|
|
|
charwindow_tab1_level,
|
|
|
|
charwindow_tab1_exp,
|
|
|
|
charwindow_tab1_stats,
|
2019-04-05 22:36:04 +00:00
|
|
|
charwindow_tab1_statnames,
|
2019-04-04 17:35:33 +00:00
|
|
|
charwindow_tab1_stats_numbers,
|
|
|
|
charwindow_tab1_expbar,
|
2019-04-05 22:36:04 +00:00
|
|
|
charwindow_rectangle,
|
|
|
|
charwindow_exp_rectangle,
|
|
|
|
charwindow_exp_progress_rectangle,
|
2019-03-15 04:55:52 +00:00
|
|
|
//5 Quest-Log
|
|
|
|
questlog_frame,
|
|
|
|
questlog_bg,
|
|
|
|
questlog_icon,
|
|
|
|
questlog_close,
|
|
|
|
questlog_title,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// TODO: make macro to mimic widget_ids! for images ids or find another solution to simplify addition of new images.
|
2019-04-04 14:45:57 +00:00
|
|
|
pub(self) struct Imgs {
|
2019-03-15 04:55:52 +00:00
|
|
|
// Bag
|
|
|
|
bag: ImgId,
|
|
|
|
bag_hover: ImgId,
|
|
|
|
bag_press: ImgId,
|
|
|
|
bag_open: ImgId,
|
|
|
|
bag_open_hover: ImgId,
|
|
|
|
bag_open_press: ImgId,
|
|
|
|
bag_contents: ImgId,
|
2019-04-01 20:31:29 +00:00
|
|
|
inv_grid: ImgId,
|
2019-04-02 04:54:27 +00:00
|
|
|
inv_slot: ImgId,
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
// Buttons
|
|
|
|
settings: ImgId,
|
|
|
|
settings_hover: ImgId,
|
|
|
|
settings_press: ImgId,
|
|
|
|
|
|
|
|
social_button: ImgId,
|
|
|
|
social_hover: ImgId,
|
|
|
|
social_press: ImgId,
|
|
|
|
|
|
|
|
map_button: ImgId,
|
|
|
|
map_hover: ImgId,
|
|
|
|
map_press: ImgId,
|
|
|
|
|
|
|
|
spellbook_button: ImgId,
|
|
|
|
spellbook_hover: ImgId,
|
|
|
|
spellbook_press: ImgId,
|
|
|
|
|
|
|
|
character_button: ImgId,
|
|
|
|
character_hover: ImgId,
|
|
|
|
character_press: ImgId,
|
|
|
|
|
|
|
|
qlog_button: ImgId,
|
|
|
|
qlog_hover: ImgId,
|
|
|
|
qlog_press: ImgId,
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
// Close button
|
|
|
|
close_button: ImgId,
|
|
|
|
close_button_hover: ImgId,
|
|
|
|
close_button_press: ImgId,
|
|
|
|
|
|
|
|
// Menu
|
|
|
|
esc_bg: ImgId,
|
|
|
|
fireplace: ImgId,
|
|
|
|
button_dark: ImgId,
|
|
|
|
button_dark_hover: ImgId,
|
|
|
|
button_dark_press: ImgId,
|
|
|
|
|
|
|
|
// MiniMap
|
|
|
|
mmap_frame: ImgId,
|
|
|
|
mmap_frame_bg: ImgId,
|
|
|
|
|
|
|
|
// SkillBar Module
|
|
|
|
sb_grid: ImgId,
|
|
|
|
sb_grid_bg: ImgId,
|
|
|
|
l_click: ImgId,
|
|
|
|
r_click: ImgId,
|
|
|
|
mana_bar: ImgId,
|
|
|
|
health_bar: ImgId,
|
|
|
|
xp_bar: ImgId,
|
|
|
|
|
|
|
|
//Buff Frame(s)
|
|
|
|
//buff_frame: ImgId,
|
|
|
|
//buff_frame_bg: ImgId,
|
|
|
|
//buff_frame_red: ImgId,
|
|
|
|
//buff_frame_green: ImgId,
|
|
|
|
|
|
|
|
//Missing: Buff Frame Animation
|
|
|
|
window_frame: ImgId,
|
2019-03-28 02:25:08 +00:00
|
|
|
window_frame_2: ImgId,
|
2019-03-15 04:55:52 +00:00
|
|
|
//Settings-Window
|
|
|
|
settings_bg: ImgId,
|
|
|
|
settings_icon: ImgId,
|
|
|
|
settings_button_mo: ImgId,
|
|
|
|
check: ImgId,
|
|
|
|
check_mo: ImgId,
|
|
|
|
check_press: ImgId,
|
|
|
|
check_checked: ImgId,
|
|
|
|
check_checked_mo: ImgId,
|
|
|
|
slider: ImgId,
|
|
|
|
slider_indicator: ImgId,
|
|
|
|
button_blank: ImgId,
|
|
|
|
button_blue_mo: ImgId,
|
|
|
|
button_blue_press: ImgId,
|
2019-04-05 22:36:04 +00:00
|
|
|
window_bg: ImgId,
|
2019-03-30 00:11:10 +00:00
|
|
|
// Social-Window
|
2019-03-15 04:55:52 +00:00
|
|
|
social_bg: ImgId,
|
|
|
|
social_icon: ImgId,
|
2019-03-30 00:11:10 +00:00
|
|
|
// Map-Window
|
2019-03-15 04:55:52 +00:00
|
|
|
map_bg: ImgId,
|
|
|
|
map_icon: ImgId,
|
2019-04-24 19:55:22 +00:00
|
|
|
map_frame_l: ImgId,
|
|
|
|
map_frame_r: ImgId,
|
2019-03-30 00:11:10 +00:00
|
|
|
// Spell Book Window
|
2019-03-15 04:55:52 +00:00
|
|
|
spellbook_bg: ImgId,
|
|
|
|
spellbook_icon: ImgId,
|
2019-03-30 00:11:10 +00:00
|
|
|
// Char Window
|
2019-04-05 22:36:04 +00:00
|
|
|
charwindow: ImgId,
|
2019-03-15 04:55:52 +00:00
|
|
|
charwindow_icon: ImgId,
|
2019-04-04 17:35:33 +00:00
|
|
|
charwindow_tab_bg: ImgId,
|
|
|
|
charwindow_tab: ImgId,
|
|
|
|
charwindow_expbar: ImgId,
|
2019-04-05 22:36:04 +00:00
|
|
|
progress_frame: ImgId,
|
2019-04-04 17:35:33 +00:00
|
|
|
progress: ImgId,
|
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
// Buttons
|
|
|
|
mmap_button: ImgId,
|
|
|
|
mmap_button_hover: ImgId,
|
|
|
|
mmap_button_press: ImgId,
|
|
|
|
mmap_button_open: ImgId,
|
|
|
|
|
2019-03-30 00:11:10 +00:00
|
|
|
// Quest-Log Window
|
2019-03-15 04:55:52 +00:00
|
|
|
questlog_bg: ImgId,
|
|
|
|
questlog_icon: ImgId,
|
2019-03-28 02:25:08 +00:00
|
|
|
//help
|
2019-03-30 00:11:10 +00:00
|
|
|
// Chat-Arrow
|
2019-03-30 02:59:31 +00:00
|
|
|
chat_arrow: ImgId,
|
|
|
|
chat_arrow_mo: ImgId,
|
|
|
|
chat_arrow_press: ImgId,
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
impl Imgs {
|
|
|
|
fn new(ui: &mut Ui, renderer: &mut Renderer) -> Imgs {
|
2019-04-24 19:55:22 +00:00
|
|
|
let mut load_img = |filename, ui: &mut Ui| {
|
2019-04-04 13:49:31 +00:00
|
|
|
let fullpath: String = ["/voxygen/", filename].concat();
|
2019-04-13 01:40:59 +00:00
|
|
|
let image = image::load_from_memory(
|
2019-04-04 13:49:31 +00:00
|
|
|
assets::load(fullpath.as_str())
|
2019-04-24 19:55:22 +00:00
|
|
|
.expect("Error loading Main UI Image")
|
2019-04-04 13:49:31 +00:00
|
|
|
.as_slice(),
|
|
|
|
)
|
|
|
|
.unwrap();
|
2019-04-15 06:07:56 +00:00
|
|
|
ui.new_graphic(ui::Graphic::Image(image))
|
2019-03-15 04:55:52 +00:00
|
|
|
};
|
2019-04-24 19:55:22 +00:00
|
|
|
let mut load_vox = |filename, ui: &mut Ui| {
|
|
|
|
let fullpath: String = ["/voxygen/", filename].concat();
|
|
|
|
let dot_vox = dot_vox::load_bytes(
|
|
|
|
assets::load(fullpath.as_str())
|
|
|
|
.expect("Error loading Main UI .vox")
|
|
|
|
.as_slice(),
|
|
|
|
)
|
|
|
|
.unwrap();
|
|
|
|
ui.new_graphic(ui::Graphic::Voxel(Segment::from(dot_vox)))
|
|
|
|
};
|
|
|
|
Imgs {
|
2019-03-15 04:55:52 +00:00
|
|
|
// Bag
|
2019-04-24 19:55:22 +00:00
|
|
|
bag: load_img("element/buttons/bag/closed.png", ui),
|
|
|
|
bag_hover: load_img("element/buttons/bag/closed_hover.png", ui),
|
|
|
|
bag_press: load_img("element/buttons/bag/closed_press.png", ui),
|
|
|
|
bag_open: load_img("element/buttons/bag/open.png", ui),
|
|
|
|
bag_open_hover: load_img("element/buttons/bag/open_hover.png", ui),
|
|
|
|
bag_open_press: load_img("element/buttons/bag/open_press.png", ui),
|
|
|
|
bag_contents: load_vox("element/frames/bag.vox", ui),
|
|
|
|
inv_grid: load_vox("element/frames/inv_grid.vox", ui),
|
|
|
|
inv_slot: load_vox("element/buttons/inv_slot.vox", ui),
|
|
|
|
|
|
|
|
// Buttons
|
|
|
|
|
|
|
|
settings: load_vox("element/buttons/settings.vox", ui),
|
|
|
|
settings_hover: load_vox("element/buttons/settings_hover.vox", ui),
|
|
|
|
settings_press: load_vox("element/buttons/settings_press.vox", ui),
|
|
|
|
|
|
|
|
social_button: load_vox("element/buttons/social.vox", ui),
|
|
|
|
social_hover: load_vox("element/buttons/social_hover.vox", ui),
|
|
|
|
social_press: load_vox("element/buttons/social_press.vox", ui),
|
|
|
|
|
|
|
|
map_button: load_vox("element/buttons/map.vox", ui),
|
|
|
|
map_hover: load_vox("element/buttons/map_hover.vox", ui),
|
|
|
|
map_press: load_vox("element/buttons/map_press.vox", ui),
|
|
|
|
|
|
|
|
spellbook_button: load_vox("element/buttons/spellbook.vox", ui),
|
|
|
|
spellbook_hover: load_vox("element/buttons/spellbook_hover.vox", ui),
|
|
|
|
spellbook_press: load_vox("element/buttons/spellbook_press.vox", ui),
|
|
|
|
|
|
|
|
character_button: load_vox("element/buttons/character.vox", ui),
|
|
|
|
character_hover: load_vox("element/buttons/character_hover.vox", ui),
|
|
|
|
character_press: load_vox("element/buttons/character_press.vox", ui),
|
|
|
|
|
|
|
|
qlog_button: load_vox("element/buttons/qlog.vox", ui),
|
|
|
|
qlog_hover: load_vox("element/buttons/qlog_hover.vox", ui),
|
|
|
|
qlog_press: load_vox("element/buttons/qlog_press.vox", ui),
|
|
|
|
|
|
|
|
mmap_button: load_img("element/buttons/border.png", ui),
|
|
|
|
mmap_button_hover: load_img("element/buttons/border_mo.png", ui),
|
|
|
|
mmap_button_press: load_img("element/buttons/border_press.png", ui),
|
|
|
|
mmap_button_open: load_img("element/buttons/border_pressed.png", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
|
|
|
// Close button
|
2019-04-24 19:55:22 +00:00
|
|
|
close_button: load_vox("element/buttons/x.vox", ui),
|
|
|
|
close_button_hover: load_vox("element/buttons/x_hover.vox", ui),
|
|
|
|
close_button_press: load_vox("element/buttons/x_press.vox", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
|
|
|
// Esc-Menu
|
2019-04-24 19:55:22 +00:00
|
|
|
esc_bg: load_img("element/frames/menu.png", ui),
|
|
|
|
fireplace: load_vox("element/misc_bg/fireplace.vox", ui),
|
|
|
|
button_dark: load_vox("element/buttons/button_dark.vox", ui),
|
|
|
|
button_dark_hover: load_img("element/buttons/button_dark_hover.png", ui),
|
|
|
|
button_dark_press: load_img("element/buttons/button_dark_press.png", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
|
|
|
// MiniMap
|
2019-04-24 19:55:22 +00:00
|
|
|
mmap_frame: load_vox("element/frames/mmap.vox", ui),
|
|
|
|
mmap_frame_bg: load_img("element/misc_bg/mmap_bg.png", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
|
|
|
|
|
|
|
// Skillbar Module
|
2019-04-24 19:55:22 +00:00
|
|
|
sb_grid: load_img("element/skill_bar/sbar_grid.png", ui),
|
|
|
|
sb_grid_bg: load_img("element/skill_bar/sbar_grid_bg.png", ui),
|
|
|
|
l_click: load_img("element/skill_bar/l.png", ui),
|
|
|
|
r_click: load_img("element/skill_bar/r.png", ui),
|
|
|
|
mana_bar: load_img("element/skill_bar/mana_bar.png", ui),
|
|
|
|
health_bar: load_img("element/skill_bar/health_bar.png", ui),
|
|
|
|
xp_bar: load_img("element/skill_bar/xp_bar.png", ui),
|
|
|
|
|
|
|
|
// Missing: Buff Frame Animation (.gif ?!) (we could do animation in ui.maintain(), or in shader?)
|
|
|
|
window_frame: load_vox("element/frames/window2.vox", ui),
|
|
|
|
window_frame_2: load_img("element/frames/window_2.png", ui),
|
|
|
|
|
|
|
|
// Settings Window
|
|
|
|
settings_bg: load_img("element/frames/settings.png", ui),
|
|
|
|
settings_icon: load_img("element/icons/settings.png", ui),
|
|
|
|
settings_button_mo: load_img("element/buttons/blue_mo.png", ui),
|
|
|
|
check: load_img("element/buttons/check/no.png", ui),
|
|
|
|
check_mo: load_img("element/buttons/check/no_mo.png", ui),
|
|
|
|
check_press: load_img("element/buttons/check/press.png", ui),
|
|
|
|
check_checked: load_img("element/buttons/check/yes.png", ui),
|
|
|
|
check_checked_mo: load_img("element/buttons/check/yes_mo.png", ui),
|
|
|
|
slider: load_img("element/slider/track.png", ui),
|
|
|
|
slider_indicator: load_img("element/slider/indicator.png", ui),
|
|
|
|
button_blank: ui.new_graphic(ui::Graphic::Blank),
|
|
|
|
button_blue_mo: load_img("element/buttons/blue_mo.png", ui),
|
|
|
|
button_blue_press: load_img("element/buttons/blue_press.png", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-05 22:36:04 +00:00
|
|
|
// Window BG
|
2019-04-24 19:55:22 +00:00
|
|
|
window_bg: load_img("element/misc_bg/window_bg.png", ui),
|
2019-04-05 22:36:04 +00:00
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
// Social Window
|
|
|
|
social_bg: load_img("element/misc_bg/small_bg.png", ui),
|
|
|
|
social_icon: load_img("element/icons/social.png", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
// Map Window
|
|
|
|
map_bg: load_img("element/misc_bg/small_bg.png", ui),
|
|
|
|
map_icon: load_img("element/icons/map.png", ui),
|
|
|
|
map_frame_l: load_vox("element/frames/map_l.vox", ui),
|
|
|
|
map_frame_r: load_vox("element/frames/map_r.vox", ui),
|
2019-03-15 04:55:52 +00:00
|
|
|
|
|
|
|
// Spell Book Window
|
2019-04-24 19:55:22 +00:00
|
|
|
spellbook_bg: load_img("element/misc_bg/small_bg.png", ui),
|
|
|
|
spellbook_icon: load_img("element/icons/spellbook.png", ui),
|
|
|
|
|
|
|
|
// Char Window
|
|
|
|
charwindow: load_img("element/misc_bg/charwindow.png", ui),
|
|
|
|
charwindow_icon: load_img("element/icons/charwindow.png", ui),
|
|
|
|
charwindow_tab_bg: load_img("element/frames/tab.png", ui),
|
|
|
|
charwindow_tab: load_img("element/buttons/tab.png", ui),
|
|
|
|
charwindow_expbar: load_img("element/misc_bg/small_bg.png", ui),
|
|
|
|
progress_frame: load_img("element/frames/progress_bar.png", ui),
|
|
|
|
progress: load_img("element/misc_bg/progress.png", ui),
|
|
|
|
|
|
|
|
// Quest-Log Window
|
|
|
|
questlog_bg: load_img("element/misc_bg/small_bg.png", ui),
|
|
|
|
questlog_icon: load_img("element/icons/questlog.png", ui),
|
2019-03-30 00:11:10 +00:00
|
|
|
|
|
|
|
// Chat-Arrows
|
2019-04-24 19:55:22 +00:00
|
|
|
chat_arrow: load_img("element/buttons/arrow/chat_arrow.png", ui),
|
|
|
|
chat_arrow_mo: load_img("element/buttons/arrow/chat_arrow_mo.png", ui),
|
|
|
|
chat_arrow_press: load_img("element/buttons/arrow/chat_arrow_press.png", ui),
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-16 02:03:21 +00:00
|
|
|
enum SettingsTab {
|
|
|
|
Interface,
|
|
|
|
Video,
|
|
|
|
Sound,
|
|
|
|
Gameplay,
|
|
|
|
Controls,
|
|
|
|
}
|
|
|
|
|
|
|
|
pub enum Event {
|
|
|
|
SendMessage(String),
|
|
|
|
Logout,
|
|
|
|
Quit,
|
|
|
|
}
|
|
|
|
|
2019-03-28 04:00:51 +00:00
|
|
|
// TODO: are these the possible layouts we want?
|
|
|
|
// TODO: maybe replace this with bitflags
|
|
|
|
// map not here because it currently is displayed over the top of other open windows
|
|
|
|
enum Windows {
|
2019-04-01 20:31:29 +00:00
|
|
|
Settings, // display settings window
|
2019-03-28 04:00:51 +00:00
|
|
|
CharacterAnd(Option<Small>), // show character window + optionally another
|
|
|
|
Small(Small),
|
|
|
|
None,
|
|
|
|
}
|
|
|
|
#[derive(Clone, Copy)]
|
|
|
|
enum Small {
|
|
|
|
Spellbook,
|
|
|
|
Social,
|
|
|
|
Questlog,
|
|
|
|
}
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
pub struct Hud {
|
|
|
|
ui: Ui,
|
|
|
|
ids: Ids,
|
|
|
|
imgs: Imgs,
|
|
|
|
chat: chat::Chat,
|
|
|
|
font_metamorph: FontId,
|
2019-03-28 02:25:08 +00:00
|
|
|
font_opensans: FontId,
|
2019-03-15 04:55:52 +00:00
|
|
|
show_help: bool,
|
2019-04-22 18:47:22 +00:00
|
|
|
show_debug: bool,
|
2019-03-15 04:55:52 +00:00
|
|
|
bag_open: bool,
|
|
|
|
menu_open: bool,
|
2019-03-28 04:00:51 +00:00
|
|
|
open_windows: Windows,
|
|
|
|
map_open: bool,
|
2019-04-02 01:05:18 +00:00
|
|
|
show_ui: bool,
|
2019-04-04 13:51:36 +00:00
|
|
|
inventory_space: u32,
|
2019-04-05 22:36:04 +00:00
|
|
|
xp_percentage: f64,
|
|
|
|
hp_percentage: f64,
|
|
|
|
mana_percentage: f64,
|
2019-04-02 14:25:14 +00:00
|
|
|
inventorytest_button: bool,
|
2019-04-01 20:31:29 +00:00
|
|
|
settings_tab: SettingsTab,
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-04-06 22:05:56 +00:00
|
|
|
//#[inline]
|
|
|
|
//pub fn rgba_bytes(r: u8, g: u8, b: u8, a: f32) -> Color {
|
2019-04-10 20:23:49 +00:00
|
|
|
//Color::Rgba(r as f32 / 255.0, g as f32 / 255.0, b as f32 / 255.0, a)
|
2019-04-06 22:05:56 +00:00
|
|
|
//}
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
impl Hud {
|
|
|
|
pub fn new(window: &mut Window) -> Self {
|
|
|
|
let mut ui = Ui::new(window).unwrap();
|
|
|
|
// TODO: adjust/remove this, right now it is used to demonstrate window scaling functionality
|
|
|
|
ui.scaling_mode(ScaleMode::RelativeToWindow([1920.0, 1080.0].into()));
|
|
|
|
// Generate ids
|
2019-03-16 02:03:21 +00:00
|
|
|
let ids = Ids::new(ui.id_generator());
|
2019-03-15 04:55:52 +00:00
|
|
|
// Load images
|
|
|
|
let imgs = Imgs::new(&mut ui, window.renderer_mut());
|
|
|
|
// Load fonts
|
2019-04-20 22:02:48 +00:00
|
|
|
let load_font = |filename, ui: &mut Ui| {
|
|
|
|
let fullpath: String = ["/voxygen/font", filename].concat();
|
2019-04-22 18:47:22 +00:00
|
|
|
ui.new_font(
|
|
|
|
conrod_core::text::Font::from_bytes(
|
|
|
|
assets::load(fullpath.as_str()).expect("Error loading file"),
|
|
|
|
)
|
|
|
|
.unwrap(),
|
|
|
|
)
|
2019-04-20 22:02:48 +00:00
|
|
|
};
|
|
|
|
let font_opensans = load_font("/OpenSans-Regular.ttf", &mut ui);
|
|
|
|
let font_metamorph = load_font("/Metamorphous-Regular.ttf", &mut ui);
|
2019-03-15 04:55:52 +00:00
|
|
|
// Chat box
|
|
|
|
let chat = chat::Chat::new(&mut ui);
|
2019-04-20 22:02:48 +00:00
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
Self {
|
|
|
|
ui,
|
|
|
|
imgs,
|
|
|
|
ids,
|
|
|
|
chat,
|
2019-03-16 02:03:21 +00:00
|
|
|
settings_tab: SettingsTab::Interface,
|
2019-04-10 20:23:49 +00:00
|
|
|
show_help: true,
|
2019-04-22 18:47:22 +00:00
|
|
|
show_debug: false,
|
2019-03-15 04:55:52 +00:00
|
|
|
bag_open: false,
|
|
|
|
menu_open: false,
|
2019-03-28 04:00:51 +00:00
|
|
|
map_open: false,
|
2019-04-02 01:05:18 +00:00
|
|
|
show_ui: true,
|
2019-04-02 14:25:14 +00:00
|
|
|
inventorytest_button: false,
|
2019-04-05 22:36:04 +00:00
|
|
|
inventory_space: 0,
|
|
|
|
open_windows: Windows::None,
|
2019-03-15 04:55:52 +00:00
|
|
|
font_metamorph,
|
2019-03-28 02:25:08 +00:00
|
|
|
font_opensans,
|
2019-04-09 16:30:13 +00:00
|
|
|
xp_percentage: 0.4,
|
|
|
|
hp_percentage: 1.0,
|
|
|
|
mana_percentage: 1.0,
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-22 16:16:21 +00:00
|
|
|
fn update_layout(&mut self, tps: f64) -> Vec<Event> {
|
2019-03-16 02:03:21 +00:00
|
|
|
let mut events = Vec::new();
|
2019-03-17 17:52:54 +00:00
|
|
|
let ref mut ui_widgets = self.ui.set_widgets();
|
2019-04-18 13:21:25 +00:00
|
|
|
let version = env!("CARGO_PKG_VERSION");
|
2019-04-02 04:54:27 +00:00
|
|
|
|
2019-04-10 20:23:49 +00:00
|
|
|
const TEXT_COLOR: Color = Color::Rgba(1.0, 1.0, 1.0, 1.0);
|
2019-04-09 16:30:13 +00:00
|
|
|
const HP_COLOR: Color = Color::Rgba(0.33, 0.63, 0.0, 1.0);
|
|
|
|
const MANA_COLOR: Color = Color::Rgba(0.42, 0.41, 0.66, 1.0);
|
|
|
|
const XP_COLOR: Color = Color::Rgba(0.59, 0.41, 0.67, 1.0);
|
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Don't show anything if the ui is toggled off
|
|
|
|
if !self.show_ui {
|
|
|
|
return events;
|
|
|
|
}
|
2019-04-22 18:47:22 +00:00
|
|
|
|
|
|
|
// Display debug window
|
|
|
|
if self.show_debug {
|
|
|
|
Image::new(self.imgs.window_frame_2)
|
|
|
|
.down_from(self.ids.mmap_frame, 20.0)
|
|
|
|
.w_h(300.0, 350.0)
|
|
|
|
.set(self.ids.debug_bg, ui_widgets);
|
|
|
|
Text::new(&format!("FPS: {:.1}", tps))
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.top_left_with_margins_on(self.ids.debug_bg, 20.0, 20.0)
|
|
|
|
.font_id(self.font_opensans)
|
|
|
|
.font_size(18)
|
|
|
|
.set(self.ids.fps_counter, ui_widgets);
|
|
|
|
}
|
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Add Bag-Space Button
|
|
|
|
if self.inventorytest_button {
|
|
|
|
if Button::image(self.imgs.mmap_button)
|
|
|
|
.w_h(100.0, 100.0)
|
|
|
|
.middle_of(ui_widgets.window)
|
|
|
|
.label("1 Up!")
|
|
|
|
.label_font_size(20)
|
|
|
|
.hover_image(self.imgs.mmap_button_hover)
|
|
|
|
.press_image(self.imgs.mmap_button_press)
|
|
|
|
.set(self.ids.bag_space_add, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-15 04:55:52 +00:00
|
|
|
{
|
2019-04-20 15:17:29 +00:00
|
|
|
self.inventory_space = self.inventory_space + 1;
|
|
|
|
};
|
|
|
|
}
|
2019-04-24 20:33:34 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Chat box
|
|
|
|
if let Some(msg) = self
|
|
|
|
.chat
|
|
|
|
.update_layout(ui_widgets, self.font_opensans, &self.imgs)
|
|
|
|
{
|
|
|
|
events.push(Event::SendMessage(msg));
|
|
|
|
}
|
2019-04-24 20:33:34 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Alpha Version
|
|
|
|
Text::new(version)
|
|
|
|
.top_left_with_margins_on(ui_widgets.window, 5.0, 5.0)
|
|
|
|
.font_size(14)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.v_logo, ui_widgets);
|
2019-04-24 20:33:34 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Help Text
|
|
|
|
if self.show_help {
|
|
|
|
Image::new(self.imgs.window_frame_2)
|
|
|
|
.top_left_with_margins_on(ui_widgets.window, 3.0, 3.0)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(300.0, 190.0)
|
2019-04-20 15:17:29 +00:00
|
|
|
.set(self.ids.help_bg, ui_widgets);
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
Text::new(
|
|
|
|
"Tab = Free Cursor \n\
|
|
|
|
Esc = Open/Close Menus \n\
|
|
|
|
\n\
|
|
|
|
F1 = Toggle this Window \n\
|
|
|
|
F2 = Toggle Interface \n\
|
|
|
|
\n\
|
|
|
|
Enter = Open Chat \n\
|
|
|
|
Mouse Wheel = Scroll Chat"
|
|
|
|
)
|
|
|
|
.color(TEXT_COLOR)
|
2019-04-24 19:55:22 +00:00
|
|
|
.top_left_with_margins_on(self.ids.help_bg, 20.0, 20.0)
|
|
|
|
.font_id(self.font_opensans)
|
|
|
|
.font_size(18)
|
|
|
|
.set(self.ids.help, ui_widgets);
|
2019-04-24 20:33:34 +00:00
|
|
|
|
|
|
|
// X-button
|
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(100.0 * 0.2, 100.0 * 0.2)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(self.ids.help_bg, 8.0, 3.0)
|
|
|
|
.set(self.ids.button_help2, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.show_help = false;
|
|
|
|
};
|
2019-04-20 15:17:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Minimap frame and bg
|
2019-04-24 20:33:34 +00:00
|
|
|
Image::new(self.imgs.mmap_frame_bg)
|
|
|
|
.w_h(1750.0 / 8.0, 1650.0 / 8.0)
|
|
|
|
.top_right_with_margins_on(ui_widgets.window, 5.0, 5.0)
|
|
|
|
.set(self.ids.mmap_frame_bg, ui_widgets);
|
|
|
|
|
|
|
|
Image::new(self.imgs.mmap_frame)
|
|
|
|
.w_h(1750.0 / 8.0, 1650.0 / 8.0)
|
|
|
|
.top_right_with_margins_on(ui_widgets.window, 5.0, 5.0)
|
|
|
|
.set(self.ids.mmap_frame, ui_widgets);
|
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Title
|
|
|
|
// Make it display the actual location
|
2019-04-24 20:33:34 +00:00
|
|
|
Text::new("Uncanny Valley")
|
|
|
|
.mid_top_with_margin_on(self.ids.mmap_frame, 5.0)
|
|
|
|
.font_size(14)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.mmap_location, ui_widgets);
|
2019-04-20 15:17:29 +00:00
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
// Buttons at Bag
|
2019-04-20 15:17:29 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 0 Settings
|
|
|
|
if Button::image(self.imgs.settings)
|
|
|
|
.w_h(29.0, 25.0)
|
|
|
|
.bottom_right_with_margins_on(ui_widgets.window, 5.0, 57.0)
|
|
|
|
.hover_image(self.imgs.settings_hover)
|
|
|
|
.press_image(self.imgs.settings_press)
|
|
|
|
.label("N")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_y(conrod_core::position::Relative::Scalar(-7.0))
|
|
|
|
.label_x(conrod_core::position::Relative::Scalar(10.0))
|
|
|
|
.set(self.ids.settings_button, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Settings => Windows::None,
|
|
|
|
_ => Windows::Settings,
|
2019-04-24 19:55:22 +00:00
|
|
|
};
|
2019-04-24 20:33:34 +00:00
|
|
|
self.bag_open = false;
|
|
|
|
};
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 2 Map
|
|
|
|
if Button::image(self.imgs.map_button)
|
|
|
|
.w_h(22.0, 25.0)
|
|
|
|
.left_from(self.ids.social_button, 10.0)
|
|
|
|
.hover_image(self.imgs.map_hover)
|
|
|
|
.press_image(self.imgs.map_press)
|
|
|
|
.label("M")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_y(conrod_core::position::Relative::Scalar(-7.0))
|
|
|
|
.label_x(conrod_core::position::Relative::Scalar(10.0))
|
|
|
|
.set(self.ids.map_button, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.map_open = !self.map_open;
|
|
|
|
self.bag_open = false;
|
|
|
|
};
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Other Windows can only be accessed, when Settings are closed.
|
|
|
|
// Opening Settings will close all other Windows including the Bag.
|
|
|
|
// Opening the Map won't close the windows displayed before.
|
|
|
|
Image::new(self.imgs.social_button)
|
|
|
|
.w_h(25.0, 25.0)
|
|
|
|
.left_from(self.ids.settings_button, 10.0)
|
|
|
|
.set(self.ids.social_button_bg, ui_widgets);
|
|
|
|
Image::new(self.imgs.spellbook_button)
|
|
|
|
.w_h(28.0, 25.0)
|
|
|
|
.left_from(self.ids.map_button, 10.0)
|
|
|
|
.set(self.ids.spellbook_button_bg, ui_widgets);
|
|
|
|
Image::new(self.imgs.character_button)
|
|
|
|
.w_h(27.0, 25.0)
|
|
|
|
.left_from(self.ids.spellbook_button, 10.0)
|
|
|
|
.set(self.ids.character_button_bg, ui_widgets);
|
|
|
|
Image::new(self.imgs.qlog_button)
|
|
|
|
.w_h(23.0, 25.0)
|
|
|
|
.left_from(self.ids.character_button, 10.0)
|
|
|
|
.set(self.ids.qlog_button_bg, ui_widgets);
|
|
|
|
|
|
|
|
if match self.open_windows {
|
|
|
|
Windows::Settings => false,
|
|
|
|
_ => true,
|
|
|
|
} && self.map_open == false {
|
|
|
|
// 1 Social
|
|
|
|
if Button::image(self.imgs.social_button)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(25.0, 25.0)
|
|
|
|
.left_from(self.ids.settings_button, 10.0)
|
|
|
|
.hover_image(self.imgs.social_hover)
|
|
|
|
.press_image(self.imgs.social_press)
|
|
|
|
.label("O")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_y(conrod_core::position::Relative::Scalar(-7.0))
|
|
|
|
.label_x(conrod_core::position::Relative::Scalar(10.0))
|
|
|
|
.set(self.ids.social_button, ui_widgets)
|
2019-04-24 20:33:34 +00:00
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(Small::Social) => Windows::None,
|
|
|
|
Windows::None | Windows::Small(_) => Windows::Small(Small::Social),
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(Small::Social) => Windows::CharacterAnd(None),
|
|
|
|
_ => Windows::CharacterAnd(Some(Small::Social)),
|
|
|
|
},
|
|
|
|
Windows::Settings => Windows::Settings,
|
|
|
|
};
|
|
|
|
}
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 3 Spellbook
|
|
|
|
if Button::image(self.imgs.spellbook_button)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(28.0, 25.0)
|
|
|
|
.left_from(self.ids.map_button, 10.0)
|
|
|
|
.hover_image(self.imgs.spellbook_hover)
|
|
|
|
.press_image(self.imgs.spellbook_press)
|
|
|
|
.label("P")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_y(conrod_core::position::Relative::Scalar(-7.0))
|
|
|
|
.label_x(conrod_core::position::Relative::Scalar(10.0))
|
|
|
|
.set(self.ids.spellbook_button, ui_widgets)
|
2019-04-24 20:33:34 +00:00
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(Small::Spellbook) => Windows::None,
|
|
|
|
Windows::None | Windows::Small(_) => Windows::Small(Small::Spellbook),
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(Small::Spellbook) => Windows::CharacterAnd(None),
|
|
|
|
_ => Windows::CharacterAnd(Some(Small::Spellbook)),
|
|
|
|
},
|
|
|
|
Windows::Settings => Windows::Settings,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
// 4 Char-Window
|
|
|
|
if Button::image(self.imgs.character_button)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(27.0, 25.0)
|
|
|
|
.left_from(self.ids.spellbook_button, 10.0)
|
|
|
|
.hover_image(self.imgs.character_hover)
|
|
|
|
.press_image(self.imgs.character_press)
|
|
|
|
.label("C")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_y(conrod_core::position::Relative::Scalar(-7.0))
|
|
|
|
.label_x(conrod_core::position::Relative::Scalar(10.0))
|
|
|
|
.set(self.ids.character_button, ui_widgets)
|
2019-04-24 20:33:34 +00:00
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(small) => Windows::Small(small),
|
|
|
|
None => Windows::None,
|
|
|
|
},
|
|
|
|
Windows::Small(small) => Windows::CharacterAnd(Some(small)),
|
|
|
|
Windows::None => Windows::CharacterAnd(None),
|
|
|
|
Windows::Settings => Windows::Settings,
|
2019-04-02 04:54:27 +00:00
|
|
|
}
|
2019-03-28 04:00:51 +00:00
|
|
|
}
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 5 Quest-Log
|
|
|
|
if Button::image(self.imgs.qlog_button)
|
|
|
|
.w_h(23.0, 25.0)
|
|
|
|
.left_from(self.ids.character_button, 10.0)
|
|
|
|
.hover_image(self.imgs.qlog_hover)
|
|
|
|
.press_image(self.imgs.qlog_press)
|
|
|
|
.label("L")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_y(conrod_core::position::Relative::Scalar(-7.0))
|
|
|
|
.label_x(conrod_core::position::Relative::Scalar(10.0))
|
|
|
|
.set(self.ids.qlog_button, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(Small::Questlog) => Windows::None,
|
|
|
|
Windows::None | Windows::Small(_) => Windows::Small(Small::Questlog),
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(Small::Questlog) => Windows::CharacterAnd(None),
|
|
|
|
_ => Windows::CharacterAnd(Some(Small::Questlog)),
|
|
|
|
},
|
|
|
|
Windows::Settings => Windows::Settings,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Skillbar Module
|
|
|
|
|
|
|
|
// Experience-Bar
|
|
|
|
Image::new(self.imgs.xp_bar)
|
|
|
|
.w_h(2688.0 / 6.0, 116.0 / 6.0)
|
|
|
|
.mid_bottom_of(ui_widgets.window)
|
|
|
|
.set(self.ids.xp_bar, ui_widgets);
|
|
|
|
|
|
|
|
Rectangle::fill_with([406.0 * (self.xp_percentage), 5.0], XP_COLOR) // "W=406*[Exp. %]"
|
|
|
|
.top_left_with_margins_on(self.ids.xp_bar, 5.0, 21.0)
|
|
|
|
.set(self.ids.xp_bar_progress, ui_widgets);
|
|
|
|
|
|
|
|
// Left Grid
|
|
|
|
Image::new(self.imgs.sb_grid)
|
|
|
|
.w_h(2240.0 / 12.0, 448.0 / 12.0)
|
|
|
|
.up_from(self.ids.xp_bar, 0.0)
|
|
|
|
.align_left_of(self.ids.xp_bar)
|
|
|
|
.set(self.ids.sb_grid_l, ui_widgets);
|
|
|
|
|
|
|
|
Image::new(self.imgs.sb_grid_bg)
|
|
|
|
.w_h(2240.0 / 12.0, 448.0 / 12.0)
|
|
|
|
.middle_of(self.ids.sb_grid_l)
|
|
|
|
.set(self.ids.sb_grid_bg_l, ui_widgets);
|
|
|
|
|
|
|
|
// Right Grid
|
|
|
|
Image::new(self.imgs.sb_grid)
|
|
|
|
.w_h(2240.0 / 12.0, 448.0 / 12.0)
|
|
|
|
.up_from(self.ids.xp_bar, 0.0)
|
|
|
|
.align_right_of(self.ids.xp_bar)
|
|
|
|
.set(self.ids.sb_grid_r, ui_widgets);
|
|
|
|
|
|
|
|
Image::new(self.imgs.sb_grid_bg)
|
|
|
|
.w_h(2240.0 / 12.0, 448.0 / 12.0)
|
|
|
|
.middle_of(self.ids.sb_grid_r)
|
|
|
|
.set(self.ids.sb_grid_bg_r, ui_widgets);
|
|
|
|
|
|
|
|
// Right and Left Click
|
|
|
|
Image::new(self.imgs.l_click)
|
|
|
|
.w_h(224.0 / 6.0, 320.0 / 6.0)
|
|
|
|
.right_from(self.ids.sb_grid_bg_l, 0.0)
|
|
|
|
.align_bottom_of(self.ids.sb_grid_bg_l)
|
|
|
|
.set(self.ids.l_click, ui_widgets);
|
|
|
|
|
|
|
|
Image::new(self.imgs.r_click)
|
|
|
|
.w_h(224.0 / 6.0, 320.0 / 6.0)
|
|
|
|
.left_from(self.ids.sb_grid_bg_r, 0.0)
|
|
|
|
.align_bottom_of(self.ids.sb_grid_bg_r)
|
|
|
|
.set(self.ids.r_click, ui_widgets);
|
|
|
|
|
|
|
|
// Health Bar
|
|
|
|
Image::new(self.imgs.health_bar)
|
|
|
|
.w_h(1120.0 / 6.0, 96.0 / 6.0)
|
|
|
|
.left_from(self.ids.l_click, 0.0)
|
|
|
|
.align_top_of(self.ids.l_click)
|
|
|
|
.set(self.ids.health_bar, ui_widgets);
|
|
|
|
|
|
|
|
// Filling
|
|
|
|
Rectangle::fill_with([182.0 * (self.hp_percentage), 6.0], HP_COLOR) // "W=182.0 * [Health. %]"
|
|
|
|
.top_right_with_margins_on(self.ids.health_bar, 5.0, 0.0)
|
|
|
|
.set(self.ids.health_bar_color, ui_widgets);
|
|
|
|
|
|
|
|
// Mana Bar
|
|
|
|
Image::new(self.imgs.mana_bar)
|
|
|
|
.w_h(1120.0 / 6.0, 96.0 / 6.0)
|
|
|
|
.right_from(self.ids.r_click, 0.0)
|
|
|
|
.align_top_of(self.ids.r_click)
|
|
|
|
.set(self.ids.mana_bar, ui_widgets);
|
|
|
|
|
|
|
|
// Filling
|
|
|
|
Rectangle::fill_with([182.0 * (self.mana_percentage), 6.0], MANA_COLOR) // "W=182.0 * [Mana. %]"
|
|
|
|
.top_left_with_margins_on(self.ids.mana_bar, 5.0, 0.0)
|
|
|
|
.set(self.ids.mana_bar_color, ui_widgets);
|
|
|
|
|
|
|
|
// Buffs/Debuffs
|
|
|
|
|
|
|
|
// Buffs
|
|
|
|
|
|
|
|
// Debuffs
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Level Display
|
2019-04-01 20:31:29 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Insert actual Level here
|
|
|
|
Text::new("1")
|
|
|
|
.left_from(self.ids.xp_bar, -15.0)
|
|
|
|
.font_size(10)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.level_text, ui_widgets);
|
2019-04-05 22:36:04 +00:00
|
|
|
|
2019-04-20 15:17:29 +00:00
|
|
|
// Insert next Level here
|
|
|
|
Text::new("2")
|
|
|
|
.right_from(self.ids.xp_bar, -15.0)
|
|
|
|
.font_size(10)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.next_level_text, ui_widgets);
|
|
|
|
|
|
|
|
// Bag contents
|
2019-04-25 20:33:14 +00:00
|
|
|
if self.bag_open {
|
|
|
|
// Contents
|
|
|
|
Image::new(self.imgs.bag_contents)
|
|
|
|
.w_h(68.0*4.0, 123.0*4.0)
|
|
|
|
.bottom_right_with_margins_on(ui_widgets.window, 90.0, 5.0)
|
|
|
|
.set(self.ids.bag_contents, ui_widgets);
|
|
|
|
|
|
|
|
// Alignment for Grid
|
|
|
|
Rectangle::fill_with([(58.0*4.0)-5.0, 100.0*4.0], color::TRANSPARENT)
|
|
|
|
.top_left_with_margins_on(self.ids.bag_contents, 11.0*4.0, 5.0*4.0)
|
|
|
|
.scroll_kids()
|
|
|
|
.scroll_kids_vertically()
|
|
|
|
.set(self.ids.inv_alignment, ui_widgets);
|
|
|
|
// Grid
|
|
|
|
Image::new(self.imgs.inv_grid)
|
|
|
|
.w_h(58.0*4.0, 111.0*4.0)
|
|
|
|
.mid_top_with_margin_on(self.ids.inv_alignment, 0.0)
|
|
|
|
.set(self.ids.inv_grid_1, ui_widgets);
|
|
|
|
Image::new(self.imgs.inv_grid)
|
|
|
|
.w_h(58.0*4.0, 111.0*4.0)
|
|
|
|
.mid_top_with_margin_on(self.ids.inv_alignment, 110.0*4.0)
|
|
|
|
.set(self.ids.inv_grid_2, ui_widgets);
|
|
|
|
Scrollbar::y_axis(self.ids.inv_alignment)
|
|
|
|
.thickness(5.0)
|
|
|
|
.rgba(0.33, 0.33, 0.33, 1.0)
|
|
|
|
.set(self.ids.inv_scrollbar, ui_widgets);
|
|
|
|
|
|
|
|
// X-button
|
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(4.0*4.0, 4.0*4.0)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(self.ids.bag_contents, 4.5, 4.5)
|
|
|
|
.set(self.ids.bag_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.bag_open = false;
|
|
|
|
}
|
2019-04-20 15:17:29 +00:00
|
|
|
|
2019-04-25 20:33:14 +00:00
|
|
|
if self.inventory_space > 0 {
|
|
|
|
// First Slot
|
|
|
|
Button::image(self.imgs.inv_slot)
|
|
|
|
.top_left_with_margins_on(self.ids.inv_grid_1, 4.0, 4.0)
|
|
|
|
.w_h(10.0*4.0, 10.0*4.0)
|
|
|
|
.set(self.ids.inv_slot_0, ui_widgets);
|
|
|
|
}
|
2019-03-22 03:55:42 +00:00
|
|
|
}
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Bag
|
2019-04-25 08:27:18 +00:00
|
|
|
if !self.map_open && self.show_ui {
|
|
|
|
self.bag_open = ToggleButton::new(self.bag_open, self.imgs.bag, self.imgs.bag_open)
|
|
|
|
.bottom_right_with_margins_on(ui_widgets.window, 5.0, 5.0)
|
|
|
|
.hover_images(self.imgs.bag_hover, self.imgs.bag_open_hover)
|
|
|
|
.press_images(self.imgs.bag_press, self.imgs.bag_open_press)
|
|
|
|
.w_h(420.0 / 10.0, 480.0 / 10.0)
|
|
|
|
.set(self.ids.bag, ui_widgets);
|
2019-04-24 19:55:22 +00:00
|
|
|
Text::new("B")
|
2019-04-25 08:27:18 +00:00
|
|
|
.bottom_right_with_margins_on(self.ids.bag, 0.0, 0.0)
|
|
|
|
.font_size(10)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.bag_text, ui_widgets);
|
|
|
|
} else {
|
|
|
|
Image::new(self.imgs.bag)
|
|
|
|
.bottom_right_with_margins_on(ui_widgets.window, 5.0, 5.0)
|
|
|
|
.w_h(420.0 / 10.0, 480.0 / 10.0)
|
|
|
|
.set(self.ids.bag_map_open, ui_widgets);
|
|
|
|
Text::new("B")
|
|
|
|
.bottom_right_with_margins_on(self.ids.bag, 0.0, 0.0)
|
|
|
|
.font_size(10)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.bag_text, ui_widgets);
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
//Windows
|
|
|
|
|
|
|
|
//Char Window will always appear at the left side. Other Windows either appear at the left side,
|
|
|
|
//or when the Char Window is opened they will appear right from it.
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 0 Settings
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-03-28 04:00:51 +00:00
|
|
|
if let Windows::Settings = self.open_windows {
|
2019-04-24 20:33:34 +00:00
|
|
|
// BG
|
2019-03-15 04:55:52 +00:00
|
|
|
Image::new(self.imgs.settings_bg)
|
|
|
|
.middle_of(ui_widgets.window)
|
|
|
|
.w_h(1648.0 / 2.5, 1952.0 / 2.5)
|
|
|
|
.set(self.ids.settings_bg, ui_widgets);
|
2019-04-24 20:33:34 +00:00
|
|
|
// X-Button
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(244.0 * 0.22 / 2.5, 244.0 * 0.22 / 2.5)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(self.ids.settings_bg, 4.0, 4.0)
|
|
|
|
.set(self.ids.settings_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-03-28 04:00:51 +00:00
|
|
|
self.open_windows = Windows::None;
|
2019-03-16 02:03:21 +00:00
|
|
|
self.settings_tab = SettingsTab::Interface;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-03-16 02:03:21 +00:00
|
|
|
// Title
|
|
|
|
Text::new("Settings")
|
|
|
|
.mid_top_with_margin_on(self.ids.settings_bg, 10.0)
|
|
|
|
.font_size(30)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.settings_title, ui_widgets);
|
2019-03-16 02:03:21 +00:00
|
|
|
// Icon
|
2019-03-15 04:55:52 +00:00
|
|
|
Image::new(self.imgs.settings_icon)
|
|
|
|
.w_h(224.0 / 3.0, 224.0 / 3.0)
|
|
|
|
.top_left_with_margins_on(self.ids.settings_bg, -10.0, -10.0)
|
|
|
|
.set(self.ids.settings_icon, ui_widgets);
|
2019-03-28 02:25:08 +00:00
|
|
|
// TODO: Find out if we can remove this
|
|
|
|
// Alignment Rectangle
|
2019-04-01 20:31:29 +00:00
|
|
|
Rectangle::fill_with([1008.0 / 2.5, 1616.0 / 2.5], color::TRANSPARENT)
|
|
|
|
.top_left_with_margins_on(self.ids.settings_bg, 77.0, 205.0)
|
|
|
|
.set(self.ids.rectangle, ui_widgets);
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 1 Interface////////////////////////////
|
2019-04-01 20:31:29 +00:00
|
|
|
if Button::image(if let SettingsTab::Interface = self.settings_tab {
|
|
|
|
self.imgs.button_blue_mo
|
|
|
|
} else {
|
|
|
|
self.imgs.button_blank
|
|
|
|
})
|
|
|
|
.w_h(304.0 / 2.5, 80.0 / 2.5)
|
|
|
|
.hover_image(self.imgs.button_blue_mo)
|
|
|
|
.press_image(self.imgs.button_blue_press)
|
|
|
|
.top_left_with_margins_on(self.ids.settings_bg, 78.0, 50.0)
|
|
|
|
.label("Interface")
|
|
|
|
.label_font_size(14)
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-01 20:31:29 +00:00
|
|
|
.set(self.ids.interface, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-15 04:55:52 +00:00
|
|
|
{
|
2019-03-16 02:03:21 +00:00
|
|
|
self.settings_tab = SettingsTab::Interface;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
2019-04-24 20:33:34 +00:00
|
|
|
// Toggle Help
|
2019-03-16 02:03:21 +00:00
|
|
|
if let SettingsTab::Interface = self.settings_tab {
|
2019-04-01 20:31:29 +00:00
|
|
|
self.show_help =
|
|
|
|
ToggleButton::new(self.show_help, self.imgs.check, self.imgs.check_checked)
|
|
|
|
.w_h(288.0 / 24.0, 288.0 / 24.0)
|
|
|
|
.top_left_with_margins_on(self.ids.rectangle, 15.0, 15.0)
|
|
|
|
.hover_images(self.imgs.check_checked_mo, self.imgs.check_mo)
|
|
|
|
.press_images(self.imgs.check_press, self.imgs.check_press)
|
|
|
|
.set(self.ids.button_help, ui_widgets);
|
2019-03-16 02:03:21 +00:00
|
|
|
Text::new("Show Help")
|
2019-04-04 13:51:36 +00:00
|
|
|
.right_from(self.ids.button_help, 10.0)
|
2019-03-16 02:03:21 +00:00
|
|
|
.font_size(12)
|
2019-04-04 17:35:33 +00:00
|
|
|
.font_id(self.font_opensans)
|
2019-03-16 02:03:21 +00:00
|
|
|
.graphics_for(self.ids.button_help)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-16 02:03:21 +00:00
|
|
|
.set(self.ids.show_help_label, ui_widgets);
|
2019-04-02 14:25:14 +00:00
|
|
|
|
|
|
|
self.inventorytest_button = ToggleButton::new(
|
|
|
|
self.inventorytest_button,
|
|
|
|
self.imgs.check,
|
|
|
|
self.imgs.check_checked,
|
|
|
|
)
|
2019-04-24 20:33:34 +00:00
|
|
|
.w_h(288.0 / 24.0, 288.0 / 24.0)
|
|
|
|
.top_left_with_margins_on(self.ids.rectangle, 40.0, 15.0)
|
|
|
|
.hover_images(self.imgs.check_checked_mo, self.imgs.check_mo)
|
|
|
|
.press_images(self.imgs.check_press, self.imgs.check_press)
|
|
|
|
.set(self.ids.inventorytest_button, ui_widgets);
|
|
|
|
|
2019-04-02 14:25:14 +00:00
|
|
|
Text::new("Show Inventory Test Button")
|
2019-04-04 13:51:36 +00:00
|
|
|
.right_from(self.ids.inventorytest_button, 10.0)
|
2019-04-02 14:25:14 +00:00
|
|
|
.font_size(12)
|
2019-04-04 17:35:33 +00:00
|
|
|
.font_id(self.font_opensans)
|
2019-04-02 14:25:14 +00:00
|
|
|
.graphics_for(self.ids.inventorytest_button)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-04-02 14:25:14 +00:00
|
|
|
.set(self.ids.inventorytest_button_label, ui_widgets);
|
2019-04-22 18:47:22 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
self.show_debug = ToggleButton::new(
|
|
|
|
self.show_debug,
|
|
|
|
self.imgs.check,
|
|
|
|
self.imgs.check_checked
|
|
|
|
)
|
|
|
|
.w_h(288.0 / 24.0, 288.0 / 24.0)
|
|
|
|
.top_left_with_margins_on(self.ids.rectangle, 65.0, 15.0)
|
|
|
|
.hover_images(self.imgs.check_checked_mo, self.imgs.check_mo)
|
|
|
|
.press_images(self.imgs.check_press, self.imgs.check_press)
|
|
|
|
.set(self.ids.debug_button, ui_widgets);
|
|
|
|
|
2019-04-22 18:47:22 +00:00
|
|
|
Text::new("Show Debug Window")
|
|
|
|
.right_from(self.ids.debug_button, 10.0)
|
|
|
|
.font_size(12)
|
|
|
|
.font_id(self.font_opensans)
|
|
|
|
.graphics_for(self.ids.debug_button)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.debug_button_label, ui_widgets);
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
2019-04-24 20:33:34 +00:00
|
|
|
|
|
|
|
// 2 Gameplay////////////////
|
2019-04-01 20:31:29 +00:00
|
|
|
if Button::image(if let SettingsTab::Gameplay = self.settings_tab {
|
2019-04-24 20:33:34 +00:00
|
|
|
self.imgs.button_blue_mo
|
|
|
|
} else {
|
|
|
|
self.imgs.button_blank
|
|
|
|
}
|
|
|
|
)
|
|
|
|
.w_h(304.0 / 2.5, 80.0 / 2.5)
|
|
|
|
.hover_image(self.imgs.button_blue_mo)
|
|
|
|
.press_image(self.imgs.button_blue_press)
|
|
|
|
.down_from(self.ids.interface, 1.0)
|
|
|
|
.label("Gameplay")
|
|
|
|
.label_font_size(14)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.gameplay, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-15 04:55:52 +00:00
|
|
|
{
|
2019-03-16 02:03:21 +00:00
|
|
|
self.settings_tab = SettingsTab::Gameplay;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 3 Controls/////////////////////
|
2019-04-01 20:31:29 +00:00
|
|
|
if Button::image(if let SettingsTab::Controls = self.settings_tab {
|
2019-04-24 20:33:34 +00:00
|
|
|
self.imgs.button_blue_mo
|
|
|
|
} else {
|
|
|
|
self.imgs.button_blank
|
|
|
|
}
|
|
|
|
)
|
|
|
|
.w_h(304.0 / 2.5, 80.0 / 2.5)
|
|
|
|
.hover_image(self.imgs.button_blue_mo)
|
|
|
|
.press_image(self.imgs.button_blue_press)
|
|
|
|
.down_from(self.ids.gameplay, 1.0)
|
|
|
|
.label("Controls")
|
|
|
|
.label_font_size(14)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.controls, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-15 04:55:52 +00:00
|
|
|
{
|
2019-03-16 02:03:21 +00:00
|
|
|
self.settings_tab = SettingsTab::Controls;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 4 Video////////////////////////////////
|
2019-04-01 20:31:29 +00:00
|
|
|
if Button::image(if let SettingsTab::Video = self.settings_tab {
|
2019-04-24 20:33:34 +00:00
|
|
|
self.imgs.button_blue_mo
|
|
|
|
} else {
|
|
|
|
self.imgs.button_blank
|
|
|
|
}
|
|
|
|
)
|
|
|
|
.w_h(304.0 / 2.5, 80.0 / 2.5)
|
|
|
|
.hover_image(self.imgs.button_blue_mo)
|
|
|
|
.press_image(self.imgs.button_blue_press)
|
|
|
|
.down_from(self.ids.controls, 1.0)
|
|
|
|
.label("Video")
|
|
|
|
.label_font_size(14)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.video, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-15 04:55:52 +00:00
|
|
|
{
|
2019-03-16 02:03:21 +00:00
|
|
|
self.settings_tab = SettingsTab::Video;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 5 Sound///////////////////////////////
|
2019-04-01 20:31:29 +00:00
|
|
|
if Button::image(if let SettingsTab::Sound = self.settings_tab {
|
2019-04-24 20:33:34 +00:00
|
|
|
self.imgs.button_blue_mo
|
|
|
|
} else {
|
|
|
|
self.imgs.button_blank
|
|
|
|
}
|
|
|
|
)
|
|
|
|
.w_h(304.0 / 2.5, 80.0 / 2.5)
|
|
|
|
.hover_image(self.imgs.button_blue_mo)
|
|
|
|
.press_image(self.imgs.button_blue_press)
|
|
|
|
.down_from(self.ids.video, 1.0)
|
|
|
|
.label("Sound")
|
|
|
|
.label_font_size(14)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.sound, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-15 04:55:52 +00:00
|
|
|
{
|
2019-03-16 02:03:21 +00:00
|
|
|
self.settings_tab = SettingsTab::Sound;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
}
|
2019-04-24 20:33:34 +00:00
|
|
|
|
2019-03-28 04:00:51 +00:00
|
|
|
if let Some((small, char_window_open)) = match self.open_windows {
|
|
|
|
Windows::Small(small) => Some((small, false)),
|
|
|
|
Windows::CharacterAnd(Some(small)) => Some((small, true)),
|
|
|
|
_ => None,
|
|
|
|
} {
|
|
|
|
// TODO: there is common code in each match arm, might be able to combine this
|
|
|
|
match small {
|
|
|
|
Small::Social => {
|
|
|
|
//Frame
|
|
|
|
if char_window_open {
|
|
|
|
Image::new(self.imgs.window_frame)
|
|
|
|
.right_from(self.ids.charwindow_frame, 20.0)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(107.0*4.0, 125.0*4.0)
|
2019-03-28 04:00:51 +00:00
|
|
|
.set(self.ids.social_frame, ui_widgets);
|
|
|
|
} else {
|
|
|
|
Image::new(self.imgs.window_frame)
|
2019-04-24 19:55:22 +00:00
|
|
|
.top_left_with_margins_on(ui_widgets.window, 200.0, 10.0)
|
2019-03-28 04:00:51 +00:00
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.social_frame, ui_widgets);
|
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Icon
|
2019-03-28 04:00:51 +00:00
|
|
|
Image::new(self.imgs.social_icon)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(40.0, 40.0)
|
|
|
|
.top_left_with_margins_on(self.ids.social_frame, 4.0, 4.0)
|
2019-03-28 04:00:51 +00:00
|
|
|
.set(self.ids.social_icon, ui_widgets);
|
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
// Content alignment
|
|
|
|
Rectangle::fill_with([362.0, 418.0], color::TRANSPARENT)
|
|
|
|
.bottom_right_with_margins_on(self.ids.social_frame, 17.0, 17.0)
|
|
|
|
.scroll_kids()
|
|
|
|
.scroll_kids_vertically()
|
|
|
|
.set(self.ids.social_bg, ui_widgets);
|
|
|
|
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// X-Button
|
2019-03-28 04:00:51 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(20.0, 20.0)
|
2019-03-28 04:00:51 +00:00
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
2019-04-24 19:55:22 +00:00
|
|
|
.top_right_with_margins_on(self.ids.social_frame, 17.0, 5.0)
|
2019-03-28 04:00:51 +00:00
|
|
|
.set(self.ids.social_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(_) => Windows::None,
|
|
|
|
Windows::CharacterAnd(_) => Windows::CharacterAnd(None),
|
2019-04-05 22:36:04 +00:00
|
|
|
_ => Windows::Settings,
|
2019-03-28 04:00:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// Title
|
|
|
|
Text::new("Social")
|
2019-04-24 19:55:22 +00:00
|
|
|
.mid_top_with_margin_on(self.ids.social_frame, 16.0)
|
|
|
|
.font_id(self.font_metamorph)
|
|
|
|
.font_size(14)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-28 04:00:51 +00:00
|
|
|
.set(self.ids.social_title, ui_widgets);
|
|
|
|
}
|
|
|
|
Small::Spellbook => {
|
2019-04-24 20:33:34 +00:00
|
|
|
// Frame
|
2019-03-28 04:00:51 +00:00
|
|
|
if char_window_open {
|
|
|
|
Image::new(self.imgs.window_frame)
|
|
|
|
.right_from(self.ids.charwindow_frame, 20.0)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.spellbook_frame, ui_widgets);
|
|
|
|
} else {
|
|
|
|
Image::new(self.imgs.window_frame)
|
|
|
|
.top_left_with_margins_on(ui_widgets.window, 200.0, 90.0)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.spellbook_frame, ui_widgets);
|
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// BG
|
2019-03-28 04:00:51 +00:00
|
|
|
Image::new(self.imgs.spellbook_bg)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.middle_of(self.ids.spellbook_frame)
|
|
|
|
.set(self.ids.spellbook_bg, ui_widgets);
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Icon
|
2019-03-28 04:00:51 +00:00
|
|
|
Image::new(self.imgs.spellbook_icon)
|
|
|
|
.w_h(224.0 / 3.0, 224.0 / 3.0)
|
|
|
|
.top_left_with_margins_on(self.ids.spellbook_frame, -10.0, -10.0)
|
|
|
|
.set(self.ids.spellbook_icon, ui_widgets);
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// X-Button
|
2019-03-28 04:00:51 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(244.0 * 0.22 / 4.0, 244.0 * 0.22 / 4.0)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(self.ids.spellbook_frame, 4.0, 4.0)
|
|
|
|
.set(self.ids.spellbook_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(_) => Windows::None,
|
|
|
|
Windows::CharacterAnd(_) => Windows::CharacterAnd(None),
|
2019-04-05 22:36:04 +00:00
|
|
|
_ => Windows::Settings,
|
2019-03-28 04:00:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// Title
|
|
|
|
Text::new("Spellbook")
|
|
|
|
.mid_top_with_margin_on(self.ids.spellbook_frame, 7.0)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-28 04:00:51 +00:00
|
|
|
.set(self.ids.spellbook_title, ui_widgets);
|
|
|
|
}
|
|
|
|
Small::Questlog => {
|
2019-04-24 20:33:34 +00:00
|
|
|
// Frame
|
2019-03-28 04:00:51 +00:00
|
|
|
if char_window_open {
|
|
|
|
Image::new(self.imgs.window_frame)
|
|
|
|
.right_from(self.ids.charwindow_frame, 20.0)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.questlog_frame, ui_widgets);
|
|
|
|
} else {
|
|
|
|
Image::new(self.imgs.window_frame)
|
|
|
|
.top_left_with_margins_on(ui_widgets.window, 200.0, 90.0)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.questlog_frame, ui_widgets);
|
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// BG
|
2019-03-28 04:00:51 +00:00
|
|
|
Image::new(self.imgs.questlog_bg)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.middle_of(self.ids.questlog_frame)
|
|
|
|
.set(self.ids.questlog_bg, ui_widgets);
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Icon
|
2019-03-28 04:00:51 +00:00
|
|
|
Image::new(self.imgs.questlog_icon)
|
|
|
|
.w_h(224.0 / 3.0, 224.0 / 3.0)
|
|
|
|
.top_left_with_margins_on(self.ids.questlog_frame, -10.0, -10.0)
|
|
|
|
.set(self.ids.questlog_icon, ui_widgets);
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// X-Button
|
2019-03-28 04:00:51 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(244.0 * 0.22 / 4.0, 244.0 * 0.22 / 4.0)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(self.ids.questlog_frame, 4.0, 4.0)
|
|
|
|
.set(self.ids.questlog_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(_) => Windows::None,
|
|
|
|
Windows::CharacterAnd(_) => Windows::CharacterAnd(None),
|
2019-04-05 22:36:04 +00:00
|
|
|
_ => Windows::Settings,
|
2019-03-28 04:00:51 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
// Title
|
|
|
|
Text::new("Quest-Log")
|
|
|
|
.mid_top_with_margin_on(self.ids.questlog_frame, 7.0)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-28 04:00:51 +00:00
|
|
|
.set(self.ids.questlog_title, ui_widgets);
|
|
|
|
}
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-05 22:36:04 +00:00
|
|
|
// 4 Char-Window
|
2019-03-28 04:00:51 +00:00
|
|
|
if let Windows::CharacterAnd(small) = self.open_windows {
|
2019-04-05 22:36:04 +00:00
|
|
|
// Frame
|
2019-03-15 04:55:52 +00:00
|
|
|
Image::new(self.imgs.window_frame)
|
2019-04-04 17:35:33 +00:00
|
|
|
.top_left_with_margins_on(ui_widgets.window, 200.0, 215.0)
|
2019-03-15 04:55:52 +00:00
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.charwindow_frame, ui_widgets);
|
|
|
|
|
2019-04-05 22:36:04 +00:00
|
|
|
// BG
|
|
|
|
Image::new(self.imgs.window_bg)
|
2019-04-04 17:35:33 +00:00
|
|
|
.w_h(348.0, 404.0)
|
|
|
|
.mid_top_with_margin_on(self.ids.charwindow_frame, 48.0)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.charwindow_bg, ui_widgets);
|
|
|
|
|
2019-04-05 22:36:04 +00:00
|
|
|
// Overlay
|
|
|
|
Image::new(self.imgs.charwindow)
|
|
|
|
.middle_of(self.ids.charwindow_bg)
|
|
|
|
.set(self.ids.charwindow, ui_widgets);
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Icon
|
2019-04-04 17:35:33 +00:00
|
|
|
//Image::new(self.imgs.charwindow_icon)
|
2019-04-05 22:36:04 +00:00
|
|
|
//.w_h(224.0 / 3.0, 224.0 / 3.0)
|
|
|
|
//.top_left_with_margins_on(self.ids.charwindow_frame, -10.0, -10.0)
|
|
|
|
//.set(self.ids.charwindow_icon, ui_widgets);
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-05 22:36:04 +00:00
|
|
|
// X-Button
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(244.0 * 0.22 / 4.0, 244.0 * 0.22 / 4.0)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(self.ids.charwindow_frame, 4.0, 4.0)
|
|
|
|
.set(self.ids.charwindow_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-03-28 04:00:51 +00:00
|
|
|
self.open_windows = match small {
|
|
|
|
Some(small) => Windows::Small(small),
|
|
|
|
None => Windows::None,
|
|
|
|
}
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
2019-04-05 22:36:04 +00:00
|
|
|
|
2019-03-16 02:03:21 +00:00
|
|
|
// Title
|
|
|
|
Text::new("Character Name") //Add in actual Character Name
|
|
|
|
.mid_top_with_margin_on(self.ids.charwindow_frame, 7.0)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.charwindow_title, ui_widgets);
|
2019-04-04 17:35:33 +00:00
|
|
|
// Tab BG
|
|
|
|
Image::new(self.imgs.charwindow_tab_bg)
|
|
|
|
.w_h(205.0, 412.0)
|
|
|
|
.mid_left_with_margin_on(self.ids.charwindow_frame, -205.0)
|
|
|
|
.set(self.ids.charwindow_tab_bg, ui_widgets);
|
2019-04-05 22:36:04 +00:00
|
|
|
// Tab Rectangle
|
|
|
|
Rectangle::fill_with([192.0, 371.0], color::rgba(0.0, 0.0, 0.0, 0.8))
|
|
|
|
.top_right_with_margins_on(self.ids.charwindow_tab_bg, 20.0, 0.0)
|
|
|
|
.set(self.ids.charwindow_rectangle, ui_widgets);
|
2019-04-04 17:35:33 +00:00
|
|
|
// Tab Button
|
|
|
|
Button::image(self.imgs.charwindow_tab)
|
|
|
|
.w_h(65.0, 23.0)
|
|
|
|
.top_left_with_margins_on(self.ids.charwindow_tab_bg, -18.0, 2.0)
|
|
|
|
.label("Stats")
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-04 17:35:33 +00:00
|
|
|
.label_font_id(self.font_opensans)
|
|
|
|
.label_font_size(14)
|
|
|
|
.set(self.ids.charwindow_tab1, ui_widgets);
|
2019-04-05 22:36:04 +00:00
|
|
|
Text::new("1") //Add in actual Character Level
|
|
|
|
.mid_top_with_margin_on(self.ids.charwindow_rectangle, 10.0)
|
2019-04-04 17:35:33 +00:00
|
|
|
.font_id(self.font_opensans)
|
|
|
|
.font_size(30)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-04-04 17:35:33 +00:00
|
|
|
.set(self.ids.charwindow_tab1_level, ui_widgets);
|
2019-04-05 22:36:04 +00:00
|
|
|
// Exp-Bar Background
|
|
|
|
Rectangle::fill_with([170.0, 10.0], color::BLACK)
|
|
|
|
.mid_top_with_margin_on(self.ids.charwindow_rectangle, 50.0)
|
|
|
|
.set(self.ids.charwindow_exp_rectangle, ui_widgets);
|
|
|
|
// Exp-Bar Progress
|
2019-04-09 16:30:13 +00:00
|
|
|
Rectangle::fill_with([170.0 * (self.xp_percentage), 6.0], XP_COLOR) // 0.8 = Experience percantage
|
2019-04-05 22:36:04 +00:00
|
|
|
.mid_left_with_margin_on(self.ids.charwindow_tab1_expbar, 1.0)
|
|
|
|
.set(self.ids.charwindow_exp_progress_rectangle, ui_widgets);
|
|
|
|
// Exp-Bar Foreground Frame
|
|
|
|
Image::new(self.imgs.progress_frame)
|
|
|
|
.w_h(170.0, 10.0)
|
|
|
|
.middle_of(self.ids.charwindow_exp_rectangle)
|
|
|
|
.set(self.ids.charwindow_tab1_expbar, ui_widgets);
|
|
|
|
// Exp-Text
|
|
|
|
Text::new("120/170") // Shows the Exp / Exp to reach the next level
|
|
|
|
.mid_top_with_margin_on(self.ids.charwindow_tab1_expbar, 10.0)
|
2019-04-04 17:35:33 +00:00
|
|
|
.font_id(self.font_opensans)
|
2019-04-05 22:36:04 +00:00
|
|
|
.font_size(15)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-04-05 22:36:04 +00:00
|
|
|
.set(self.ids.charwindow_tab1_exp, ui_widgets);
|
2019-04-04 17:35:33 +00:00
|
|
|
|
2019-04-05 22:36:04 +00:00
|
|
|
// Stats
|
|
|
|
Text::new(
|
|
|
|
"Stamina\n\
|
|
|
|
\n\
|
|
|
|
Strength\n\
|
|
|
|
\n\
|
|
|
|
Dexterity\n\
|
|
|
|
\n\
|
|
|
|
Intelligence",
|
|
|
|
)
|
2019-04-24 20:33:34 +00:00
|
|
|
.top_left_with_margins_on(self.ids.charwindow_rectangle, 100.0, 20.0)
|
|
|
|
.font_id(self.font_opensans)
|
|
|
|
.font_size(16)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.charwindow_tab1_statnames, ui_widgets);
|
2019-04-05 22:36:04 +00:00
|
|
|
|
|
|
|
Text::new(
|
|
|
|
"1234\n\
|
|
|
|
\n\
|
|
|
|
12312\n\
|
|
|
|
\n\
|
|
|
|
12414\n\
|
|
|
|
\n\
|
|
|
|
124124",
|
|
|
|
)
|
2019-04-24 20:33:34 +00:00
|
|
|
.right_from(self.ids.charwindow_tab1_statnames, 10.0)
|
|
|
|
.font_id(self.font_opensans)
|
|
|
|
.font_size(16)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.charwindow_tab1_stats, ui_widgets);
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// 2 Map
|
|
|
|
if self.map_open {
|
|
|
|
// BG
|
2019-03-15 04:55:52 +00:00
|
|
|
Image::new(self.imgs.map_bg)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(824.0, 488.0)
|
|
|
|
.middle_of(ui_widgets.window)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.map_bg, ui_widgets);
|
2019-04-24 20:33:34 +00:00
|
|
|
// Frame
|
2019-04-24 19:55:22 +00:00
|
|
|
Image::new(self.imgs.map_frame_l)
|
|
|
|
.top_left_with_margins_on(self.ids.map_bg, 0.0, 0.0)
|
|
|
|
.w_h(412.0, 488.0)
|
|
|
|
.set(self.ids.map_frame_l, ui_widgets);
|
|
|
|
Image::new(self.imgs.map_frame_r)
|
|
|
|
.top_right_with_margins_on(self.ids.map_bg, 0.0, 0.0)
|
|
|
|
.w_h(1648.0 / 4.0, 1952.0 / 4.0)
|
|
|
|
.set(self.ids.map_frame_r, ui_widgets);
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// Icon
|
2019-03-15 04:55:52 +00:00
|
|
|
Image::new(self.imgs.map_icon)
|
|
|
|
.w_h(224.0 / 3.0, 224.0 / 3.0)
|
|
|
|
.top_left_with_margins_on(self.ids.map_frame, -10.0, -10.0)
|
|
|
|
.set(self.ids.map_icon, ui_widgets);
|
|
|
|
|
2019-04-24 20:33:34 +00:00
|
|
|
// X-Button
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
2019-04-24 19:55:22 +00:00
|
|
|
.w_h(4.0*2.0, 4.0*2.0)
|
2019-03-15 04:55:52 +00:00
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
2019-04-24 19:55:22 +00:00
|
|
|
.top_right_with_margins_on(self.ids.map_frame_r, 1.0, 1.0)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.map_close, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-03-28 04:00:51 +00:00
|
|
|
self.map_open = false;
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
2019-03-16 02:03:21 +00:00
|
|
|
// Title
|
|
|
|
Text::new("Map")
|
2019-04-24 19:55:22 +00:00
|
|
|
.mid_top_with_margin_on(self.ids.map_bg, -7.0)
|
2019-03-16 02:03:21 +00:00
|
|
|
.font_size(50)
|
2019-04-09 16:30:13 +00:00
|
|
|
.color(TEXT_COLOR)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.map_title, ui_widgets);
|
|
|
|
}
|
|
|
|
|
2019-04-24 19:55:22 +00:00
|
|
|
|
2019-03-28 04:00:51 +00:00
|
|
|
// ESC-MENU
|
2019-03-16 02:03:21 +00:00
|
|
|
// Background
|
2019-03-15 04:55:52 +00:00
|
|
|
if self.menu_open {
|
|
|
|
Image::new(self.imgs.esc_bg)
|
|
|
|
.w_h(228.0, 450.0)
|
|
|
|
.middle_of(ui_widgets.window)
|
|
|
|
.set(self.ids.esc_bg, ui_widgets);
|
|
|
|
|
|
|
|
Image::new(self.imgs.fireplace)
|
|
|
|
.w_h(180.0, 60.0)
|
|
|
|
.mid_top_with_margin_on(self.ids.esc_bg, 50.0)
|
|
|
|
.set(self.ids.fireplace, ui_widgets);
|
|
|
|
|
2019-03-16 02:03:21 +00:00
|
|
|
// Settings
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.button_dark)
|
|
|
|
.mid_top_with_margin_on(self.ids.esc_bg, 115.0)
|
|
|
|
.w_h(170.0, 50.0)
|
|
|
|
.hover_image(self.imgs.button_dark_hover)
|
|
|
|
.press_image(self.imgs.button_dark_press)
|
2019-03-16 02:03:21 +00:00
|
|
|
.label("Settings")
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_y(conrod_core::position::Relative::Scalar(2.0))
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_font_size(17)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.menu_button_1, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.menu_open = false;
|
2019-03-28 04:00:51 +00:00
|
|
|
self.open_windows = Windows::Settings;
|
2019-03-15 04:55:52 +00:00
|
|
|
};
|
2019-03-16 02:03:21 +00:00
|
|
|
// Controls
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.button_dark)
|
|
|
|
.mid_top_with_margin_on(self.ids.esc_bg, 175.0)
|
|
|
|
.w_h(170.0, 50.0)
|
|
|
|
.hover_image(self.imgs.button_dark_hover)
|
|
|
|
.press_image(self.imgs.button_dark_press)
|
2019-03-16 02:03:21 +00:00
|
|
|
.label("Controls")
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_y(conrod_core::position::Relative::Scalar(2.0))
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_font_size(17)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.menu_button_2, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
//self.menu_open = false;
|
|
|
|
};
|
2019-03-16 02:03:21 +00:00
|
|
|
// Servers
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.button_dark)
|
|
|
|
.mid_top_with_margin_on(self.ids.esc_bg, 235.0)
|
|
|
|
.w_h(170.0, 50.0)
|
|
|
|
.hover_image(self.imgs.button_dark_hover)
|
|
|
|
.press_image(self.imgs.button_dark_press)
|
2019-03-16 02:03:21 +00:00
|
|
|
.label("Servers")
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_y(conrod_core::position::Relative::Scalar(2.0))
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_font_size(17)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.menu_button_3, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
//self.menu_open = false;
|
|
|
|
};
|
2019-03-16 02:03:21 +00:00
|
|
|
// Logout
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.button_dark)
|
|
|
|
.mid_top_with_margin_on(self.ids.esc_bg, 295.0)
|
|
|
|
.w_h(170.0, 50.0)
|
|
|
|
.hover_image(self.imgs.button_dark_hover)
|
|
|
|
.press_image(self.imgs.button_dark_press)
|
2019-03-16 02:03:21 +00:00
|
|
|
.label("Logout")
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_y(conrod_core::position::Relative::Scalar(2.0))
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_font_size(17)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.menu_button_4, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-03-16 02:03:21 +00:00
|
|
|
{
|
|
|
|
events.push(Event::Logout);
|
|
|
|
};
|
|
|
|
// Quit
|
2019-03-15 04:55:52 +00:00
|
|
|
if Button::image(self.imgs.button_dark)
|
|
|
|
.mid_top_with_margin_on(self.ids.esc_bg, 355.0)
|
|
|
|
.w_h(170.0, 50.0)
|
|
|
|
.hover_image(self.imgs.button_dark_hover)
|
|
|
|
.press_image(self.imgs.button_dark_press)
|
2019-03-16 02:03:21 +00:00
|
|
|
.label("Quit")
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_y(conrod_core::position::Relative::Scalar(2.0))
|
2019-04-09 16:30:13 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-04-06 22:05:56 +00:00
|
|
|
.label_font_size(17)
|
2019-03-15 04:55:52 +00:00
|
|
|
.set(self.ids.menu_button_5, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-03-16 02:03:21 +00:00
|
|
|
events.push(Event::Quit);
|
2019-03-15 04:55:52 +00:00
|
|
|
};
|
|
|
|
}
|
2019-04-02 04:54:27 +00:00
|
|
|
|
2019-03-16 02:03:21 +00:00
|
|
|
events
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-03-17 05:26:51 +00:00
|
|
|
pub fn new_message(&mut self, msg: String) {
|
|
|
|
self.chat.new_message(msg);
|
|
|
|
}
|
|
|
|
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_menu(&mut self) {
|
2019-03-15 04:55:52 +00:00
|
|
|
self.menu_open = !self.menu_open;
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_bag(&mut self) {
|
2019-04-02 01:05:18 +00:00
|
|
|
self.bag_open = !self.bag_open
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_map(&mut self) {
|
|
|
|
self.map_open = !self.map_open;
|
|
|
|
self.bag_open = false;
|
|
|
|
}
|
|
|
|
fn toggle_questlog(&mut self) {
|
2019-04-02 04:54:27 +00:00
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(Small::Questlog) => Windows::None,
|
|
|
|
Windows::None | Windows::Small(_) => Windows::Small(Small::Questlog),
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(Small::Questlog) => Windows::CharacterAnd(None),
|
|
|
|
_ => Windows::CharacterAnd(Some(Small::Questlog)),
|
|
|
|
},
|
2019-04-05 22:36:04 +00:00
|
|
|
Windows::Settings => Windows::Settings,
|
2019-04-02 04:54:27 +00:00
|
|
|
};
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_charwindow(&mut self) {
|
2019-04-02 04:54:27 +00:00
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(small) => Windows::Small(small),
|
|
|
|
None => Windows::None,
|
|
|
|
},
|
|
|
|
Windows::Small(small) => Windows::CharacterAnd(Some(small)),
|
|
|
|
Windows::None => Windows::CharacterAnd(None),
|
2019-04-05 22:36:04 +00:00
|
|
|
Windows::Settings => Windows::Settings,
|
2019-04-02 04:54:27 +00:00
|
|
|
}
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_social(&mut self) {
|
2019-04-02 04:54:27 +00:00
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(Small::Social) => Windows::None,
|
|
|
|
Windows::None | Windows::Small(_) => Windows::Small(Small::Social),
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(Small::Social) => Windows::CharacterAnd(None),
|
|
|
|
_ => Windows::CharacterAnd(Some(Small::Social)),
|
|
|
|
},
|
2019-04-05 22:36:04 +00:00
|
|
|
Windows::Settings => Windows::Settings,
|
2019-04-02 04:54:27 +00:00
|
|
|
};
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_spellbook(&mut self) {
|
2019-04-02 04:54:27 +00:00
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Small(Small::Spellbook) => Windows::None,
|
|
|
|
Windows::None | Windows::Small(_) => Windows::Small(Small::Spellbook),
|
|
|
|
Windows::CharacterAnd(small) => match small {
|
|
|
|
Some(Small::Spellbook) => Windows::CharacterAnd(None),
|
|
|
|
_ => Windows::CharacterAnd(Some(Small::Spellbook)),
|
|
|
|
},
|
2019-04-05 22:36:04 +00:00
|
|
|
Windows::Settings => Windows::Settings,
|
2019-04-02 04:54:27 +00:00
|
|
|
};
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_settings(&mut self) {
|
2019-04-02 04:54:27 +00:00
|
|
|
self.open_windows = match self.open_windows {
|
|
|
|
Windows::Settings => Windows::None,
|
|
|
|
_ => Windows::Settings,
|
|
|
|
};
|
|
|
|
self.bag_open = false;
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_help(&mut self) {
|
2019-04-02 01:05:18 +00:00
|
|
|
self.show_help = !self.show_help
|
|
|
|
}
|
2019-04-20 18:08:39 +00:00
|
|
|
fn toggle_ui(&mut self) {
|
2019-04-02 01:05:18 +00:00
|
|
|
self.show_ui = !self.show_ui;
|
|
|
|
}
|
2019-03-15 04:55:52 +00:00
|
|
|
|
2019-04-22 18:23:40 +00:00
|
|
|
fn toggle_windows(&mut self, global_state: &mut GlobalState) {
|
2019-04-20 18:08:39 +00:00
|
|
|
if self.bag_open
|
|
|
|
|| self.menu_open
|
|
|
|
|| self.map_open
|
|
|
|
|| match self.open_windows {
|
|
|
|
Windows::None => false,
|
|
|
|
_ => true,
|
|
|
|
}
|
|
|
|
{
|
|
|
|
self.bag_open = false;
|
|
|
|
self.menu_open = false;
|
|
|
|
self.map_open = false;
|
|
|
|
self.open_windows = Windows::None;
|
2019-04-22 18:23:40 +00:00
|
|
|
global_state.window.grab_cursor(true);
|
2019-04-20 18:08:39 +00:00
|
|
|
} else {
|
|
|
|
self.menu_open = true;
|
2019-04-22 18:23:40 +00:00
|
|
|
global_state.window.grab_cursor(false);
|
2019-04-20 18:08:39 +00:00
|
|
|
}
|
2019-03-22 03:55:42 +00:00
|
|
|
}
|
|
|
|
|
2019-04-15 00:45:54 +00:00
|
|
|
fn typing(&self) -> bool {
|
|
|
|
match self.ui.widget_capturing_keyboard() {
|
|
|
|
Some(id) if id == self.chat.input_box_id() => true,
|
|
|
|
_ => false,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-04-20 18:08:39 +00:00
|
|
|
pub fn handle_event(&mut self, event: WinEvent, global_state: &mut GlobalState) -> bool {
|
|
|
|
let cursor_grabbed = global_state.window.is_cursor_grabbed();
|
2019-03-22 03:55:42 +00:00
|
|
|
match event {
|
|
|
|
WinEvent::Ui(event) => {
|
2019-04-20 15:17:29 +00:00
|
|
|
if (self.typing() && event.is_keyboard() && self.show_ui)
|
2019-04-20 18:08:39 +00:00
|
|
|
|| !(cursor_grabbed && event.is_keyboard_or_mouse())
|
2019-04-01 20:31:29 +00:00
|
|
|
{
|
2019-03-22 03:55:42 +00:00
|
|
|
self.ui.handle_event(event);
|
|
|
|
}
|
|
|
|
true
|
2019-04-01 20:31:29 +00:00
|
|
|
}
|
2019-04-20 15:17:29 +00:00
|
|
|
WinEvent::KeyDown(Key::ToggleInterface) => {
|
|
|
|
self.toggle_ui();
|
|
|
|
true
|
|
|
|
}
|
|
|
|
_ if !self.show_ui => false,
|
2019-04-20 18:08:39 +00:00
|
|
|
WinEvent::Zoom(_) => !cursor_grabbed && !self.ui.no_widget_capturing_mouse(),
|
2019-03-30 02:15:27 +00:00
|
|
|
WinEvent::KeyDown(Key::Enter) => {
|
2019-04-15 00:45:54 +00:00
|
|
|
self.ui.focus_widget(if self.typing() {
|
|
|
|
None
|
2019-04-09 16:30:13 +00:00
|
|
|
} else {
|
2019-04-15 00:45:54 +00:00
|
|
|
Some(self.chat.input_box_id())
|
|
|
|
});
|
2019-03-30 02:15:27 +00:00
|
|
|
true
|
|
|
|
}
|
2019-04-09 16:30:13 +00:00
|
|
|
WinEvent::KeyDown(Key::Escape) => {
|
2019-04-15 00:45:54 +00:00
|
|
|
if self.typing() {
|
2019-03-30 02:15:27 +00:00
|
|
|
self.ui.focus_widget(None);
|
|
|
|
} else {
|
2019-04-09 16:30:13 +00:00
|
|
|
// Close windows on esc
|
2019-04-22 18:23:40 +00:00
|
|
|
self.toggle_windows(global_state);
|
2019-03-30 02:15:27 +00:00
|
|
|
}
|
2019-04-09 16:30:13 +00:00
|
|
|
true
|
2019-04-02 04:54:27 +00:00
|
|
|
}
|
2019-04-15 00:45:54 +00:00
|
|
|
WinEvent::KeyDown(key) if !self.typing() => match key {
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::Map => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_map();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::Bag => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_bag();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::QuestLog => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_questlog();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::CharacterWindow => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_charwindow();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::Social => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_social();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::Spellbook => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_spellbook();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::Settings => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_settings();
|
|
|
|
true
|
|
|
|
}
|
2019-04-10 20:23:49 +00:00
|
|
|
Key::Help => {
|
2019-04-09 16:30:13 +00:00
|
|
|
self.toggle_help();
|
|
|
|
true
|
|
|
|
}
|
|
|
|
_ => false,
|
|
|
|
},
|
2019-03-22 03:55:42 +00:00
|
|
|
WinEvent::KeyDown(key) | WinEvent::KeyUp(key) => match key {
|
|
|
|
Key::ToggleCursor => false,
|
2019-04-15 00:45:54 +00:00
|
|
|
_ => self.typing(),
|
2019-03-22 03:55:42 +00:00
|
|
|
},
|
2019-04-15 00:45:54 +00:00
|
|
|
WinEvent::Char(_) => self.typing(),
|
2019-03-22 03:55:42 +00:00
|
|
|
_ => false,
|
|
|
|
}
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
2019-04-22 16:16:21 +00:00
|
|
|
pub fn maintain(&mut self, renderer: &mut Renderer, tps: f64) -> Vec<Event> {
|
|
|
|
let events = self.update_layout(tps);
|
2019-03-15 04:55:52 +00:00
|
|
|
self.ui.maintain(renderer);
|
2019-03-16 02:03:21 +00:00
|
|
|
events
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn render(&self, renderer: &mut Renderer) {
|
|
|
|
self.ui.render(renderer);
|
|
|
|
}
|
|
|
|
}
|