From 16871208f27eb11a905930218eb22fec330f30a5 Mon Sep 17 00:00:00 2001 From: James Melkonian Date: Mon, 5 Apr 2021 22:15:42 -0700 Subject: [PATCH] Add topographic option to map --- CHANGELOG.md | 1 + Cargo.toml | 2 +- assets/voxygen/element/map/topographic.png | 3 + assets/voxygen/i18n/en/hud/map.ron | 1 + client/src/lib.rs | 303 +++++++++++++-------- common/src/terrain/map.rs | 6 +- voxygen/src/hud/img_ids.rs | 1 + voxygen/src/hud/map.rs | 44 ++- voxygen/src/hud/minimap.rs | 5 +- voxygen/src/hud/mod.rs | 24 +- voxygen/src/session.rs | 4 + voxygen/src/settings.rs | 4 +- world/examples/water.rs | 8 +- 13 files changed, 272 insertions(+), 134 deletions(-) create mode 100644 assets/voxygen/element/map/topographic.png diff --git a/CHANGELOG.md b/CHANGELOG.md index f13320ea09..50b0d3fd0a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -21,6 +21,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 - Attacks now emit sound effects from the target on hit. - Crafting menu tabs - Auto camera setting, making the game easier to play with one hand +- Topographic map option ### Changed diff --git a/Cargo.toml b/Cargo.toml index 362bccde47..2c7b8a0bbe 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -31,7 +31,7 @@ debug = false codegen-units = 8 lto = false # TEMP false to avoid fingerprints bug -incremental = true +incremental = false # All dependencies (but not this crate itself) [profile.dev.package."*"] opt-level = 3 diff --git a/assets/voxygen/element/map/topographic.png b/assets/voxygen/element/map/topographic.png new file mode 100644 index 0000000000..865c9e3eb4 --- /dev/null +++ b/assets/voxygen/element/map/topographic.png @@ -0,0 +1,3 @@ +version https://git-lfs.github.com/spec/v1 +oid sha256:db87739f820b657829638910770fa79a119aa60d7db6f561edafbb31afbf7a0d +size 11585 diff --git a/assets/voxygen/i18n/en/hud/map.ron b/assets/voxygen/i18n/en/hud/map.ron index 8482ecfbc2..4fbf02bc25 100644 --- a/assets/voxygen/i18n/en/hud/map.ron +++ b/assets/voxygen/i18n/en/hud/map.ron @@ -6,6 +6,7 @@ // Map and Questlog "hud.map.map_title": "Map", "hud.map.qlog_title": "Quests", + "hud.map.topo_map": "Topographic", "hud.map.difficulty": "Difficulty", "hud.map.towns": "Towns", "hud.map.castles": "Castles", diff --git a/client/src/lib.rs b/client/src/lib.rs index b0b30b8c8e..2c9f44a113 100644 --- a/client/src/lib.rs +++ b/client/src/lib.rs @@ -34,7 +34,10 @@ use common::{ outcome::Outcome, recipe::RecipeBook, resources::{DeltaTime, PlayerEntity, TimeOfDay}, - terrain::{block::Block, map::MapConfig, neighbors, BiomeKind, SitesKind, TerrainChunk, TerrainChunkSize}, + terrain::{ + block::Block, map::MapConfig, neighbors, BiomeKind, SitesKind, TerrainChunk, + TerrainChunkSize, + }, trade::{PendingTrade, SitePrices, TradeAction, TradeId, TradeResult}, uid::{Uid, UidAllocator}, vol::RectVolSize, @@ -326,8 +329,9 @@ impl Client { let horizons = [unzip_horizons(&west), unzip_horizons(&east)]; // Redraw map (with shadows this time). - let mut world_map_political = vec![0u32; rgba.size().product() as usize]; let mut world_map_rgba = vec![0u32; rgba.size().product() as usize]; + let mut world_map_political = vec![0u32; rgba.size().product() as usize]; + let mut world_map_rgba_half_alpha = vec![0u32; rgba.size().product() as usize]; let mut world_map_topo = vec![0u32; rgba.size().product() as usize]; let mut map_config = common::terrain::map::MapConfig::orthographic( map_size_lg, @@ -341,121 +345,167 @@ impl Client { && pos.y < map_size.y as i32 }; ping_stream.send(PingMsg::Ping)?; - fn sample_pos(map_config: &MapConfig, pos: Vec2, alt: &Grid, rgba: &Grid, map_size: &Vec2, map_size_lg: &common::terrain::MapSizeLg, max_height: f32) -> common::terrain::map::MapSample { - let rescale_height = |h: f32| h / max_height; - let scale_height_big = |h: u32| (h >> 3) as f32 / 8191.0 * max_height; - let bounds_check = |pos: Vec2| { - pos.reduce_partial_min() >= 0 - && pos.x < map_size.x as i32 - && pos.y < map_size.y as i32 - }; - let MapConfig { - gain, - is_contours, - is_height_map, - is_political, - is_roads, - .. - } = *map_config; - let mut is_contour_line = false; - let mut is_border = false; - let (rgba, alt, downhill_wpos) = if bounds_check(pos) { - let posi = pos.y as usize * map_size.x as usize + pos.x as usize; - let [r, g, b, a] = rgba[pos].to_le_bytes(); - let is_water = r == 0 && b > 102 && g < 77; - let alti = alt[pos]; - // Compute contours (chunks are assigned in the river code below) - let altj = rescale_height(scale_height_big(alti)); - let contour_interval = 150.0; - let chunk_contour = (altj * gain / contour_interval) as u32; + fn sample_pos( + map_config: &MapConfig, + pos: Vec2, + alt: &Grid, + rgba: &Grid, + map_size: &Vec2, + map_size_lg: &common::terrain::MapSizeLg, + max_height: f32, + ) -> common::terrain::map::MapSample { + let rescale_height = |h: f32| h / max_height; + let scale_height_big = |h: u32| (h >> 3) as f32 / 8191.0 * max_height; + let bounds_check = |pos: Vec2| { + pos.reduce_partial_min() >= 0 + && pos.x < map_size.x as i32 + && pos.y < map_size.y as i32 + }; + let MapConfig { + gain, + is_contours, + is_height_map, + is_political, + is_roads, + rgba_alpha, + .. + } = *map_config; + let mut is_contour_line = false; + let mut is_border = false; + let (rgba, alt, downhill_wpos) = if bounds_check(pos) { + let posi = pos.y as usize * map_size.x as usize + pos.x as usize; + let [r, g, b, a] = rgba[pos].to_le_bytes(); + let is_water = r == 0 && b > 102 && g < 77; + let alti = alt[pos]; + // Compute contours (chunks are assigned in the river code below) + let altj = rescale_height(scale_height_big(alti)); + let contour_interval = 150.0; + let chunk_contour = (altj * gain / contour_interval) as u32; - // Compute downhill. - let downhill = { - let mut best = -1; - let mut besth = alti; - for nposi in neighbors(*map_size_lg, posi) { - let nbh = alt.raw()[nposi]; - let nalt = rescale_height(scale_height_big(nbh)); - let nchunk_contour = (nalt * gain / contour_interval) as u32; - if !is_contour_line && chunk_contour > nchunk_contour { - is_contour_line = true; - } - let [nr, ng, nb, _na] = rgba.raw()[nposi].to_le_bytes(); - let n_is_water = nr == 0 && nb > 102 && ng < 77; - - if !is_border && is_political && is_water && !n_is_water { - is_border = true; - } - - if nbh < besth { - besth = nbh; - best = nposi as isize; - } + // Compute downhill. + let downhill = { + let mut best = -1; + let mut besth = alti; + for nposi in neighbors(*map_size_lg, posi) { + let nbh = alt.raw()[nposi]; + let nalt = rescale_height(scale_height_big(nbh)); + let nchunk_contour = (nalt * gain / contour_interval) as u32; + if !is_contour_line && chunk_contour > nchunk_contour { + is_contour_line = true; } - best - }; - let downhill_wpos = if downhill < 0 { - None - } else { - Some( - Vec2::new( - (downhill as usize % map_size.x as usize) as i32, - (downhill as usize / map_size.x as usize) as i32, - ) * TerrainChunkSize::RECT_SIZE.map(|e| e as i32), - ) - }; - (Rgba::new(r, g, b, a), alti, downhill_wpos) - } else { - (Rgba::zero(), 0, None) + let [nr, ng, nb, _na] = rgba.raw()[nposi].to_le_bytes(); + let n_is_water = nr == 0 && nb > 102 && ng < 77; + + if !is_border && is_political && is_water && !n_is_water { + is_border = true; + } + + if nbh < besth { + besth = nbh; + best = nposi as isize; + } + } + best }; - let alt = f64::from(rescale_height(scale_height_big(alt))); - let wpos = pos * TerrainChunkSize::RECT_SIZE.map(|e| e as i32); - let downhill_wpos = downhill_wpos - .unwrap_or(wpos + TerrainChunkSize::RECT_SIZE.map(|e| e as i32)); - let is_path = rgba.r == 0x37 && rgba.g == 0x29 && rgba.b == 0x23; - let rgba = rgba.map(|e: u8| e as f64 / 255.0); - let rgba = if is_height_map { - if is_path { - // Path color is Rgb::new(0x37, 0x29, 0x23) - Rgba::new(0.9, 0.9, 0.63, 1.0) - } else if rgba.r == 0.0 && rgba.b > 0.4 && rgba.g < 0.3 { - // Water - Rgba::new(0.23, 0.47, 0.53, 0.5) - } else if is_contours && is_contour_line { - // Color contour lines - Rgba::new(0.15, 0.15, 0.15, 0.5) - } else { - // Color hill shading - let lightness = (alt + 0.2).min(1.0) as f64; - Rgba::new(lightness, 0.9 * lightness, 0.5 * lightness, 0.5) - } - } else if is_roads && is_path { - Rgba::new(0.9, 0.9, 0.63, 1.0) - } else if is_political { - if is_path { - Rgba::new(0.3, 0.3, 0.3, 1.0) - } else if is_border { - Rgba::new(0.0, 0.0, 0.0, 1.0) - } else { - Rgba::new(1.0, 0.9, 0.6, 1.0) - } - } else if is_contours && is_contour_line { - Rgba::new(0.15, 0.15, 0.15, 0.8) + let downhill_wpos = if downhill < 0 { + None } else { - Rgba::new(rgba.r, rgba.g, rgba.b, 0.5) - }.map(|e| (e * 255.0) as u8); - common::terrain::map::MapSample { - rgba, - alt, - downhill_wpos, - connections: None, - is_path, + Some( + Vec2::new( + (downhill as usize % map_size.x as usize) as i32, + (downhill as usize / map_size.x as usize) as i32, + ) * TerrainChunkSize::RECT_SIZE.map(|e| e as i32), + ) + }; + (Rgba::new(r, g, b, a), alti, downhill_wpos) + } else { + (Rgba::zero(), 0, None) + }; + let alt = f64::from(rescale_height(scale_height_big(alt))); + let wpos = pos * TerrainChunkSize::RECT_SIZE.map(|e| e as i32); + let downhill_wpos = downhill_wpos + .unwrap_or(wpos + TerrainChunkSize::RECT_SIZE.map(|e| e as i32)); + let is_path = rgba.r == 0x37 && rgba.g == 0x29 && rgba.b == 0x23; + let rgba = rgba.map(|e: u8| e as f64 / 255.0); + let rgba = if is_height_map { + if is_path { + // Path color is Rgb::new(0x37, 0x29, 0x23) + Rgba::new(0.9, 0.9, 0.63, 1.0) + } else if rgba.r == 0.0 && rgba.b > 0.4 && rgba.g < 0.3 { + // Water + Rgba::new(0.23, 0.47, 0.53, 0.5) + } else if is_contours && is_contour_line { + // Color contour lines + Rgba::new(0.15, 0.15, 0.15, 0.5) + } else { + // Color hill shading + let lightness = (alt + 0.2).min(1.0) as f64; + Rgba::new(lightness, 0.9 * lightness, 0.5 * lightness, 0.5) } + } else if is_roads && is_path { + Rgba::new(0.9, 0.9, 0.63, 1.0) + } else if is_political { + if is_path { + Rgba::new(0.3, 0.3, 0.3, 1.0) + } else if is_border { + Rgba::new(0.0, 0.0, 0.0, 1.0) + } else { + Rgba::new(1.0, 0.9, 0.6, 1.0) + } + } else if is_contours && is_contour_line { + Rgba::new(0.15, 0.15, 0.15, 0.8) + } else { + Rgba::new(rgba.r, rgba.g, rgba.b, rgba_alpha) + } + .map(|e| (e * 255.0) as u8); + common::terrain::map::MapSample { + rgba, + alt, + downhill_wpos, + connections: None, + is_path, + } } map_config.is_shaded = true; + map_config.rgba_alpha = 1.0; + map_config.generate( + |pos| { + sample_pos( + &map_config, + pos, + &alt, + &rgba, + &map_size, + &map_size_lg, + max_height, + ) + }, + |wpos| { + let pos = wpos.map2(TerrainChunkSize::RECT_SIZE, |e, f| e / f as i32); + rescale_height(if bounds_check(pos) { + scale_height_big(alt[pos]) + } else { + 0.0 + }) + }, + |pos, (r, g, b, a)| { + world_map_rgba[pos.y * map_size.x as usize + pos.x] = + u32::from_le_bytes([r, g, b, a]); + }, + ); map_config.is_political = true; map_config.generate( - |pos| sample_pos(&map_config, pos, &alt, &rgba, &map_size, &map_size_lg, max_height), + |pos| { + sample_pos( + &map_config, + pos, + &alt, + &rgba, + &map_size, + &map_size_lg, + max_height, + ) + }, |wpos| { let pos = wpos.map2(TerrainChunkSize::RECT_SIZE, |e, f| e / f as i32); rescale_height(if bounds_check(pos) { @@ -471,9 +521,20 @@ impl Client { ); map_config.is_shaded = false; + map_config.rgba_alpha = 0.5; map_config.is_political = false; map_config.generate( - |pos| sample_pos(&map_config, pos, &alt, &rgba, &map_size, &map_size_lg, max_height), + |pos| { + sample_pos( + &map_config, + pos, + &alt, + &rgba, + &map_size, + &map_size_lg, + max_height, + ) + }, |wpos| { let pos = wpos.map2(TerrainChunkSize::RECT_SIZE, |e, f| e / f as i32); rescale_height(if bounds_check(pos) { @@ -483,7 +544,7 @@ impl Client { }) }, |pos, (r, g, b, a)| { - world_map_rgba[pos.y * map_size.x as usize + pos.x] = + world_map_rgba_half_alpha[pos.y * map_size.x as usize + pos.x] = u32::from_le_bytes([r, g, b, a]); }, ); @@ -491,7 +552,17 @@ impl Client { map_config.is_contours = true; map_config.is_roads = true; map_config.generate( - |pos| sample_pos(&map_config, pos, &alt, &rgba, &map_size, &map_size_lg, max_height), + |pos| { + sample_pos( + &map_config, + pos, + &alt, + &rgba, + &map_size, + &map_size_lg, + max_height, + ) + }, |wpos| { let pos = wpos.map2(TerrainChunkSize::RECT_SIZE, |e, f| e / f as i32); rescale_height(if bounds_check(pos) { @@ -525,9 +596,15 @@ impl Client { let lod_base = rgba; let lod_alt = alt; let world_map_rgba_img = make_raw(&world_map_rgba)?; - let world_map_topo_img = make_raw(&world_map_topo)?; let world_map_political_img = make_raw(&world_map_political)?; - let world_map_layers = vec!(world_map_political_img, world_map_rgba_img, world_map_topo_img); + let world_map_rgba_half_alpha_img = make_raw(&world_map_rgba_half_alpha)?; + let world_map_topo_img = make_raw(&world_map_topo)?; + let world_map_layers = vec![ + world_map_rgba_img, + world_map_political_img, + world_map_rgba_half_alpha_img, + world_map_topo_img, + ]; let horizons = (west.0, west.1, east.0, east.1) .into_par_iter() .map(|(wa, wh, ea, eh)| u32::from_le_bytes([wa, wh, ea, eh])) diff --git a/common/src/terrain/map.rs b/common/src/terrain/map.rs index 74313a9bc5..a323f20e31 100644 --- a/common/src/terrain/map.rs +++ b/common/src/terrain/map.rs @@ -334,6 +334,10 @@ pub struct MapConfig<'a> { /// /// Defaults to false pub is_roads: bool, + /// Alpha value for rgba. Handled by the sample_pos closure + /// + /// Defaults to 1.0 + pub rgba_alpha: f64, } pub const QUADRANTS: usize = 4; @@ -418,6 +422,7 @@ impl<'a> MapConfig<'a> { is_height_map: false, is_political: false, is_roads: false, + rgba_alpha: 1.0, } } @@ -736,4 +741,3 @@ impl<'a> MapConfig<'a> { } } } - diff --git a/voxygen/src/hud/img_ids.rs b/voxygen/src/hud/img_ids.rs index 024c762fda..5a746d9c83 100644 --- a/voxygen/src/hud/img_ids.rs +++ b/voxygen/src/hud/img_ids.rs @@ -336,6 +336,7 @@ image_ids! { crosshair_bg_pressed: "voxygen.element.misc_bg.crosshair_bg_pressed", // Map + map_topo: "voxygen.element.map.topographic", map_bg: "voxygen.element.misc_bg.map_bg", map_frame: "voxygen.element.misc_bg.map_frame", map_frame_art: "voxygen.element.misc_bg.map_frame_art", diff --git a/voxygen/src/hud/map.rs b/voxygen/src/hud/map.rs index d3ee0b2f73..07ac6d207e 100644 --- a/voxygen/src/hud/map.rs +++ b/voxygen/src/hud/map.rs @@ -40,6 +40,9 @@ widget_ids! { member_indicators[], member_height_indicators[], map_settings_align, + show_topo_map_img, + show_topo_map_box, + show_topo_map_text, show_towns_img, show_towns_box, show_towns_text, @@ -123,6 +126,7 @@ pub enum Event { ShowDungeons(bool), ShowCaves(bool), ShowTrees(bool), + ShowTopoMap(bool), Close, RequestSiteInfo(SiteId), } @@ -184,6 +188,7 @@ impl<'a> Widget for Map<'a> { let show_castles = self.global_state.settings.interface.map_show_castles; let show_caves = self.global_state.settings.interface.map_show_caves; let show_trees = self.global_state.settings.interface.map_show_trees; + let show_topo_map = self.global_state.settings.interface.map_show_topo_map; let mut events = Vec::new(); let i18n = &self.localized_strings; // Tooltips @@ -342,7 +347,7 @@ impl<'a> Widget for Map<'a> { .parent(state.ids.bg) .source_rectangle(rect_src) .set(state.ids.map_layers[index], ui); - } else { + } else if show_topo_map { Image::new(layer.none) .mid_top_with_margin_on(state.ids.map_align, 10.0) .w_h(map_size.x, map_size.y) @@ -369,9 +374,44 @@ impl<'a> Widget for Map<'a> { .top_right_with_margins_on(state.ids.frame, 55.0, 10.0) .set(state.ids.map_settings_align, ui); // Checkboxes + // Show topographic map + Image::new(self.imgs.map_topo) + .top_left_with_margins_on(state.ids.map_settings_align, 5.0, 5.0) + .w_h(20.0, 20.0) + .set(state.ids.show_topo_map_img, ui); + if Button::image(if show_topo_map { + self.imgs.checkbox_checked + } else { + self.imgs.checkbox + }) + .w_h(18.0, 18.0) + .hover_image(if show_topo_map { + self.imgs.checkbox_checked_mo + } else { + self.imgs.checkbox_mo + }) + .press_image(if show_topo_map { + self.imgs.checkbox_checked + } else { + self.imgs.checkbox_press + }) + .right_from(state.ids.show_topo_map_img, 10.0) + .set(state.ids.show_topo_map_box, ui) + .was_clicked() + { + events.push(Event::ShowTopoMap(!show_topo_map)); + } + Text::new(i18n.get("hud.map.topo_map")) + .right_from(state.ids.show_topo_map_box, 10.0) + .font_size(self.fonts.cyri.scale(14)) + .font_id(self.fonts.cyri.conrod_id) + .graphics_for(state.ids.show_topo_map_box) + .color(TEXT_COLOR) + .set(state.ids.show_topo_map_text, ui); + // Show difficulties Image::new(self.imgs.map_dif_6) - .top_left_with_margins_on(state.ids.map_settings_align, 5.0, 5.0) + .down_from(state.ids.show_topo_map_img, 10.0) .w_h(20.0, 20.0) .set(state.ids.show_difficulty_img, ui); if Button::image(if show_difficulty { diff --git a/voxygen/src/hud/minimap.rs b/voxygen/src/hud/minimap.rs index b9e481c50a..7eed945091 100644 --- a/voxygen/src/hud/minimap.rs +++ b/voxygen/src/hud/minimap.rs @@ -118,6 +118,7 @@ impl<'a> Widget for MiniMap<'a> { const SCALE: f64 = 1.5; // TODO Make this a setting let show_minimap = self.global_state.settings.interface.minimap_show; let is_facing_north = self.global_state.settings.interface.minimap_face_north; + let show_topo_map = self.global_state.settings.interface.map_show_topo_map; let orientation = if is_facing_north { Vec3::new(0.0, 1.0, 0.0) } else { @@ -272,7 +273,7 @@ impl<'a> Widget for MiniMap<'a> { .parent(state.ids.mmap_frame_bg) .source_rectangle(rect_src) .set(state.ids.map_layers[index], ui); - } else { + } else if show_topo_map { Image::new(world_map_rotation) .middle_of(state.ids.mmap_frame_bg) .w_h(map_size.x, map_size.y) @@ -350,7 +351,7 @@ impl<'a> Widget for MiniMap<'a> { SiteKind::Cave => Color::Rgba(1.0, 1.0, 1.0, 0.0), SiteKind::Tree => Color::Rgba(1.0, 1.0, 1.0, 0.0), })) - .parent(state.ids.map_layers[2]) + .parent(state.ids.map_layers[3]) .set(state.ids.mmap_site_icons_bgs[i], ui); Image::new(match &site.kind { SiteKind::Town => self.imgs.mmap_site_town, diff --git a/voxygen/src/hud/mod.rs b/voxygen/src/hud/mod.rs index 53f64343cf..6d4532f566 100644 --- a/voxygen/src/hud/mod.rs +++ b/voxygen/src/hud/mod.rs @@ -374,6 +374,7 @@ pub enum Event { ChangeAmbiance(f32), MapZoom(f64), MapDrag(Vec2), + MapShowTopoMap(bool), MapShowDifficulty(bool), MapShowTowns(bool), MapShowDungeons(bool), @@ -777,7 +778,7 @@ impl PromptDialogSettings { pub struct Hud { ui: Ui, ids: Ids, - world_map_layers: (/* Id */ Vec, Vec2), + world_map: (/* Id */ Vec, Vec2), imgs: Imgs, item_imgs: ItemImgs, fonts: Fonts, @@ -820,15 +821,11 @@ impl Hud { // Load world map let mut layers = Vec::new(); for layer in client.world_data().map_layers() { - layers.push(ui.add_graphic_with_rotations(Graphic::Image( - Arc::clone(layer), - Some(water_color), - ))); + layers.push( + ui.add_graphic_with_rotations(Graphic::Image(Arc::clone(layer), Some(water_color))), + ); } - let world_map_layers = ( - layers, - client.world_data().chunk_size().map(|e| e as u32), - ); + let world_map = (layers, client.world_data().chunk_size().map(|e| e as u32)); // Load images. let imgs = Imgs::load(&mut ui).expect("Failed to load images!"); // Load rotation images. @@ -865,7 +862,7 @@ impl Hud { Self { ui, imgs, - world_map_layers, + world_map, rot_imgs, item_imgs, fonts, @@ -2233,7 +2230,7 @@ impl Hud { client, &self.imgs, &self.rot_imgs, - &self.world_map_layers, + &self.world_map, &self.fonts, camera.get_orientation(), &global_state, @@ -2786,7 +2783,7 @@ impl Hud { client, &self.imgs, &self.rot_imgs, - &self.world_map_layers, + &self.world_map, &self.fonts, self.pulse, i18n, @@ -2801,6 +2798,9 @@ impl Hud { self.show.want_grab = true; self.force_ungrab = false; }, + map::Event::ShowTopoMap(map_show_topo_map) => { + events.push(Event::MapShowTopoMap(map_show_topo_map)); + }, map::Event::ShowDifficulties(map_show_difficulties) => { events.push(Event::MapShowDifficulty(map_show_difficulties)); }, diff --git a/voxygen/src/session.rs b/voxygen/src/session.rs index ff7c946075..e12d806ce3 100644 --- a/voxygen/src/session.rs +++ b/voxygen/src/session.rs @@ -1332,6 +1332,10 @@ impl PlayState for SessionState { global_state.settings.interface.map_drag = map_drag; global_state.settings.save_to_file_warn(); }, + HudEvent::MapShowTopoMap(map_show_topo_map) => { + global_state.settings.interface.map_show_topo_map = map_show_topo_map; + global_state.settings.save_to_file_warn(); + }, HudEvent::MapShowDifficulty(map_show_difficulty) => { global_state.settings.interface.map_show_difficulty = map_show_difficulty; global_state.settings.save_to_file_warn(); diff --git a/voxygen/src/settings.rs b/voxygen/src/settings.rs index 11c3a826ea..90531dba08 100644 --- a/voxygen/src/settings.rs +++ b/voxygen/src/settings.rs @@ -444,6 +444,7 @@ pub struct InterfaceSettings { pub ui_scale: ScaleMode, pub map_zoom: f64, pub map_drag: Vec2, + pub map_show_topo_map: bool, pub map_show_difficulty: bool, pub map_show_towns: bool, pub map_show_dungeons: bool, @@ -451,7 +452,6 @@ pub struct InterfaceSettings { pub loading_tips: bool, pub map_show_caves: bool, pub map_show_trees: bool, - pub map_show_topo: bool, pub minimap_show: bool, pub minimap_face_north: bool, } @@ -477,6 +477,7 @@ impl Default for InterfaceSettings { ui_scale: ScaleMode::RelativeToWindow([1920.0, 1080.0].into()), map_zoom: 10.0, map_drag: Vec2 { x: 0.0, y: 0.0 }, + map_show_topo_map: false, map_show_difficulty: true, map_show_towns: true, map_show_dungeons: true, @@ -484,7 +485,6 @@ impl Default for InterfaceSettings { loading_tips: true, map_show_caves: true, map_show_trees: true, - map_show_topo: false, minimap_show: true, minimap_face_north: false, } diff --git a/world/examples/water.rs b/world/examples/water.rs index e4243b7cb1..8c722dddb8 100644 --- a/world/examples/water.rs +++ b/world/examples/water.rs @@ -91,9 +91,10 @@ fn main() { } else { MapSample { alt: 0.0, - rgb: Rgb::new(0, 0, 0), + rgba: Rgba::new(0, 0, 0, 255), connections: None, downhill_wpos: (pos + 1) * TerrainChunkSize::RECT_SIZE.map(|e| e as i32), + is_path: false, } } }; @@ -178,6 +179,11 @@ fn main() { is_temperature, is_humidity, is_debug: true, + is_contours: false, + is_height_map: false, + is_political: false, + is_roads: false, + rgba_alpha: 1.0, }; if samples_changed {