2019-10-02 10:05:17 +00:00
|
|
|
use super::{img_ids::Imgs, Fonts, Show, TEXT_COLOR_2};
|
|
|
|
use client::{self, Client};
|
|
|
|
use common::comp;
|
2019-04-30 14:39:19 +00:00
|
|
|
use conrod_core::{
|
2019-05-07 03:25:25 +00:00
|
|
|
color,
|
2019-06-22 14:30:53 +00:00
|
|
|
widget::{self, Button, Image, Rectangle, Text},
|
|
|
|
widget_ids, Colorable, Positionable, Sizeable, Widget, WidgetCommon,
|
2019-04-30 14:39:19 +00:00
|
|
|
};
|
2019-10-02 10:05:17 +00:00
|
|
|
use vek::*;
|
2019-06-22 14:30:53 +00:00
|
|
|
|
2019-04-30 14:39:19 +00:00
|
|
|
widget_ids! {
|
|
|
|
struct Ids {
|
2019-05-04 17:29:19 +00:00
|
|
|
map_frame,
|
2019-04-30 14:39:19 +00:00
|
|
|
map_bg,
|
2019-05-04 17:29:19 +00:00
|
|
|
map_icon,
|
2019-04-30 14:39:19 +00:00
|
|
|
map_close,
|
2019-05-04 17:29:19 +00:00
|
|
|
map_title,
|
2019-04-30 14:39:19 +00:00
|
|
|
map_frame_l,
|
|
|
|
map_frame_r,
|
2019-05-04 17:29:19 +00:00
|
|
|
map_frame_bl,
|
|
|
|
map_frame_br,
|
2019-06-22 14:30:53 +00:00
|
|
|
location_name,
|
2019-10-02 10:05:17 +00:00
|
|
|
indicator,
|
|
|
|
grid,
|
2019-04-30 14:39:19 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#[derive(WidgetCommon)]
|
|
|
|
pub struct Map<'a> {
|
2019-07-02 21:25:07 +00:00
|
|
|
_show: &'a Show,
|
2019-06-22 14:30:53 +00:00
|
|
|
client: &'a Client,
|
|
|
|
|
2019-04-30 14:39:19 +00:00
|
|
|
imgs: &'a Imgs,
|
2019-07-02 21:25:07 +00:00
|
|
|
_fonts: &'a Fonts,
|
2019-04-30 14:39:19 +00:00
|
|
|
#[conrod(common_builder)]
|
|
|
|
common: widget::CommonBuilder,
|
|
|
|
}
|
|
|
|
impl<'a> Map<'a> {
|
2019-06-22 14:30:53 +00:00
|
|
|
pub fn new(show: &'a Show, client: &'a Client, imgs: &'a Imgs, fonts: &'a Fonts) -> Self {
|
2019-04-30 14:39:19 +00:00
|
|
|
Self {
|
2019-07-02 21:25:07 +00:00
|
|
|
_show: show,
|
2019-04-30 14:39:19 +00:00
|
|
|
imgs,
|
2019-06-22 14:30:53 +00:00
|
|
|
client,
|
2019-07-02 21:25:07 +00:00
|
|
|
_fonts: fonts,
|
2019-04-30 14:39:19 +00:00
|
|
|
common: widget::CommonBuilder::default(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub struct State {
|
|
|
|
ids: Ids,
|
|
|
|
}
|
|
|
|
|
|
|
|
pub enum Event {
|
|
|
|
Close,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<'a> Widget for Map<'a> {
|
|
|
|
type State = State;
|
2019-04-30 20:43:55 +00:00
|
|
|
type Style = ();
|
2019-04-30 14:39:19 +00:00
|
|
|
type Event = Option<Event>;
|
|
|
|
|
|
|
|
fn init_state(&self, id_gen: widget::id::Generator) -> Self::State {
|
|
|
|
State {
|
|
|
|
ids: Ids::new(id_gen),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
fn style(&self) -> Self::Style {
|
2019-04-30 20:43:55 +00:00
|
|
|
()
|
2019-04-30 14:39:19 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
fn update(self, args: widget::UpdateArgs<Self>) -> Self::Event {
|
2019-05-07 05:40:03 +00:00
|
|
|
let widget::UpdateArgs { state, ui, .. } = args;
|
2019-04-30 14:39:19 +00:00
|
|
|
|
|
|
|
// BG
|
2019-05-07 05:40:03 +00:00
|
|
|
Rectangle::fill_with([824.0, 976.0], color::TRANSPARENT)
|
|
|
|
.mid_top_with_margin_on(ui.window, 15.0)
|
|
|
|
.scroll_kids()
|
|
|
|
.scroll_kids_vertically()
|
|
|
|
.set(state.ids.map_bg, ui);
|
2019-05-12 04:17:10 +00:00
|
|
|
|
2019-05-07 05:40:03 +00:00
|
|
|
// Frame
|
|
|
|
Image::new(self.imgs.map_frame_l)
|
|
|
|
.top_left_with_margins_on(state.ids.map_bg, 0.0, 0.0)
|
|
|
|
.w_h(412.0, 488.0)
|
|
|
|
.set(state.ids.map_frame_l, ui);
|
|
|
|
Image::new(self.imgs.map_frame_r)
|
|
|
|
.right_from(state.ids.map_frame_l, 0.0)
|
|
|
|
.w_h(412.0, 488.0)
|
|
|
|
.set(state.ids.map_frame_r, ui);
|
|
|
|
Image::new(self.imgs.map_frame_br)
|
|
|
|
.down_from(state.ids.map_frame_r, 0.0)
|
|
|
|
.w_h(412.0, 488.0)
|
|
|
|
.set(state.ids.map_frame_br, ui);
|
|
|
|
Image::new(self.imgs.map_frame_bl)
|
|
|
|
.down_from(state.ids.map_frame_l, 0.0)
|
|
|
|
.w_h(412.0, 488.0)
|
|
|
|
.set(state.ids.map_frame_bl, ui);
|
2019-05-04 17:29:19 +00:00
|
|
|
|
2019-05-07 05:40:03 +00:00
|
|
|
// Icon
|
|
|
|
Image::new(self.imgs.map_icon)
|
|
|
|
.w_h(224.0 / 3.0, 224.0 / 3.0)
|
|
|
|
.top_left_with_margins_on(state.ids.map_frame, -10.0, -10.0)
|
|
|
|
.set(state.ids.map_icon, ui);
|
2019-04-30 14:39:19 +00:00
|
|
|
|
|
|
|
// X-Button
|
2019-05-07 05:40:03 +00:00
|
|
|
if Button::image(self.imgs.close_button)
|
|
|
|
.w_h(28.0, 28.0)
|
|
|
|
.hover_image(self.imgs.close_button_hover)
|
|
|
|
.press_image(self.imgs.close_button_press)
|
|
|
|
.top_right_with_margins_on(state.ids.map_frame_r, 0.0, 0.0)
|
|
|
|
.set(state.ids.map_close, ui)
|
|
|
|
.was_clicked()
|
2019-04-30 14:39:19 +00:00
|
|
|
{
|
|
|
|
return Some(Event::Close);
|
2019-05-07 05:40:03 +00:00
|
|
|
}
|
2019-04-30 14:39:19 +00:00
|
|
|
|
2019-06-22 14:30:53 +00:00
|
|
|
// Location Name
|
|
|
|
match self.client.current_chunk() {
|
|
|
|
Some(chunk) => Text::new(chunk.meta().name())
|
|
|
|
.mid_top_with_margin_on(state.ids.map_bg, 40.0)
|
|
|
|
.font_size(40)
|
|
|
|
.color(TEXT_COLOR_2)
|
|
|
|
.parent(state.ids.map_frame_r)
|
|
|
|
.set(state.ids.location_name, ui),
|
|
|
|
None => Text::new(" ")
|
|
|
|
.mid_top_with_margin_on(state.ids.map_bg, 3.0)
|
|
|
|
.font_size(40)
|
|
|
|
.color(TEXT_COLOR_2)
|
|
|
|
.set(state.ids.location_name, ui),
|
|
|
|
}
|
2019-10-02 10:05:17 +00:00
|
|
|
// Map Image
|
|
|
|
Image::new(self.imgs.map_placeholder)
|
|
|
|
.middle_of(state.ids.map_bg)
|
|
|
|
.w_h(700.0, 700.0)
|
|
|
|
.parent(state.ids.map_bg)
|
|
|
|
.set(state.ids.grid, ui);
|
|
|
|
// Coordinates
|
|
|
|
let player_pos = self
|
|
|
|
.client
|
|
|
|
.state()
|
|
|
|
.ecs()
|
|
|
|
.read_storage::<comp::Pos>()
|
|
|
|
.get(self.client.entity())
|
|
|
|
.map_or(Vec3::zero(), |pos| pos.0);
|
|
|
|
|
|
|
|
let worldsize = 32768.0; // TODO This has to get the actual world size and not be hardcoded
|
|
|
|
let x = player_pos.x as f64 / worldsize * 700.0;
|
|
|
|
let y = player_pos.y as f64 / worldsize * 700.0;
|
|
|
|
// Indicator
|
|
|
|
Image::new(self.imgs.map_indicator)
|
|
|
|
.bottom_left_with_margins_on(state.ids.grid, y, x - 11.5)
|
|
|
|
.w_h(23.0, 25.0)
|
|
|
|
.floating(true)
|
|
|
|
.parent(ui.window)
|
|
|
|
.set(state.ids.indicator, ui);
|
2019-06-22 14:30:53 +00:00
|
|
|
|
2019-04-30 14:39:19 +00:00
|
|
|
None
|
|
|
|
}
|
|
|
|
}
|