2019-03-15 04:55:52 +00:00
|
|
|
use crate::{
|
|
|
|
render::Renderer,
|
2019-05-11 14:59:48 +00:00
|
|
|
ui::{
|
|
|
|
self,
|
2019-07-27 19:26:31 +00:00
|
|
|
img_ids::{BlankGraphic, ImageGraphic, VoxelGraphic},
|
2019-07-29 14:06:13 +00:00
|
|
|
Tooltip, Tooltipable, Ui,
|
2019-05-11 14:59:48 +00:00
|
|
|
},
|
2019-06-06 14:48:41 +00:00
|
|
|
GlobalState,
|
2019-04-19 18:14:00 +00:00
|
|
|
};
|
2019-03-04 07:28:16 +00:00
|
|
|
use conrod_core::{
|
2019-04-17 17:41:22 +00:00
|
|
|
color,
|
2019-03-15 04:55:52 +00:00
|
|
|
color::TRANSPARENT,
|
2019-04-28 02:12:30 +00:00
|
|
|
position::Relative,
|
2019-06-06 14:48:41 +00:00
|
|
|
widget::{text_box::Event as TextBoxEvent, Button, Image, List, Rectangle, Text, TextBox},
|
2019-04-04 13:49:31 +00:00
|
|
|
widget_ids, Borderable, Color, Colorable, Labelable, Positionable, Sizeable, Widget,
|
2019-03-04 07:28:16 +00:00
|
|
|
};
|
|
|
|
|
2019-03-15 04:55:52 +00:00
|
|
|
widget_ids! {
|
2019-03-04 07:28:16 +00:00
|
|
|
struct Ids {
|
|
|
|
// Background and logo
|
|
|
|
bg,
|
|
|
|
v_logo,
|
2019-03-15 04:55:52 +00:00
|
|
|
alpha_version,
|
2019-05-23 22:45:48 +00:00
|
|
|
// Disclaimer
|
|
|
|
disc_window,
|
|
|
|
disc_text_1,
|
|
|
|
disc_text_2,
|
|
|
|
disc_button,
|
|
|
|
disc_scrollbar,
|
2019-03-15 04:55:52 +00:00
|
|
|
// Login, Singleplayer
|
2019-03-04 07:28:16 +00:00
|
|
|
login_button,
|
|
|
|
login_text,
|
2019-04-17 20:38:52 +00:00
|
|
|
login_error,
|
|
|
|
login_error_bg,
|
2019-03-04 07:28:16 +00:00
|
|
|
address_text,
|
|
|
|
address_bg,
|
|
|
|
address_field,
|
|
|
|
username_text,
|
|
|
|
username_bg,
|
|
|
|
username_field,
|
2019-03-15 04:55:52 +00:00
|
|
|
singleplayer_button,
|
|
|
|
singleplayer_text,
|
2019-05-03 11:02:03 +00:00
|
|
|
usrnm_bg,
|
|
|
|
srvr_bg,
|
2019-05-17 09:22:32 +00:00
|
|
|
// Server list
|
2019-03-04 07:28:16 +00:00
|
|
|
servers_button,
|
2019-04-19 11:14:05 +00:00
|
|
|
servers_frame,
|
|
|
|
servers_text,
|
|
|
|
servers_close,
|
|
|
|
// Buttons
|
2019-03-04 07:28:16 +00:00
|
|
|
settings_button,
|
|
|
|
quit_button,
|
2019-04-15 20:51:32 +00:00
|
|
|
// Error
|
|
|
|
error_frame,
|
2019-04-17 17:41:22 +00:00
|
|
|
button_ok,
|
2019-04-24 19:55:22 +00:00
|
|
|
version,
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-08 18:19:57 +00:00
|
|
|
image_ids! {
|
|
|
|
struct Imgs {
|
|
|
|
<VoxelGraphic>
|
2019-08-06 06:31:48 +00:00
|
|
|
v_logo: "voxygen.element.v_logo",
|
|
|
|
input_bg: "voxygen.element.misc_bg.textbox",
|
|
|
|
button: "voxygen.element.buttons.button",
|
|
|
|
button_hover: "voxygen.element.buttons.button_hover",
|
|
|
|
button_press: "voxygen.element.buttons.button_press",
|
|
|
|
disclaimer: "voxygen.element.frames.disclaimer",
|
2019-03-04 07:28:16 +00:00
|
|
|
|
2019-05-08 18:19:57 +00:00
|
|
|
<ImageGraphic>
|
2019-08-06 06:31:48 +00:00
|
|
|
bg: "voxygen.background.bg_main",
|
|
|
|
error_frame: "voxygen.element.frames.window_2",
|
2019-07-27 19:26:31 +00:00
|
|
|
|
|
|
|
<BlankGraphic>
|
|
|
|
nothing: (),
|
2019-05-08 18:19:57 +00:00
|
|
|
}
|
2019-06-22 14:30:53 +00:00
|
|
|
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
|
2019-05-08 18:19:57 +00:00
|
|
|
font_ids! {
|
|
|
|
pub struct Fonts {
|
2019-08-06 06:31:48 +00:00
|
|
|
opensans: "voxygen.font.OpenSans-Regular",
|
|
|
|
metamorph: "voxygen.font.Metamorphous-Regular",
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-03-17 17:52:54 +00:00
|
|
|
pub enum Event {
|
|
|
|
LoginAttempt {
|
|
|
|
username: String,
|
|
|
|
server_address: String,
|
|
|
|
},
|
2019-04-18 13:53:03 +00:00
|
|
|
StartSingleplayer,
|
2019-03-17 17:52:54 +00:00
|
|
|
Quit,
|
2019-06-10 20:44:03 +00:00
|
|
|
Settings,
|
2019-05-26 20:42:45 +00:00
|
|
|
DisclaimerClosed,
|
2019-03-17 17:52:54 +00:00
|
|
|
}
|
|
|
|
|
2019-03-04 07:28:16 +00:00
|
|
|
pub struct MainMenuUi {
|
|
|
|
ui: Ui,
|
|
|
|
ids: Ids,
|
|
|
|
imgs: Imgs,
|
2019-05-08 18:19:57 +00:00
|
|
|
fonts: Fonts,
|
2019-03-15 04:55:52 +00:00
|
|
|
username: String,
|
2019-03-04 07:28:16 +00:00
|
|
|
server_address: String,
|
2019-04-04 14:45:57 +00:00
|
|
|
login_error: Option<String>,
|
2019-04-14 23:28:29 +00:00
|
|
|
connecting: Option<std::time::Instant>,
|
2019-04-19 11:14:05 +00:00
|
|
|
show_servers: bool,
|
2019-05-23 22:45:48 +00:00
|
|
|
show_disclaimer: bool,
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
impl MainMenuUi {
|
2019-04-18 17:40:29 +00:00
|
|
|
pub fn new(global_state: &mut GlobalState) -> Self {
|
2019-05-07 03:25:25 +00:00
|
|
|
let window = &mut global_state.window;
|
2019-04-18 17:40:29 +00:00
|
|
|
let networking = &global_state.settings.networking;
|
2019-07-26 02:28:53 +00:00
|
|
|
let gameplay = &global_state.settings.gameplay;
|
|
|
|
|
2019-03-04 07:28:16 +00:00
|
|
|
let mut ui = Ui::new(window).unwrap();
|
2019-07-26 02:28:53 +00:00
|
|
|
ui.set_scaling_mode(gameplay.ui_scale);
|
2019-03-04 07:28:16 +00:00
|
|
|
// Generate ids
|
|
|
|
let ids = Ids::new(ui.id_generator());
|
|
|
|
// Load images
|
2019-05-08 18:19:57 +00:00
|
|
|
let imgs = Imgs::load(&mut ui).expect("Failed to load images");
|
2019-03-15 04:55:52 +00:00
|
|
|
// Load fonts
|
2019-05-08 18:19:57 +00:00
|
|
|
let fonts = Fonts::load(&mut ui).expect("Failed to load fonts");
|
2019-04-20 22:02:48 +00:00
|
|
|
|
2019-03-04 07:28:16 +00:00
|
|
|
Self {
|
|
|
|
ui,
|
|
|
|
ids,
|
2019-05-08 18:19:57 +00:00
|
|
|
imgs,
|
|
|
|
fonts,
|
2019-04-18 17:40:29 +00:00
|
|
|
username: networking.username.clone(),
|
2019-04-25 08:45:01 +00:00
|
|
|
server_address: networking.servers[networking.default_server].clone(),
|
2019-04-04 14:45:57 +00:00
|
|
|
login_error: None,
|
2019-04-14 23:28:29 +00:00
|
|
|
connecting: None,
|
2019-04-19 11:14:05 +00:00
|
|
|
show_servers: false,
|
2019-05-26 20:42:45 +00:00
|
|
|
show_disclaimer: global_state.settings.show_disclaimer,
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-26 20:42:45 +00:00
|
|
|
fn update_layout(&mut self, global_state: &mut GlobalState) -> Vec<Event> {
|
2019-03-17 17:52:54 +00:00
|
|
|
let mut events = Vec::new();
|
2019-07-29 14:06:13 +00:00
|
|
|
let (ref mut ui_widgets, ref mut tooltip_manager) = self.ui.set_widgets();
|
2019-04-18 13:21:25 +00:00
|
|
|
let version = env!("CARGO_PKG_VERSION");
|
2019-05-23 22:45:48 +00:00
|
|
|
const TEXT_COLOR: Color = Color::Rgba(1.0, 1.0, 1.0, 1.0);
|
2019-06-22 14:30:53 +00:00
|
|
|
const TEXT_COLOR_2: Color = Color::Rgba(1.0, 1.0, 1.0, 0.2);
|
2019-03-15 04:55:52 +00:00
|
|
|
// Background image, Veloren logo, Alpha-Version Label
|
|
|
|
Image::new(self.imgs.bg)
|
|
|
|
.middle_of(ui_widgets.window)
|
|
|
|
.set(self.ids.bg, ui_widgets);
|
2019-04-24 19:55:22 +00:00
|
|
|
Image::new(self.imgs.v_logo)
|
2019-04-29 20:37:19 +00:00
|
|
|
.w_h(123.0 * 3.0, 35.0 * 3.0)
|
2019-08-01 17:53:34 +00:00
|
|
|
.top_right_with_margins(30.0, 30.0)
|
2019-03-04 07:28:16 +00:00
|
|
|
.set(self.ids.v_logo, ui_widgets);
|
2019-04-24 19:55:22 +00:00
|
|
|
Text::new(version)
|
2019-08-01 17:53:34 +00:00
|
|
|
.top_right_with_margins_on(ui_widgets.window, 5.0, 5.0)
|
2019-04-27 20:55:30 +00:00
|
|
|
.font_size(14)
|
2019-05-18 19:03:13 +00:00
|
|
|
.font_id(self.fonts.opensans)
|
2019-04-27 20:55:30 +00:00
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.version, ui_widgets);
|
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
if self.show_disclaimer {
|
|
|
|
Image::new(self.imgs.disclaimer)
|
|
|
|
.w_h(1800.0, 800.0)
|
|
|
|
.middle_of(ui_widgets.window)
|
|
|
|
.scroll_kids()
|
|
|
|
.scroll_kids_vertically()
|
|
|
|
.set(self.ids.disc_window, ui_widgets);
|
2019-04-18 13:53:03 +00:00
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
Text::new("Disclaimer")
|
|
|
|
.top_left_with_margins_on(self.ids.disc_window, 30.0, 40.0)
|
|
|
|
.font_id(self.fonts.metamorph)
|
|
|
|
.font_size(35)
|
|
|
|
.font_id(self.fonts.metamorph)
|
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.disc_text_1, ui_widgets);
|
|
|
|
Text::new(
|
|
|
|
"Welcome to the alpha version of Veloren!\n\
|
|
|
|
\n\
|
|
|
|
\n\
|
|
|
|
Before you dive into the fun, please keep a few things in mind:\n\
|
|
|
|
\n\
|
|
|
|
- This is a very early alpha. Expect bugs, extremely unfinished gameplay, unpolished mechanics, and missing features. \n\
|
|
|
|
If you are a reviewer, please DO NOT review this version.\n\
|
|
|
|
\n\
|
|
|
|
- If you have constructive feedback or bug reports, you can contact us via Reddit, GitLab, or our community Discord server.\n\
|
|
|
|
\n\
|
|
|
|
- Veloren is licensed under the GPL 3 open-source licence. That means you're free to play, modify, and redistribute the game however you wish \n\
|
|
|
|
(provided derived work is also under GPL 3).
|
|
|
|
\n\
|
|
|
|
- Veloren is a non-profit community project, and everybody working on it is a volunteer.\n\
|
|
|
|
If you like what you see, you're welcome to join the development or art teams!
|
|
|
|
\n\
|
|
|
|
- 'Voxel RPG' is a genre in its own right. First-person shooters used to be called Doom clones.\n\
|
|
|
|
Like them, we're trying to build a niche. This game is not a clone, and its development will diverge from existing games in the future.\n\
|
|
|
|
\n\
|
|
|
|
Thanks for taking the time to read this notice, we hope you enjoy the game!\n\
|
|
|
|
\n\
|
|
|
|
~ The Veloren Devs")
|
|
|
|
.top_left_with_margins_on(self.ids.disc_window, 110.0, 40.0)
|
|
|
|
.font_id(self.fonts.metamorph)
|
|
|
|
.font_size(26)
|
2019-05-08 18:19:57 +00:00
|
|
|
.font_id(self.fonts.opensans)
|
2019-05-23 22:45:48 +00:00
|
|
|
.color(TEXT_COLOR)
|
|
|
|
.set(self.ids.disc_text_2, ui_widgets);
|
2019-05-03 11:02:03 +00:00
|
|
|
if Button::image(self.imgs.button)
|
2019-05-23 22:45:48 +00:00
|
|
|
.w_h(300.0, 50.0)
|
|
|
|
.mid_bottom_with_margin_on(self.ids.disc_window, 30.0)
|
2019-05-03 11:02:03 +00:00
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
2019-04-17 20:38:52 +00:00
|
|
|
.label_y(Relative::Scalar(2.0))
|
2019-05-23 22:45:48 +00:00
|
|
|
.label("Accept")
|
|
|
|
.label_font_size(18)
|
2019-04-17 17:41:22 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-05-23 22:45:48 +00:00
|
|
|
.set(self.ids.disc_button, ui_widgets)
|
2019-04-17 17:41:22 +00:00
|
|
|
.was_clicked()
|
2019-04-17 20:38:52 +00:00
|
|
|
{
|
2019-05-26 20:42:45 +00:00
|
|
|
self.show_disclaimer = false;
|
|
|
|
events.push(Event::DisclaimerClosed);
|
|
|
|
}
|
2019-05-23 22:45:48 +00:00
|
|
|
} else {
|
|
|
|
// TODO: Don't use macros for this?
|
|
|
|
// Input fields
|
|
|
|
// Used when the login button is pressed, or enter is pressed within input field
|
|
|
|
macro_rules! login {
|
|
|
|
() => {
|
|
|
|
self.login_error = None;
|
|
|
|
self.connecting = Some(std::time::Instant::now());
|
|
|
|
events.push(Event::LoginAttempt {
|
|
|
|
username: self.username.clone(),
|
|
|
|
server_address: self.server_address.clone(),
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
2019-04-19 15:27:37 +00:00
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
// Singleplayer
|
|
|
|
// Used when the singleplayer button is pressed
|
|
|
|
macro_rules! singleplayer {
|
|
|
|
() => {
|
|
|
|
self.login_error = None;
|
|
|
|
events.push(Event::StartSingleplayer);
|
|
|
|
events.push(Event::LoginAttempt {
|
|
|
|
username: "singleplayer".to_string(),
|
|
|
|
server_address: "localhost".to_string(),
|
|
|
|
});
|
|
|
|
};
|
|
|
|
}
|
2019-04-19 15:27:37 +00:00
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
// Username
|
|
|
|
Rectangle::fill_with([320.0, 50.0], color::rgba(0.0, 0.0, 0.0, 0.97))
|
|
|
|
.middle_of(ui_widgets.window)
|
|
|
|
.set(self.ids.usrnm_bg, ui_widgets);
|
|
|
|
Image::new(self.imgs.input_bg)
|
|
|
|
.w_h(337.0, 67.0)
|
|
|
|
.middle_of(self.ids.usrnm_bg)
|
|
|
|
.set(self.ids.username_bg, ui_widgets);
|
|
|
|
for event in TextBox::new(&self.username)
|
|
|
|
.w_h(290.0, 30.0)
|
|
|
|
.mid_bottom_with_margin_on(self.ids.username_bg, 44.0 / 2.0)
|
|
|
|
.font_size(22)
|
|
|
|
.font_id(self.fonts.opensans)
|
|
|
|
.text_color(TEXT_COLOR)
|
|
|
|
// transparent background
|
|
|
|
.color(TRANSPARENT)
|
|
|
|
.border_color(TRANSPARENT)
|
|
|
|
.set(self.ids.username_field, ui_widgets)
|
|
|
|
{
|
|
|
|
match event {
|
|
|
|
TextBoxEvent::Update(username) => {
|
|
|
|
// Note: TextBox limits the input string length to what fits in it
|
|
|
|
self.username = username.to_string();
|
|
|
|
}
|
|
|
|
TextBoxEvent::Enter => {
|
|
|
|
login!();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// Login error
|
|
|
|
if let Some(msg) = &self.login_error {
|
|
|
|
let text = Text::new(&msg)
|
|
|
|
.rgba(1.0, 1.0, 1.0, 1.0)
|
|
|
|
.font_size(30)
|
|
|
|
.font_id(self.fonts.opensans);
|
|
|
|
Rectangle::fill_with([400.0, 100.0], color::TRANSPARENT)
|
|
|
|
.rgba(0.1, 0.1, 0.1, 1.0)
|
|
|
|
.parent(ui_widgets.window)
|
|
|
|
.mid_top_with_margin_on(self.ids.username_bg, -35.0)
|
|
|
|
.set(self.ids.login_error_bg, ui_widgets);
|
|
|
|
Image::new(self.imgs.error_frame)
|
|
|
|
.w_h(400.0, 100.0)
|
|
|
|
.middle_of(self.ids.login_error_bg)
|
|
|
|
.set(self.ids.error_frame, ui_widgets);
|
|
|
|
text.mid_top_with_margin_on(self.ids.error_frame, 10.0)
|
|
|
|
.set(self.ids.login_error, ui_widgets);
|
|
|
|
if Button::image(self.imgs.button)
|
|
|
|
.w_h(100.0, 30.0)
|
|
|
|
.mid_bottom_with_margin_on(self.ids.login_error_bg, 5.0)
|
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
|
|
|
.label_y(Relative::Scalar(2.0))
|
|
|
|
.label("Okay")
|
|
|
|
.label_font_size(10)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.button_ok, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
self.login_error = None
|
|
|
|
};
|
|
|
|
}
|
|
|
|
if self.show_servers {
|
|
|
|
Image::new(self.imgs.error_frame)
|
2019-06-22 14:30:53 +00:00
|
|
|
.mid_top_with_margin_on(self.ids.username_bg, -320.0)
|
|
|
|
.w_h(400.0, 300.0)
|
2019-05-23 22:45:48 +00:00
|
|
|
.set(self.ids.servers_frame, ui_widgets);
|
|
|
|
|
2019-07-13 00:26:17 +00:00
|
|
|
let ref mut net_settings = global_state.settings.networking;
|
2019-05-23 22:45:48 +00:00
|
|
|
|
|
|
|
// TODO: Draw scroll bar or remove it.
|
2019-06-06 14:48:41 +00:00
|
|
|
let (mut items, _scrollbar) = List::flow_down(net_settings.servers.len())
|
2019-05-23 22:45:48 +00:00
|
|
|
.top_left_with_margins_on(self.ids.servers_frame, 0.0, 5.0)
|
|
|
|
.w_h(400.0, 300.0)
|
|
|
|
.scrollbar_next_to()
|
|
|
|
.scrollbar_thickness(18.0)
|
|
|
|
.scrollbar_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.servers_text, ui_widgets);
|
|
|
|
|
|
|
|
while let Some(item) = items.next(ui_widgets) {
|
|
|
|
let mut text = "".to_string();
|
2019-05-31 03:01:52 +00:00
|
|
|
if &net_settings.servers[item.i] == &self.server_address {
|
2019-06-22 14:30:53 +00:00
|
|
|
text.push_str("-> ")
|
2019-05-23 22:45:48 +00:00
|
|
|
} else {
|
|
|
|
text.push_str(" ")
|
|
|
|
}
|
2019-05-31 03:01:52 +00:00
|
|
|
text.push_str(&net_settings.servers[item.i]);
|
2019-04-19 11:14:05 +00:00
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
if item
|
|
|
|
.set(
|
2019-06-22 14:30:53 +00:00
|
|
|
Button::image(self.imgs.nothing)
|
|
|
|
.w_h(100.0, 50.0)
|
|
|
|
.mid_top_with_margin_on(self.ids.servers_frame, 10.0)
|
|
|
|
//.hover_image(self.imgs.button_hover)
|
|
|
|
//.press_image(self.imgs.button_press)
|
2019-05-23 22:45:48 +00:00
|
|
|
.label_y(Relative::Scalar(2.0))
|
|
|
|
.label(&text)
|
|
|
|
.label_font_size(20)
|
|
|
|
.label_color(TEXT_COLOR),
|
|
|
|
ui_widgets,
|
|
|
|
)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-05-31 03:01:52 +00:00
|
|
|
self.server_address = net_settings.servers[item.i].clone();
|
2019-07-13 00:26:17 +00:00
|
|
|
net_settings.default_server = item.i;
|
2019-05-23 22:45:48 +00:00
|
|
|
}
|
2019-04-20 16:21:12 +00:00
|
|
|
}
|
2019-04-19 15:27:37 +00:00
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
if Button::image(self.imgs.button)
|
|
|
|
.w_h(200.0, 53.0)
|
|
|
|
.mid_bottom_with_margin_on(self.ids.servers_frame, 5.0)
|
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
|
|
|
.label_y(Relative::Scalar(2.0))
|
|
|
|
.label("Close")
|
|
|
|
.label_font_size(20)
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.set(self.ids.servers_close, ui_widgets)
|
2019-04-20 16:21:12 +00:00
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-05-23 22:45:48 +00:00
|
|
|
self.show_servers = false
|
|
|
|
};
|
|
|
|
}
|
|
|
|
// Server address
|
|
|
|
Rectangle::fill_with([320.0, 50.0], color::rgba(0.0, 0.0, 0.0, 0.97))
|
|
|
|
.down_from(self.ids.usrnm_bg, 30.0)
|
|
|
|
.set(self.ids.srvr_bg, ui_widgets);
|
|
|
|
Image::new(self.imgs.input_bg)
|
|
|
|
.w_h(337.0, 67.0)
|
|
|
|
.middle_of(self.ids.srvr_bg)
|
|
|
|
.set(self.ids.address_bg, ui_widgets);
|
|
|
|
for event in TextBox::new(&self.server_address)
|
|
|
|
.w_h(290.0, 30.0)
|
|
|
|
.mid_bottom_with_margin_on(self.ids.address_bg, 44.0 / 2.0)
|
|
|
|
.font_size(22)
|
|
|
|
.font_id(self.fonts.opensans)
|
|
|
|
.text_color(TEXT_COLOR)
|
|
|
|
// transparent background
|
|
|
|
.color(TRANSPARENT)
|
|
|
|
.border_color(TRANSPARENT)
|
|
|
|
.set(self.ids.address_field, ui_widgets)
|
|
|
|
{
|
|
|
|
match event {
|
|
|
|
TextBoxEvent::Update(server_address) => {
|
|
|
|
self.server_address = server_address.to_string();
|
|
|
|
}
|
|
|
|
TextBoxEvent::Enter => {
|
|
|
|
login!();
|
|
|
|
}
|
2019-04-19 15:27:37 +00:00
|
|
|
}
|
|
|
|
}
|
2019-05-23 22:45:48 +00:00
|
|
|
// Login button
|
|
|
|
// Change button text and remove hover/press images if a connection is in progress
|
|
|
|
if let Some(start) = self.connecting {
|
|
|
|
Button::image(self.imgs.button)
|
|
|
|
.w_h(258.0, 55.0)
|
|
|
|
.down_from(self.ids.address_bg, 20.0)
|
|
|
|
.align_middle_x_of(self.ids.address_bg)
|
|
|
|
.label("Connecting...")
|
|
|
|
.label_color({
|
|
|
|
let pulse =
|
|
|
|
((start.elapsed().as_millis() as f32 * 0.008).sin() + 1.0) / 2.0;
|
|
|
|
Color::Rgba(
|
|
|
|
TEXT_COLOR.red() * (pulse / 2.0 + 0.5),
|
|
|
|
TEXT_COLOR.green() * (pulse / 2.0 + 0.5),
|
|
|
|
TEXT_COLOR.blue() * (pulse / 2.0 + 0.5),
|
|
|
|
pulse / 4.0 + 0.75,
|
|
|
|
)
|
|
|
|
})
|
|
|
|
.label_font_size(22)
|
|
|
|
.label_y(Relative::Scalar(5.0))
|
|
|
|
.set(self.ids.login_button, ui_widgets);
|
|
|
|
} else {
|
|
|
|
if Button::image(self.imgs.button)
|
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
|
|
|
.w_h(258.0, 55.0)
|
|
|
|
.down_from(self.ids.address_bg, 20.0)
|
|
|
|
.align_middle_x_of(self.ids.address_bg)
|
|
|
|
.label("Login")
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_font_size(24)
|
|
|
|
.label_y(Relative::Scalar(5.0))
|
2019-07-29 14:06:13 +00:00
|
|
|
.with_tooltip(
|
|
|
|
tooltip_manager,
|
|
|
|
Tooltip::new("Login", "Click to login with the entered details")
|
|
|
|
.title_font_size(15)
|
|
|
|
.desc_font_size(10)
|
|
|
|
.title_text_color(TEXT_COLOR)
|
|
|
|
.desc_text_color(TEXT_COLOR_2),
|
|
|
|
)
|
2019-05-23 22:45:48 +00:00
|
|
|
.set(self.ids.login_button, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
login!();
|
|
|
|
}
|
|
|
|
};
|
2019-04-19 15:27:37 +00:00
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
// Singleplayer button
|
2019-05-03 11:02:03 +00:00
|
|
|
if Button::image(self.imgs.button)
|
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
|
|
|
.w_h(258.0, 55.0)
|
2019-05-23 22:45:48 +00:00
|
|
|
.down_from(self.ids.login_button, 20.0)
|
2019-04-14 23:28:29 +00:00
|
|
|
.align_middle_x_of(self.ids.address_bg)
|
2019-05-23 22:45:48 +00:00
|
|
|
.label("Singleplayer")
|
|
|
|
.label_color(TEXT_COLOR)
|
2019-05-03 11:02:03 +00:00
|
|
|
.label_font_size(22)
|
2019-04-14 23:28:29 +00:00
|
|
|
.label_y(Relative::Scalar(5.0))
|
2019-05-23 22:45:48 +00:00
|
|
|
.label_x(Relative::Scalar(2.0))
|
|
|
|
.set(self.ids.singleplayer_button, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
|
|
|
singleplayer!();
|
|
|
|
}
|
|
|
|
// Quit
|
2019-04-29 20:37:19 +00:00
|
|
|
if Button::image(self.imgs.button)
|
2019-05-23 22:45:48 +00:00
|
|
|
.w_h(190.0, 40.0)
|
|
|
|
.bottom_left_with_margins_on(ui_widgets.window, 60.0, 30.0)
|
2019-04-24 19:55:22 +00:00
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
2019-05-23 22:45:48 +00:00
|
|
|
.label("Quit")
|
2019-04-14 23:28:29 +00:00
|
|
|
.label_color(TEXT_COLOR)
|
2019-05-23 22:45:48 +00:00
|
|
|
.label_font_size(20)
|
|
|
|
.label_y(Relative::Scalar(3.0))
|
|
|
|
.set(self.ids.quit_button, ui_widgets)
|
2019-04-14 23:28:29 +00:00
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-05-23 22:45:48 +00:00
|
|
|
events.push(Event::Quit);
|
2019-06-10 20:44:03 +00:00
|
|
|
}
|
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
// Settings
|
|
|
|
if Button::image(self.imgs.button)
|
|
|
|
.w_h(190.0, 40.0)
|
|
|
|
.up_from(self.ids.quit_button, 8.0)
|
2019-06-22 14:30:53 +00:00
|
|
|
//.hover_image(self.imgs.button_hover)
|
|
|
|
//.press_image(self.imgs.button_press)
|
2019-05-23 22:45:48 +00:00
|
|
|
.label("Settings")
|
2019-06-22 14:30:53 +00:00
|
|
|
.label_color(TEXT_COLOR_2)
|
2019-05-23 22:45:48 +00:00
|
|
|
.label_font_size(20)
|
|
|
|
.label_y(Relative::Scalar(3.0))
|
|
|
|
.set(self.ids.settings_button, ui_widgets)
|
|
|
|
.was_clicked()
|
2019-06-10 20:44:03 +00:00
|
|
|
{
|
|
|
|
events.push(Event::Settings);
|
|
|
|
}
|
|
|
|
|
2019-05-23 22:45:48 +00:00
|
|
|
// Servers
|
|
|
|
if Button::image(self.imgs.button)
|
|
|
|
.w_h(190.0, 40.0)
|
|
|
|
.up_from(self.ids.settings_button, 8.0)
|
|
|
|
.hover_image(self.imgs.button_hover)
|
|
|
|
.press_image(self.imgs.button_press)
|
|
|
|
.label("Servers")
|
|
|
|
.label_color(TEXT_COLOR)
|
|
|
|
.label_font_size(20)
|
|
|
|
.label_y(Relative::Scalar(3.0))
|
|
|
|
.set(self.ids.servers_button, ui_widgets)
|
|
|
|
.was_clicked()
|
|
|
|
{
|
2019-06-28 08:24:13 +00:00
|
|
|
self.show_servers = !self.show_servers;
|
2019-05-23 22:45:48 +00:00
|
|
|
};
|
2019-03-15 04:55:52 +00:00
|
|
|
}
|
2019-03-17 17:52:54 +00:00
|
|
|
|
|
|
|
events
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
|
2019-04-04 14:45:57 +00:00
|
|
|
pub fn login_error(&mut self, msg: String) {
|
|
|
|
self.login_error = Some(msg);
|
2019-04-14 23:28:29 +00:00
|
|
|
self.connecting = None;
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn connected(&mut self) {
|
|
|
|
self.connecting = None;
|
2019-04-04 14:45:57 +00:00
|
|
|
}
|
|
|
|
|
2019-03-22 03:55:42 +00:00
|
|
|
pub fn handle_event(&mut self, event: ui::Event) {
|
|
|
|
self.ui.handle_event(event);
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
|
2019-04-19 11:14:05 +00:00
|
|
|
pub fn maintain(&mut self, global_state: &mut GlobalState) -> Vec<Event> {
|
|
|
|
let events = self.update_layout(global_state);
|
2019-05-20 06:09:20 +00:00
|
|
|
self.ui.maintain(global_state.window.renderer_mut(), None);
|
2019-03-17 17:52:54 +00:00
|
|
|
events
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn render(&self, renderer: &mut Renderer) {
|
2019-05-14 06:43:07 +00:00
|
|
|
self.ui.render(renderer, None);
|
2019-03-04 07:28:16 +00:00
|
|
|
}
|
|
|
|
}
|