Compare commits
38 Commits
d2de71a5cf
..
l10n
| Author | SHA1 | Date | |
|---|---|---|---|
| e21c4bf46e | |||
| 2dee4edd2c | |||
| 0b4aa6e90d | |||
| 3b59b0bada | |||
| 604faff238 | |||
| 26e4b637a2 | |||
| 75e3bc6f93 | |||
| 70bb125076 | |||
| e0a4fc186a | |||
| 6a9d30e8ea | |||
| 1e6a12eeda | |||
| 31912da76f | |||
| fe8896e870 | |||
| c99517572e | |||
| 0b7f30a7c4 | |||
| fcfaf043c4 | |||
| 0393a330a6 | |||
| 2fdb58bc7d | |||
| c758bda1a9 | |||
| 88e301e2a2 | |||
| 161c664e08 | |||
| a0408ec798 | |||
| 480d5586b9 | |||
| 7b49018593 | |||
| 4b447a9b9d | |||
| 443feb2bfa | |||
| 8710101a78 | |||
| 2c20148e64 | |||
| ffc0e84788 | |||
| 2d2004e447 | |||
| 4a7cfc113d | |||
| f03ad5a0e9 | |||
| 7f5b83f9d8 | |||
| 5a8f93e225 | |||
| 668b0f6b23 | |||
| fc1eb5a408 | |||
| 561c7e22b3 | |||
| ce067d4ff0 |
|
Before Width: | Height: | Size: 339 KiB After Width: | Height: | Size: 313 KiB |
|
After Width: | Height: | Size: 729 KiB |
|
After Width: | Height: | Size: 308 KiB |
|
Before Width: | Height: | Size: 1.7 MiB After Width: | Height: | Size: 525 KiB |
|
Before Width: | Height: | Size: 1.9 MiB After Width: | Height: | Size: 710 KiB |
|
Before Width: | Height: | Size: 2.8 MiB |
|
Before Width: | Height: | Size: 348 KiB |
@@ -31,10 +31,10 @@ import bikerouterGravel from './custom/bikerouter-gravel.json';
|
|||||||
export const maptilerKeyPlaceHolder = 'MAPTILER_KEY';
|
export const maptilerKeyPlaceHolder = 'MAPTILER_KEY';
|
||||||
|
|
||||||
export const basemaps: { [key: string]: string | StyleSpecification } = {
|
export const basemaps: { [key: string]: string | StyleSpecification } = {
|
||||||
maptilerStreets: `https://api.maptiler.com/maps/streets-v4/style.json?key=${maptilerKeyPlaceHolder}`,
|
libertyTopo: 'https://styles.gpx.studio/liberty-topo.json',
|
||||||
maptilerTopo: `https://api.maptiler.com/maps/topo-v4/style.json?key=${maptilerKeyPlaceHolder}`,
|
libertySatellite: 'https://styles.gpx.studio/liberty-satellite.json',
|
||||||
maptilerOutdoors: `https://api.maptiler.com/maps/outdoor-v4/style.json?key=${maptilerKeyPlaceHolder}`,
|
osm: 'https://styles.gpx.studio/osm.json',
|
||||||
maptilerSatellite: `https://api.maptiler.com/maps/hybrid-v4/style.json?key=${maptilerKeyPlaceHolder}`,
|
osmTopo: 'https://styles.gpx.studio/osm-topo.json',
|
||||||
esriSatellite: {
|
esriSatellite: {
|
||||||
version: 8,
|
version: 8,
|
||||||
sources: {
|
sources: {
|
||||||
@@ -799,10 +799,10 @@ export type LayerTreeType = { [key: string]: LayerTreeType | boolean };
|
|||||||
export const basemapTree: LayerTreeType = {
|
export const basemapTree: LayerTreeType = {
|
||||||
basemaps: {
|
basemaps: {
|
||||||
world: {
|
world: {
|
||||||
maptilerStreets: true,
|
libertyTopo: true,
|
||||||
maptilerTopo: true,
|
libertySatellite: true,
|
||||||
maptilerOutdoors: true,
|
osm: true,
|
||||||
maptilerSatellite: true,
|
osmTopo: true,
|
||||||
esriSatellite: true,
|
esriSatellite: true,
|
||||||
openStreetMap: true,
|
openStreetMap: true,
|
||||||
openTopoMap: true,
|
openTopoMap: true,
|
||||||
@@ -936,7 +936,7 @@ export const overpassTree: LayerTreeType = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Default basemap used
|
// Default basemap used
|
||||||
export const defaultBasemap = 'maptilerStreets';
|
export const defaultBasemap = 'libertyTopo';
|
||||||
|
|
||||||
// Default overlays used (none)
|
// Default overlays used (none)
|
||||||
export const defaultOverlays: LayerTreeType = {
|
export const defaultOverlays: LayerTreeType = {
|
||||||
@@ -1025,10 +1025,10 @@ export const defaultOverpassQueries: LayerTreeType = {
|
|||||||
export const defaultBasemapTree: LayerTreeType = {
|
export const defaultBasemapTree: LayerTreeType = {
|
||||||
basemaps: {
|
basemaps: {
|
||||||
world: {
|
world: {
|
||||||
maptilerStreets: true,
|
libertyTopo: true,
|
||||||
maptilerTopo: true,
|
libertySatellite: true,
|
||||||
maptilerOutdoors: true,
|
osm: true,
|
||||||
maptilerSatellite: true,
|
osmTopo: true,
|
||||||
esriSatellite: false,
|
esriSatellite: false,
|
||||||
openStreetMap: true,
|
openStreetMap: true,
|
||||||
openTopoMap: true,
|
openTopoMap: true,
|
||||||
@@ -1487,14 +1487,11 @@ export const overpassQueryData: Record<string, OverpassQueryData> = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export const terrainSources: { [key: string]: RasterDEMSourceSpecification } = {
|
export const terrainSources: { [key: string]: RasterDEMSourceSpecification } = {
|
||||||
'maptiler-dem': {
|
|
||||||
type: 'raster-dem',
|
|
||||||
url: `https://api.maptiler.com/tiles/terrain-rgb-v2/tiles.json?key=${maptilerKeyPlaceHolder}`,
|
|
||||||
},
|
|
||||||
mapterhorn: {
|
mapterhorn: {
|
||||||
type: 'raster-dem',
|
type: 'raster-dem',
|
||||||
url: 'https://tiles.mapterhorn.com/tilejson.json',
|
url: 'https://tiles.gpx.studio/mapterhorn.json',
|
||||||
|
encoding: 'terrarium',
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export const defaultTerrainSource = 'maptiler-dem';
|
export const defaultTerrainSource = 'mapterhorn';
|
||||||
|
|||||||
@@ -8,7 +8,7 @@
|
|||||||
...others
|
...others
|
||||||
}: {
|
}: {
|
||||||
iconOnly?: boolean;
|
iconOnly?: boolean;
|
||||||
company?: 'gpx.studio' | 'maptiler' | 'github' | 'crowdin' | 'facebook' | 'reddit';
|
company?: 'gpx.studio' | 'github' | 'crowdin' | 'facebook' | 'reddit';
|
||||||
[key: string]: any;
|
[key: string]: any;
|
||||||
} = $props();
|
} = $props();
|
||||||
</script>
|
</script>
|
||||||
@@ -19,12 +19,6 @@
|
|||||||
alt="Logo of gpx.studio."
|
alt="Logo of gpx.studio."
|
||||||
{...others}
|
{...others}
|
||||||
/>
|
/>
|
||||||
{:else if company === 'maptiler'}
|
|
||||||
<img
|
|
||||||
src="{base}/maptiler-logo{mode.current === 'dark' ? '-dark' : ''}.svg"
|
|
||||||
alt="Logo of Maptiler."
|
|
||||||
{...others}
|
|
||||||
/>
|
|
||||||
{:else if company === 'github'}
|
{:else if company === 'github'}
|
||||||
<svg
|
<svg
|
||||||
role="img"
|
role="img"
|
||||||
|
|||||||
@@ -1,10 +1,10 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import maptilerTopoMap from '$lib/assets/img/home/maptiler-topo.png?enhanced';
|
import topoMap from '$lib/assets/img/docs/maps/topo.png?enhanced';
|
||||||
import waymarkedMap from '$lib/assets/img/home/waymarked.png?enhanced';
|
import waymarkedMap from '$lib/assets/img/docs/maps/waymarked.png?enhanced';
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="relative h-80 aspect-square rounded-2xl shadow-xl overflow-clip">
|
<div class="relative h-80 aspect-square rounded-2xl shadow-xl overflow-clip">
|
||||||
<enhanced:img src={maptilerTopoMap} alt="MapTiler Topo map screenshot." class="absolute" />
|
<enhanced:img src={topoMap} alt="Topo map screenshot." class="absolute" />
|
||||||
<enhanced:img
|
<enhanced:img
|
||||||
src={waymarkedMap}
|
src={waymarkedMap}
|
||||||
alt="Waymarked Trails map screenshot."
|
alt="Waymarked Trails map screenshot."
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ export const defaultEmbeddingOptions = {
|
|||||||
key: '',
|
key: '',
|
||||||
files: [],
|
files: [],
|
||||||
ids: [],
|
ids: [],
|
||||||
basemap: 'maptilerStreets',
|
basemap: 'libertyTopo',
|
||||||
elevation: {
|
elevation: {
|
||||||
show: true,
|
show: true,
|
||||||
height: 170,
|
height: 170,
|
||||||
@@ -126,7 +126,7 @@ export function convertOldEmbeddingOptions(options: URLSearchParams): any {
|
|||||||
if (options.has('source')) {
|
if (options.has('source')) {
|
||||||
let basemap = options.get('source')!;
|
let basemap = options.get('source')!;
|
||||||
if (basemap === 'satellite') {
|
if (basemap === 'satellite') {
|
||||||
newOptions.basemap = 'maptilerSatellite';
|
newOptions.basemap = 'libertySatellite';
|
||||||
} else if (basemap === 'otm') {
|
} else if (basemap === 'otm') {
|
||||||
newOptions.basemap = 'openTopoMap';
|
newOptions.basemap = 'openTopoMap';
|
||||||
} else if (basemap === 'ohm') {
|
} else if (basemap === 'ohm') {
|
||||||
|
|||||||
@@ -74,7 +74,7 @@ export class DistanceMarkers {
|
|||||||
layout: {
|
layout: {
|
||||||
'text-field': ['get', 'distance'],
|
'text-field': ['get', 'distance'],
|
||||||
'text-size': 14,
|
'text-size': 14,
|
||||||
'text-font': ['Open Sans Bold'],
|
'text-font': ['Noto Sans Bold'],
|
||||||
},
|
},
|
||||||
paint: {
|
paint: {
|
||||||
'text-color': 'black',
|
'text-color': 'black',
|
||||||
|
|||||||
@@ -251,11 +251,11 @@ export class GPXLayer {
|
|||||||
source: this.fileId,
|
source: this.fileId,
|
||||||
layout: {
|
layout: {
|
||||||
'text-field': '»',
|
'text-field': '»',
|
||||||
'text-offset': [0, -0.06],
|
'text-offset': [0, -0.1],
|
||||||
'text-keep-upright': false,
|
'text-keep-upright': false,
|
||||||
'text-max-angle': 361,
|
'text-max-angle': 361,
|
||||||
'text-allow-overlap': true,
|
'text-allow-overlap': true,
|
||||||
'text-font': ['Open Sans Bold'],
|
'text-font': ['Noto Sans Bold'],
|
||||||
'symbol-placement': 'line',
|
'symbol-placement': 'line',
|
||||||
'symbol-spacing': 20,
|
'symbol-spacing': 20,
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -24,7 +24,7 @@ liveQuery(() => db.overpassdata.toArray()).subscribe((pois) => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
export class OverpassLayer {
|
export class OverpassLayer {
|
||||||
overpassUrl = 'https://overpass.private.coffee/api/interpreter';
|
overpassUrl = 'https://overpass.gpx.studio/api/interpreter';
|
||||||
minZoom = 12;
|
minZoom = 12;
|
||||||
queryZoom = 12;
|
queryZoom = 12;
|
||||||
expirationTime = 7 * 24 * 3600 * 1000;
|
expirationTime = 7 * 24 * 3600 * 1000;
|
||||||
|
|||||||
@@ -10,7 +10,8 @@ import {
|
|||||||
import { getLayers } from '$lib/components/map/layer-control/utils';
|
import { getLayers } from '$lib/components/map/layer-control/utils';
|
||||||
import { i18n } from '$lib/i18n.svelte';
|
import { i18n } from '$lib/i18n.svelte';
|
||||||
|
|
||||||
const { currentBasemap, currentOverlays, customLayers, opacities, terrainSource } = settings;
|
const { currentBasemap, currentOverlays, customLayers, opacities, terrainSource, distanceUnits } =
|
||||||
|
settings;
|
||||||
|
|
||||||
const emptySource: maplibregl.GeoJSONSourceSpecification = {
|
const emptySource: maplibregl.GeoJSONSourceSpecification = {
|
||||||
type: 'geojson',
|
type: 'geojson',
|
||||||
@@ -57,15 +58,24 @@ export class StyleManager {
|
|||||||
opacities.subscribe(() => this.updateOverlays());
|
opacities.subscribe(() => this.updateOverlays());
|
||||||
terrainSource.subscribe(() => this.updateTerrain());
|
terrainSource.subscribe(() => this.updateTerrain());
|
||||||
customLayers.subscribe(() => this.updateBasemap());
|
customLayers.subscribe(() => this.updateBasemap());
|
||||||
|
distanceUnits.subscribe(() => {
|
||||||
|
const map = get(this._map);
|
||||||
|
if (map && (map.getLayer('contours_m') || map.getLayer('contours_ft'))) {
|
||||||
|
this.updateBasemap();
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
updateBasemap() {
|
updateBasemap() {
|
||||||
const map_ = get(this._map);
|
const map_ = get(this._map);
|
||||||
if (!map_) return;
|
if (!map_) return;
|
||||||
this.buildStyle().then((style) => map_.setStyle(style));
|
let basemap = get(currentBasemap);
|
||||||
|
this.buildStyle(basemap).then((style) => {
|
||||||
|
if (get(currentBasemap) === basemap) map_.setStyle(style);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
async buildStyle(): Promise<maplibregl.StyleSpecification> {
|
async buildStyle(basemap: string): Promise<maplibregl.StyleSpecification> {
|
||||||
const custom = get(customLayers);
|
const custom = get(customLayers);
|
||||||
|
|
||||||
const style: maplibregl.StyleSpecification = {
|
const style: maplibregl.StyleSpecification = {
|
||||||
@@ -79,22 +89,31 @@ export class StyleManager {
|
|||||||
layers: [],
|
layers: [],
|
||||||
};
|
};
|
||||||
|
|
||||||
let basemap = get(currentBasemap);
|
|
||||||
const basemapInfo = basemaps[basemap] ?? custom[basemap]?.value ?? basemaps[defaultBasemap];
|
const basemapInfo = basemaps[basemap] ?? custom[basemap]?.value ?? basemaps[defaultBasemap];
|
||||||
|
|
||||||
let basemapStyle = basemaps.openStreetMap as maplibregl.StyleSpecification;
|
let basemapStyle = basemaps.openStreetMap as maplibregl.StyleSpecification;
|
||||||
try {
|
try {
|
||||||
basemapStyle = await this.get(basemapInfo);
|
basemapStyle = await this.get(basemapInfo);
|
||||||
|
for (const source in basemapStyle.sources) {
|
||||||
|
const src = basemapStyle.sources[source];
|
||||||
|
if (
|
||||||
|
src &&
|
||||||
|
typeof src === 'object' &&
|
||||||
|
'url' in src &&
|
||||||
|
typeof src.url === 'string' &&
|
||||||
|
src.url.includes(maptilerKeyPlaceHolder)
|
||||||
|
) {
|
||||||
|
src.url = src.url.replace(maptilerKeyPlaceHolder, this._maptilerKey);
|
||||||
|
}
|
||||||
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error(e.message);
|
console.error(e.message);
|
||||||
}
|
}
|
||||||
this.merge(style, basemapStyle);
|
this.merge(style, basemapStyle);
|
||||||
|
|
||||||
if (this._maptilerKey !== '') {
|
const terrain = this.getCurrentTerrain();
|
||||||
const terrain = this.getCurrentTerrain();
|
style.sources[terrain.source] = terrainSources[terrain.source];
|
||||||
style.sources[terrain.source] = terrainSources[terrain.source];
|
style.terrain = terrain.exaggeration > 0 ? terrain : undefined;
|
||||||
style.terrain = terrain.exaggeration > 0 ? terrain : undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
style.layers.push(...anchorLayers);
|
style.layers.push(...anchorLayers);
|
||||||
|
|
||||||
@@ -166,7 +185,6 @@ export class StyleManager {
|
|||||||
}
|
}
|
||||||
|
|
||||||
updateTerrain() {
|
updateTerrain() {
|
||||||
if (this._maptilerKey === '') return;
|
|
||||||
const map_ = get(this._map);
|
const map_ = get(this._map);
|
||||||
if (!map_) return;
|
if (!map_) return;
|
||||||
|
|
||||||
@@ -189,9 +207,6 @@ export class StyleManager {
|
|||||||
): Promise<maplibregl.StyleSpecification> {
|
): Promise<maplibregl.StyleSpecification> {
|
||||||
if (typeof styleInfo === 'string') {
|
if (typeof styleInfo === 'string') {
|
||||||
let styleUrl = styleInfo as string;
|
let styleUrl = styleInfo as string;
|
||||||
if (styleUrl.includes(maptilerKeyPlaceHolder)) {
|
|
||||||
styleUrl = styleUrl.replace(maptilerKeyPlaceHolder, this._maptilerKey);
|
|
||||||
}
|
|
||||||
const response = await fetch(styleUrl, { cache: 'force-cache' });
|
const response = await fetch(styleUrl, { cache: 'force-cache' });
|
||||||
if (!response.ok) {
|
if (!response.ok) {
|
||||||
throw new Error(`HTTP error fetching style "${styleInfo}": ${response.status}`);
|
throw new Error(`HTTP error fetching style "${styleInfo}": ${response.status}`);
|
||||||
@@ -205,23 +220,46 @@ export class StyleManager {
|
|||||||
|
|
||||||
merge(style: maplibregl.StyleSpecification, other: maplibregl.StyleSpecification) {
|
merge(style: maplibregl.StyleSpecification, other: maplibregl.StyleSpecification) {
|
||||||
style.sources = { ...style.sources, ...other.sources };
|
style.sources = { ...style.sources, ...other.sources };
|
||||||
|
const units = get(distanceUnits);
|
||||||
for (let layer of other.layers ?? []) {
|
for (let layer of other.layers ?? []) {
|
||||||
|
if ('source' in layer) {
|
||||||
|
if (layer.source == 'contours_m' && units === 'imperial') continue;
|
||||||
|
if (layer.source == 'contours_ft' && units !== 'imperial') continue;
|
||||||
|
}
|
||||||
if (layer.type === 'symbol' && layer.layout && layer.layout['text-field']) {
|
if (layer.type === 'symbol' && layer.layout && layer.layout['text-field']) {
|
||||||
const textField = layer.layout['text-field'];
|
const textField = layer.layout['text-field'];
|
||||||
if (
|
if (Array.isArray(textField)) {
|
||||||
Array.isArray(textField) &&
|
if (
|
||||||
textField.length >= 2 &&
|
textField.length == 4 &&
|
||||||
textField[0] === 'coalesce' &&
|
Array.isArray(textField[3]) &&
|
||||||
Array.isArray(textField[1]) &&
|
textField[3][0] === 'coalesce' &&
|
||||||
textField[1][0] === 'get' &&
|
Array.isArray(textField[3][1]) &&
|
||||||
typeof textField[1][1] === 'string' &&
|
textField[3][1][0] === 'get' &&
|
||||||
textField[1][1].startsWith('name')
|
typeof textField[3][1][1] === 'string' &&
|
||||||
) {
|
textField[3][1][1].startsWith('name')
|
||||||
layer.layout['text-field'] = [
|
) {
|
||||||
'coalesce',
|
// OpenFreeMap styles
|
||||||
['get', `name:${i18n.lang}`],
|
layer.layout['text-field'] = [
|
||||||
['get', 'name'],
|
'coalesce',
|
||||||
];
|
['get', `name:${i18n.lang}`],
|
||||||
|
['get', 'name'],
|
||||||
|
];
|
||||||
|
}
|
||||||
|
if (
|
||||||
|
textField.length == 3 &&
|
||||||
|
textField[0] === 'coalesce' &&
|
||||||
|
Array.isArray(textField[1]) &&
|
||||||
|
textField[1][0] === 'get' &&
|
||||||
|
typeof textField[1][1] === 'string' &&
|
||||||
|
textField[1][1].startsWith('name')
|
||||||
|
) {
|
||||||
|
// OpenMapTiles styles
|
||||||
|
layer.layout['text-field'] = [
|
||||||
|
'coalesce',
|
||||||
|
['get', `name:${i18n.lang}`],
|
||||||
|
['get', 'name'],
|
||||||
|
];
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
style.layers.push(layer);
|
style.layers.push(layer);
|
||||||
@@ -236,10 +274,6 @@ export class StyleManager {
|
|||||||
|
|
||||||
getCurrentTerrain() {
|
getCurrentTerrain() {
|
||||||
const terrain = get(terrainSource);
|
const terrain = get(terrainSource);
|
||||||
const source = terrainSources[terrain];
|
|
||||||
if (source.url && source.url.includes(maptilerKeyPlaceHolder)) {
|
|
||||||
source.url = source.url.replace(maptilerKeyPlaceHolder, this._maptilerKey);
|
|
||||||
}
|
|
||||||
const map_ = get(this._map);
|
const map_ = get(this._map);
|
||||||
return {
|
return {
|
||||||
source: terrain,
|
source: terrain,
|
||||||
|
|||||||
@@ -59,7 +59,7 @@ Only one basemap can be displayed at a time.
|
|||||||
<DocsLayers />
|
<DocsLayers />
|
||||||
<span class="text-sm text-center mt-2">
|
<span class="text-sm text-center mt-2">
|
||||||
|
|
||||||
Hover over the map to show the <a href="https://hiking.waymarkedtrails.org" target="_blank">Waymarked Trails hiking</a> overlay on top of the <a href="https://www.maptiler.com/maps/outdoor-topo/" target="_blank">MapTiler Topo</a> basemap.
|
Hover over the map to show the <a href="https://hiking.waymarkedtrails.org" target="_blank">Waymarked Trails hiking</a> overlay on top of the topographic basemap.
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ This tool allows you to add elevation data to traces and [points of interest](..
|
|||||||
|
|
||||||
<DocsNote>
|
<DocsNote>
|
||||||
|
|
||||||
Elevation data is provided by <a href="https://maptiler.com" target="_blank">MapTiler</a>.
|
Elevation data is provided by <a href="https://mapterhorn.com" target="_blank">Mapterhorn</a>.
|
||||||
You can learn more about its origin and accuracy in the <a href="https://docs.maptiler.com/guides/map-tiling-hosting/data-hosting/rgb-terrain-by-maptiler/" target="_blank">documentation</a>.
|
You can learn more about its origin and accuracy in the <a href="https://mapterhorn.com/attribution/" target="_blank">documentation</a>.
|
||||||
|
|
||||||
</DocsNote>
|
</DocsNote>
|
||||||
@@ -59,7 +59,7 @@ Met de kaartlagen knop kun je wisselen tussen verschillende basiskaarten, en kaa
|
|||||||
<DocsLayers />
|
<DocsLayers />
|
||||||
<span class="text-sm text-center mt-2">
|
<span class="text-sm text-center mt-2">
|
||||||
|
|
||||||
Hover over the map to show the <a href="https://hiking.waymarkedtrails.org" target="_blank">Waymarked Trails hiking</a> overlay on top of the topographic basemap.
|
Beweeg over de kaart om de <a href="https://hiking.waymarkedtrails.org" target="_blank">Gemarkeerde sporen wandelen</a> overlay te tonen bovenop de topografische basiskaart.
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -13,9 +13,9 @@ title: Instellingen
|
|||||||
|
|
||||||
Wijzig de eenheden die worden gebruikt om afstanden in de interface weer te geven.
|
Wijzig de eenheden die worden gebruikt om afstanden in de interface weer te geven.
|
||||||
|
|
||||||
### <Zap size="16" class="inline-block" style="margin-bottom: 2px" /> Snelheids eenheden
|
### <Zap size="16" class="inline-block" style="margin-bottom: 2px" /> Snelheidseenheden
|
||||||
|
|
||||||
Verander de eenheden die worden gebruikt om velocities in de interface weer te geven.
|
Verander de eenheden die worden gebruikt om snelheden in de interface weer te geven.
|
||||||
Je kunt kiezen tussen afstand per uur of minuten per afstand, wat geschikter kan zijn voor het uitvoeren van activiteiten.
|
Je kunt kiezen tussen afstand per uur of minuten per afstand, wat geschikter kan zijn voor het uitvoeren van activiteiten.
|
||||||
|
|
||||||
### <Thermometer size="16" class="inline-block" style="margin-bottom: 2px" /> Temperatuureenheden
|
### <Thermometer size="16" class="inline-block" style="margin-bottom: 2px" /> Temperatuureenheden
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ Met dit gereedschap kun je hoogtegegevens toevoegen aan sporen en [interessante
|
|||||||
|
|
||||||
<DocsNote>
|
<DocsNote>
|
||||||
|
|
||||||
Elevation data is provided by <a href="https://mapterhorn.com" target="_blank">Mapterhorn</a>.
|
Hoogtegegevens worden verstrekt door <a href="https://maptiler.com" target="_blank">Mapterhorn</a>.
|
||||||
You can learn more about its origin and accuracy in the <a href="https://mapterhorn.com/attribution/" target="_blank">documentation</a>.
|
Je kunt meer leren over de oorsprong en nauwkeurigheid in de <a href="https://mapterhorn.com/attribution/" target="_blank">documentatie</a>.
|
||||||
|
|
||||||
</DocsNote>
|
</DocsNote>
|
||||||
|
|||||||
@@ -59,7 +59,7 @@ title: 地图控件
|
|||||||
<DocsLayers />
|
<DocsLayers />
|
||||||
<span class="text-sm text-center mt-2">
|
<span class="text-sm text-center mt-2">
|
||||||
|
|
||||||
Hover over the map to show the <a href="https://hiking.waymarkedtrails.org" target="_blank">Waymarked Trails hiking</a> overlay on top of the topographic basemap.
|
鼠标悬停在地图上,可在地形图底图上方显示 <a href="https://hiking.waymarkedtrails.org" target="_blank">Waymarked Trails 徒步路线</a> 叠加层。
|
||||||
|
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@@ -18,7 +18,7 @@ title: 请求海拔数据
|
|||||||
|
|
||||||
<DocsNote>
|
<DocsNote>
|
||||||
|
|
||||||
Elevation data is provided by <a href="https://mapterhorn.com" target="_blank">Mapterhorn</a>.
|
海拔数据来自 <a href="https://mapterhorn.com" target="_blank">Mapterhorn</a> ,
|
||||||
You can learn more about its origin and accuracy in the <a href="https://mapterhorn.com/attribution/" target="_blank">documentation</a>.
|
查阅 <a href="https://mapterhorn.com/attribution/" target="_blank">官方文档</a> 以了解海拔数据来源及其准确度。
|
||||||
|
|
||||||
</DocsNote>
|
</DocsNote>
|
||||||
|
|||||||
@@ -210,7 +210,7 @@ type RoutingProfile =
|
|||||||
| 'motorcycle'
|
| 'motorcycle'
|
||||||
| 'water'
|
| 'water'
|
||||||
| 'railway';
|
| 'railway';
|
||||||
type TerrainSource = 'maptiler-dem' | 'mapterhorn';
|
type TerrainSource = 'mapterhorn';
|
||||||
type StreetViewSource = 'mapillary' | 'google';
|
type StreetViewSource = 'mapillary' | 'google';
|
||||||
|
|
||||||
export const settings = {
|
export const settings = {
|
||||||
@@ -308,7 +308,7 @@ export const settings = {
|
|||||||
terrainSource: new Setting<TerrainSource>(
|
terrainSource: new Setting<TerrainSource>(
|
||||||
'terrainSource',
|
'terrainSource',
|
||||||
defaultTerrainSource,
|
defaultTerrainSource,
|
||||||
getValueValidator(['maptiler-dem', 'mapterhorn'], defaultTerrainSource)
|
getValueValidator(['mapterhorn'], defaultTerrainSource)
|
||||||
),
|
),
|
||||||
directionMarkers: new Setting('directionMarkers', false),
|
directionMarkers: new Setting('directionMarkers', false),
|
||||||
distanceMarkers: new Setting('distanceMarkers', false),
|
distanceMarkers: new Setting('distanceMarkers', false),
|
||||||
|
|||||||
@@ -7,7 +7,6 @@ import maplibregl from 'maplibre-gl';
|
|||||||
import { pointToTile, pointToTileFraction } from '@mapbox/tilebelt';
|
import { pointToTile, pointToTileFraction } from '@mapbox/tilebelt';
|
||||||
import type { GPXStatisticsTree } from '$lib/logic/statistics-tree';
|
import type { GPXStatisticsTree } from '$lib/logic/statistics-tree';
|
||||||
import { ListTrackSegmentItem } from '$lib/components/file-list/file-list';
|
import { ListTrackSegmentItem } from '$lib/components/file-list/file-list';
|
||||||
import { PUBLIC_MAPTILER_KEY } from '$env/static/public';
|
|
||||||
|
|
||||||
export function cn(...inputs: ClassValue[]) {
|
export function cn(...inputs: ClassValue[]) {
|
||||||
return twMerge(clsx(inputs));
|
return twMerge(clsx(inputs));
|
||||||
@@ -101,7 +100,7 @@ export function getClosestTrackSegments(
|
|||||||
|
|
||||||
export function getElevation(
|
export function getElevation(
|
||||||
points: (TrackPoint | Waypoint | Coordinates)[],
|
points: (TrackPoint | Waypoint | Coordinates)[],
|
||||||
ELEVATION_ZOOM: number = 13,
|
ELEVATION_ZOOM: number = 12,
|
||||||
tileSize = 512
|
tileSize = 512
|
||||||
): Promise<number[]> {
|
): Promise<number[]> {
|
||||||
let coordinates = points.map((point) =>
|
let coordinates = points.map((point) =>
|
||||||
@@ -122,10 +121,9 @@ export function getElevation(
|
|||||||
};
|
};
|
||||||
|
|
||||||
let promises = uniqueTiles.map((tile) =>
|
let promises = uniqueTiles.map((tile) =>
|
||||||
fetch(
|
fetch(`https://tiles.gpx.studio/mapterhorn/${ELEVATION_ZOOM}/${tile[0]}/${tile[1]}.webp`, {
|
||||||
`https://api.maptiler.com/tiles/terrain-rgb-v2/${ELEVATION_ZOOM}/${tile[0]}/${tile[1]}.webp?key=${PUBLIC_MAPTILER_KEY}`,
|
cache: 'force-cache',
|
||||||
{ cache: 'force-cache' }
|
})
|
||||||
)
|
|
||||||
.then((response) => response.blob())
|
.then((response) => response.blob())
|
||||||
.then(
|
.then(
|
||||||
(blob) =>
|
(blob) =>
|
||||||
@@ -180,10 +178,10 @@ export function getElevation(
|
|||||||
_y + (_y + 1 == tileSize ? 0 : 1)
|
_y + (_y + 1 == tileSize ? 0 : 1)
|
||||||
);
|
);
|
||||||
|
|
||||||
let ele00 = -10000 + (p00[0] * 256 * 256 + p00[1] * 256 + p00[2]) * 0.1;
|
let ele00 = -32768 + p00[0] * 256 + p00[1] + p00[2] / 256;
|
||||||
let ele01 = -10000 + (p01[0] * 256 * 256 + p01[1] * 256 + p01[2]) * 0.1;
|
let ele01 = -32768 + p01[0] * 256 + p01[1] + p01[2] / 256;
|
||||||
let ele10 = -10000 + (p10[0] * 256 * 256 + p10[1] * 256 + p10[2]) * 0.1;
|
let ele10 = -32768 + p10[0] * 256 + p10[1] + p10[2] / 256;
|
||||||
let ele11 = -10000 + (p11[0] * 256 * 256 + p11[1] * 256 + p11[2]) * 0.1;
|
let ele11 = -32768 + p11[0] * 256 + p11[1] + p11[2] / 256;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
ele00 * (1 - dx) * (1 - dy) +
|
ele00 * (1 - dx) * (1 - dy) +
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Suïssa",
|
"switzerland": "Suïssa",
|
||||||
"united_kingdom": "Regne Unit",
|
"united_kingdom": "Regne Unit",
|
||||||
"united_states": "Estats Units",
|
"united_states": "Estats Units",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Švýcarsko",
|
"switzerland": "Švýcarsko",
|
||||||
"united_kingdom": "Velká Británie",
|
"united_kingdom": "Velká Británie",
|
||||||
"united_states": "Spojené státy",
|
"united_states": "Spojené státy",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Schweiz",
|
"switzerland": "Schweiz",
|
||||||
"united_kingdom": "Großbritannien",
|
"united_kingdom": "Großbritannien",
|
||||||
"united_states": "USA",
|
"united_states": "USA",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -235,7 +235,7 @@
|
|||||||
},
|
},
|
||||||
"elevation": {
|
"elevation": {
|
||||||
"button": "Request elevation data",
|
"button": "Request elevation data",
|
||||||
"help": "Requesting elevation data will erase the existing elevation data, if any, and replace it with data from MapTiler.",
|
"help": "Requesting elevation data will erase the existing elevation data, if any, and replace it with data from Mapterhorn.",
|
||||||
"help_no_selection": "Select a file item to request elevation data."
|
"help_no_selection": "Select a file item to request elevation data."
|
||||||
},
|
},
|
||||||
"waypoint": {
|
"waypoint": {
|
||||||
@@ -304,10 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"maptilerStreets": "MapTiler Streets",
|
"libertyTopo": "Liberty Topo",
|
||||||
"maptilerTopo": "MapTiler Topo",
|
"libertySatellite": "Liberty Satellite",
|
||||||
"maptilerOutdoors": "MapTiler Outdoors",
|
"osm": "OpenMapTiles OSM",
|
||||||
"maptilerSatellite": "MapTiler Satellite",
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
@@ -388,7 +388,6 @@
|
|||||||
"tram-stop": "Tram Stop",
|
"tram-stop": "Tram Stop",
|
||||||
"bus-stop": "Bus Stop",
|
"bus-stop": "Bus Stop",
|
||||||
"ferry": "Ferry",
|
"ferry": "Ferry",
|
||||||
"maptiler-dem": "MapTiler DEM",
|
|
||||||
"mapterhorn": "Mapterhorn"
|
"mapterhorn": "Mapterhorn"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Suiza",
|
"switzerland": "Suiza",
|
||||||
"united_kingdom": "Reino Unido",
|
"united_kingdom": "Reino Unido",
|
||||||
"united_states": "Estados Unidos",
|
"united_states": "Estados Unidos",
|
||||||
"topo": "Topográfico",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satélite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Suitza",
|
"switzerland": "Suitza",
|
||||||
"united_kingdom": "Erresuma Batua",
|
"united_kingdom": "Erresuma Batua",
|
||||||
"united_states": "Ameriketako Estatu Batuak",
|
"united_states": "Ameriketako Estatu Batuak",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Sveitsi",
|
"switzerland": "Sveitsi",
|
||||||
"united_kingdom": "Iso-Britannia",
|
"united_kingdom": "Iso-Britannia",
|
||||||
"united_states": "Yhdysvallat",
|
"united_states": "Yhdysvallat",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Suisse",
|
"switzerland": "Suisse",
|
||||||
"united_kingdom": "Royaume-Uni",
|
"united_kingdom": "Royaume-Uni",
|
||||||
"united_states": "États-Unis",
|
"united_states": "États-Unis",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Svájc",
|
"switzerland": "Svájc",
|
||||||
"united_kingdom": "Anglia",
|
"united_kingdom": "Anglia",
|
||||||
"united_states": "Amerika",
|
"united_states": "Amerika",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Swiss",
|
"switzerland": "Swiss",
|
||||||
"united_kingdom": "Britania Raya",
|
"united_kingdom": "Britania Raya",
|
||||||
"united_states": "Amerika Serikat",
|
"united_states": "Amerika Serikat",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Svizzera",
|
"switzerland": "Svizzera",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "Stati Uniti",
|
"united_states": "Stati Uniti",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "스위스",
|
"switzerland": "스위스",
|
||||||
"united_kingdom": "영국",
|
"united_kingdom": "영국",
|
||||||
"united_states": "미국",
|
"united_states": "미국",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "오픈스트리트맵",
|
"openStreetMap": "오픈스트리트맵",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Šveicarija",
|
"switzerland": "Šveicarija",
|
||||||
"united_kingdom": "Jungtinė Karalystė",
|
"united_kingdom": "Jungtinė Karalystė",
|
||||||
"united_states": "Jungtinės Amerikos Valstijos",
|
"united_states": "Jungtinės Amerikos Valstijos",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -235,7 +235,7 @@
|
|||||||
},
|
},
|
||||||
"elevation": {
|
"elevation": {
|
||||||
"button": "Hoogtegegevens opvragen",
|
"button": "Hoogtegegevens opvragen",
|
||||||
"help": "Requesting elevation data will erase the existing elevation data, if any, and replace it with data from Mapterhorn.",
|
"help": "Het opvragen van hoogtegegevens verwijdert de bestaande hoogtegegevens, indien aanwezig, en vervangt deze door gegevens van Mapterhorn.",
|
||||||
"help_no_selection": "Selecteer een bestand om hoogte gegevens op te vragen."
|
"help_no_selection": "Selecteer een bestand om hoogte gegevens op te vragen."
|
||||||
},
|
},
|
||||||
"waypoint": {
|
"waypoint": {
|
||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Zwitserland",
|
"switzerland": "Zwitserland",
|
||||||
"united_kingdom": "Verenigd Koninkrijk",
|
"united_kingdom": "Verenigd Koninkrijk",
|
||||||
"united_states": "Verenigde Staten",
|
"united_states": "Verenigde Staten",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satelliet",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Sveits",
|
"switzerland": "Sveits",
|
||||||
"united_kingdom": "Storbritannia",
|
"united_kingdom": "Storbritannia",
|
||||||
"united_states": "USA",
|
"united_states": "USA",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Szwajcaria",
|
"switzerland": "Szwajcaria",
|
||||||
"united_kingdom": "Wielka Brytania",
|
"united_kingdom": "Wielka Brytania",
|
||||||
"united_states": "Stany Zjednoczone",
|
"united_states": "Stany Zjednoczone",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Suíça",
|
"switzerland": "Suíça",
|
||||||
"united_kingdom": "Reino Unido",
|
"united_kingdom": "Reino Unido",
|
||||||
"united_states": "Estados Unidos",
|
"united_states": "Estados Unidos",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Suíça",
|
"switzerland": "Suíça",
|
||||||
"united_kingdom": "Reino Unido",
|
"united_kingdom": "Reino Unido",
|
||||||
"united_states": "Estados Unidos",
|
"united_states": "Estados Unidos",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -28,7 +28,7 @@
|
|||||||
"undo": "Anulează",
|
"undo": "Anulează",
|
||||||
"redo": "Refă",
|
"redo": "Refă",
|
||||||
"delete": "Șterge",
|
"delete": "Șterge",
|
||||||
"delete_all": "Delete all",
|
"delete_all": "Șterge tot",
|
||||||
"select_all": "Selectează tot",
|
"select_all": "Selectează tot",
|
||||||
"view": "Vizualizare",
|
"view": "Vizualizare",
|
||||||
"elevation_profile": "Profil de altitudine",
|
"elevation_profile": "Profil de altitudine",
|
||||||
@@ -36,7 +36,7 @@
|
|||||||
"switch_basemap": "Comutați la harta de bază anterioară",
|
"switch_basemap": "Comutați la harta de bază anterioară",
|
||||||
"toggle_overlays": "Comută suprapunerile",
|
"toggle_overlays": "Comută suprapunerile",
|
||||||
"toggle_3d": "Comută 3D",
|
"toggle_3d": "Comută 3D",
|
||||||
"fullscreen": "Full screen",
|
"fullscreen": "Ecran complet",
|
||||||
"settings": "Setări",
|
"settings": "Setări",
|
||||||
"distance_units": "Unități de distanță",
|
"distance_units": "Unități de distanță",
|
||||||
"metric": "Metric",
|
"metric": "Metric",
|
||||||
@@ -62,46 +62,46 @@
|
|||||||
"more": "Mai multe...",
|
"more": "Mai multe...",
|
||||||
"donate": "Donați",
|
"donate": "Donați",
|
||||||
"ctrl": "Ctrl",
|
"ctrl": "Ctrl",
|
||||||
"click": "Click",
|
"click": "Clic",
|
||||||
"drag": "Drag",
|
"drag": "Drag",
|
||||||
"right_click_drag": "Right-click drag",
|
"right_click_drag": "Right-click drag",
|
||||||
"metadata": {
|
"metadata": {
|
||||||
"button": "Info...",
|
"button": "Informații...",
|
||||||
"name": "Name",
|
"name": "Nume",
|
||||||
"description": "Descriere",
|
"description": "Descriere",
|
||||||
"save": "Save"
|
"save": "Salvează"
|
||||||
},
|
},
|
||||||
"style": {
|
"style": {
|
||||||
"button": "Aspect...",
|
"button": "Aspect...",
|
||||||
"color": "Color",
|
"color": "Culoare",
|
||||||
"opacity": "Opacitate",
|
"opacity": "Opacitate",
|
||||||
"width": "Width"
|
"width": "Lățime"
|
||||||
},
|
},
|
||||||
"hide": "Ascunde",
|
"hide": "Ascunde",
|
||||||
"unhide": "Dezvăluie",
|
"unhide": "Dezvăluie",
|
||||||
"center": "Center",
|
"center": "Centrează",
|
||||||
"open_in": "Open in",
|
"open_in": "Deschide în",
|
||||||
"copy_coordinates": "Copiază coordonatele",
|
"copy_coordinates": "Copiază coordonatele",
|
||||||
"edit_osm": "Edit in OpenStreetMap"
|
"edit_osm": "Editează în OpenStreetMap"
|
||||||
},
|
},
|
||||||
"toolbar": {
|
"toolbar": {
|
||||||
"routing": {
|
"routing": {
|
||||||
"tooltip": "Planifică sau editează o rută",
|
"tooltip": "Planifică sau editează o rută",
|
||||||
"activity": "Activitate",
|
"activity": "Activitate",
|
||||||
"use_routing": "Rutare",
|
"use_routing": "Rutare",
|
||||||
"use_routing_tooltip": "Connect anchor points via road network, or in a straight line if disabled",
|
"use_routing_tooltip": "Conectează puncte de ancorare prin rețeaua rutieră sau în linie dreaptă dacă este dezactivată",
|
||||||
"allow_private": "Allow private roads",
|
"allow_private": "Permite drumuri private",
|
||||||
"reverse": {
|
"reverse": {
|
||||||
"button": "Reverse",
|
"button": "Inversează",
|
||||||
"tooltip": "Reverse the direction of the route"
|
"tooltip": "Reverse the direction of the route"
|
||||||
},
|
},
|
||||||
"route_back_to_start": {
|
"route_back_to_start": {
|
||||||
"button": "Back to start",
|
"button": "Înapoi la punctul de plecare",
|
||||||
"tooltip": "Connect the last point of the route with the starting point"
|
"tooltip": "Conectează ultimul punct al rutei cu punctul de plecare"
|
||||||
},
|
},
|
||||||
"round_trip": {
|
"round_trip": {
|
||||||
"button": "Round trip",
|
"button": "Călătorie dus-întors",
|
||||||
"tooltip": "Return to the starting point by the same route"
|
"tooltip": "Întoarce-te la punctul de plecare pe aceeași rută"
|
||||||
},
|
},
|
||||||
"start_loop_here": "Start loop here",
|
"start_loop_here": "Start loop here",
|
||||||
"help_no_file": "Select a trace to use the routing tool, or click on the map to start creating a new route.",
|
"help_no_file": "Select a trace to use the routing tool, or click on the map to start creating a new route.",
|
||||||
@@ -120,7 +120,7 @@
|
|||||||
"unknown": "Necunoscut",
|
"unknown": "Necunoscut",
|
||||||
"paved": "Asfaltat",
|
"paved": "Asfaltat",
|
||||||
"unpaved": "Unpaved",
|
"unpaved": "Unpaved",
|
||||||
"asphalt": "Asphalt",
|
"asphalt": "Asfalt",
|
||||||
"concrete": "Concrete",
|
"concrete": "Concrete",
|
||||||
"cobblestone": "Pavaj",
|
"cobblestone": "Pavaj",
|
||||||
"paving_stones": "Pavaj din pietre",
|
"paving_stones": "Pavaj din pietre",
|
||||||
@@ -140,11 +140,11 @@
|
|||||||
"grass": "Iarbă",
|
"grass": "Iarbă",
|
||||||
"grass_paver": "Pavaj cu iarbă",
|
"grass_paver": "Pavaj cu iarbă",
|
||||||
"clay": "Clay",
|
"clay": "Clay",
|
||||||
"stone": "Stone"
|
"stone": "Piatră"
|
||||||
},
|
},
|
||||||
"highway": {
|
"highway": {
|
||||||
"unknown": "Unknown",
|
"unknown": "Necunoscut",
|
||||||
"motorway": "Highway",
|
"motorway": "Autostradă",
|
||||||
"motorway_link": "Highway link",
|
"motorway_link": "Highway link",
|
||||||
"trunk": "Primary road",
|
"trunk": "Primary road",
|
||||||
"trunk_link": "Primary road link",
|
"trunk_link": "Primary road link",
|
||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Elveția",
|
"switzerland": "Elveția",
|
||||||
"united_kingdom": "Regatul Unit",
|
"united_kingdom": "Regatul Unit",
|
||||||
"united_states": "Statele Unite ale Americii",
|
"united_states": "Statele Unite ale Americii",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Швейцария",
|
"switzerland": "Швейцария",
|
||||||
"united_kingdom": "Великобритания",
|
"united_kingdom": "Великобритания",
|
||||||
"united_states": "Соединенные Штаты Америки",
|
"united_states": "Соединенные Штаты Америки",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Švajcarska",
|
"switzerland": "Švajcarska",
|
||||||
"united_kingdom": "Ujedinjeno Kraljevstvo",
|
"united_kingdom": "Ujedinjeno Kraljevstvo",
|
||||||
"united_states": "Sjеdinjеnе Američke Državе",
|
"united_states": "Sjеdinjеnе Američke Državе",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Schweiz",
|
"switzerland": "Schweiz",
|
||||||
"united_kingdom": "Storbritannien",
|
"united_kingdom": "Storbritannien",
|
||||||
"united_states": "USA",
|
"united_states": "USA",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "İsviçre",
|
"switzerland": "İsviçre",
|
||||||
"united_kingdom": "Birleşik Krallık",
|
"united_kingdom": "Birleşik Krallık",
|
||||||
"united_states": "Birlişik Devletler",
|
"united_states": "Birlişik Devletler",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Швейцарія",
|
"switzerland": "Швейцарія",
|
||||||
"united_kingdom": "Велика Британія\nВеликобританія",
|
"united_kingdom": "Велика Британія\nВеликобританія",
|
||||||
"united_states": "Сполучені Штати",
|
"united_states": "Сполучені Штати",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "Switzerland",
|
"switzerland": "Switzerland",
|
||||||
"united_kingdom": "United Kingdom",
|
"united_kingdom": "United Kingdom",
|
||||||
"united_states": "United States",
|
"united_states": "United States",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -235,7 +235,7 @@
|
|||||||
},
|
},
|
||||||
"elevation": {
|
"elevation": {
|
||||||
"button": "请求海拔数据",
|
"button": "请求海拔数据",
|
||||||
"help": "Requesting elevation data will erase the existing elevation data, if any, and replace it with data from Mapterhorn.",
|
"help": "请求成功后将移除原有的海拔数据,并使用 Mapterhorn 的海拔数据替换原有数据。",
|
||||||
"help_no_selection": "选择要请求海拔数据的文件。"
|
"help_no_selection": "选择要请求海拔数据的文件。"
|
||||||
},
|
},
|
||||||
"waypoint": {
|
"waypoint": {
|
||||||
@@ -304,8 +304,10 @@
|
|||||||
"switzerland": "瑞士",
|
"switzerland": "瑞士",
|
||||||
"united_kingdom": "英国",
|
"united_kingdom": "英国",
|
||||||
"united_states": "美国",
|
"united_states": "美国",
|
||||||
"topo": "Topo",
|
"libertyTopo": "Liberty Topo",
|
||||||
"satellite": "Satellite",
|
"libertySatellite": "Liberty Satellite",
|
||||||
|
"osm": "OpenMapTiles OSM",
|
||||||
|
"osmTopo": "OpenMapTiles OSM Topo",
|
||||||
"esriSatellite": "Esri Satellite",
|
"esriSatellite": "Esri Satellite",
|
||||||
"openStreetMap": "OpenStreetMap",
|
"openStreetMap": "OpenStreetMap",
|
||||||
"openTopoMap": "OpenTopoMap",
|
"openTopoMap": "OpenTopoMap",
|
||||||
|
|||||||
@@ -19,8 +19,8 @@
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
embeddingOptions = getMergedEmbeddingOptions(options);
|
embeddingOptions = getMergedEmbeddingOptions(options);
|
||||||
if (embeddingOptions.key === '' && embeddingOptions.basemap.startsWith('maptiler')) {
|
if (embeddingOptions.key === '' && embeddingOptions.basemap === 'satellite') {
|
||||||
embeddingOptions.basemap = 'openStreetMap';
|
embeddingOptions.basemap = 'libertyTopo';
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@@ -1,47 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generator: Adobe Illustrator 23.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
|
||||||
<svg version="1.1" id="Vrstva_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
|
||||||
viewBox="0 0 812 212" style="enable-background:new 0 0 812 212;" xml:space="preserve">
|
|
||||||
<style type="text/css">
|
|
||||||
.st0{fill:#3A1888;}
|
|
||||||
.st1{fill:#03A1C4;}
|
|
||||||
.st2{fill:#05D0DF;}
|
|
||||||
.st3{fill:#761FE8;}
|
|
||||||
.st4{fill:#FFAA01;}
|
|
||||||
.st5{fill:#F1175D;}
|
|
||||||
.st6{fill:#FB3A1B;}
|
|
||||||
.st7{fill:#FBC935;}
|
|
||||||
.st8{fill:#FFFFFF;}
|
|
||||||
</style>
|
|
||||||
<g>
|
|
||||||
<path class="st0" d="M94.3,164.2c9.2,9.2,33.8,34.3,33.8,34.3c-0.1,0.2,24.4-24.5,34.2-34.2l-34.1-34.1L94.3,164.2z"/>
|
|
||||||
<path class="st1" d="M128.3,130.2l34.1,34.1c0.1-0.1,0.1-0.1,0.2-0.2l34-34L162.5,96L128.3,130.2z"/>
|
|
||||||
<path class="st2" d="M196.6,130.1L196.6,130.1c18.9-18.9,18.9-49.4,0.1-68.3L162.5,96L196.6,130.1z"/>
|
|
||||||
<path class="st3" d="M94.1,96l-34,34c0,0,0,0,0,0l34.1,34.1c0,0,0,0,0.1,0.1l34-34L94.1,96z"/>
|
|
||||||
<path class="st4" d="M128.3,61.8L162.5,96l34.2-34.2c0,0,0,0-0.1-0.1l-34.1-34.1c0,0,0,0,0,0L128.3,61.8z"/>
|
|
||||||
<path class="st5" d="M60,61.9c-18.7,18.9-18.6,49.3,0.1,68.1l34-34L60,61.9z"/>
|
|
||||||
<path class="st6" d="M128.3,61.8L94.2,27.7l-34,34c-0.1,0.1-0.1,0.1-0.2,0.2L94.1,96L128.3,61.8z"/>
|
|
||||||
<path class="st7" d="M162.5,27.6c-18.9-18.8-49.4-18.8-68.2,0l-0.1,0.1l34.1,34.1L162.5,27.6z"/>
|
|
||||||
</g>
|
|
||||||
<path class="st8" d="M303.8,138.6v-34.9c0-8.6-4.5-16.4-13.3-16.4c-8.7,0-13.9,7.8-13.9,16.4v34.9h-16.1V73.4h14.9l1.2,7.9
|
|
||||||
c3.4-6.6,11-9,17.2-9c7.8,0,15.6,3.2,19.3,12.2c5.8-9.2,13.3-11.9,21.8-11.9c18.5,0,27.6,11.4,27.6,30.9v35.1h-16.1v-35.1
|
|
||||||
c0-8.6-3.6-15.9-12.3-15.9c-8.7,0-14.1,7.5-14.1,16.1v34.9H303.8z"/>
|
|
||||||
<path class="st8" d="M430.5,73.5h15.5v65.1h-15.2l-0.8-9.5c-3.7,7.7-13.9,11.4-21.1,11.5c-19.3,0.1-33.6-11.8-33.6-34.6
|
|
||||||
c0-22.5,14.9-34.2,34-34.1c8.7,0,17,4.1,20.7,10.6L430.5,73.5z M391.4,106c0,12.4,8.6,19.8,19.3,19.8c25.4,0,25.4-39.5,0-39.5
|
|
||||||
C399.9,86.3,391.4,93.6,391.4,106z"/>
|
|
||||||
<path class="st8" d="M459.5,165.8V73.5h15.1l1.1,9c5-7.3,13.7-10.4,21.1-10.4c20.1,0,33.4,14.9,33.4,34.1c0,19-12,34.1-32.9,34.1
|
|
||||||
c-6.9,0-17-2.1-21.7-9.3v34.9H459.5z M514.1,106.1c0-10.2-6.9-18.5-18.5-18.5c-11.6,0-18.5,8.3-18.5,18.5c0,10.2,7.5,18.5,18.5,18.5
|
|
||||||
C506.6,124.6,514.1,116.3,514.1,106.1z"/>
|
|
||||||
<path class="st8" d="M559,53.7v19.7h22.2v5.4H559v39.8c0,8.8,1.9,15.1,12,15.1c3.2,0,6.7-1.1,10-2.6l2.2,5.3
|
|
||||||
c-4.1,2-8.2,3.3-12.3,3.3c-13.9,0-18.4-8.2-18.4-21V78.8h-13.9v-5.4h13.9v-19L559,53.7z"/>
|
|
||||||
<path class="st8" d="M604.7,52.1c0,6.9-10.4,6.9-10.4,0C594.3,45.2,604.7,45.2,604.7,52.1z M596.1,73.1v65.5h6.5V73.1H596.1z"/>
|
|
||||||
<path class="st8" d="M627.6,46.2v92.5h-6.5V46.2H627.6z"/>
|
|
||||||
<path class="st8" d="M730.2,73.4l0.3,11.6c4.1-8.9,13.3-12.3,21.7-12.3c4.9-0.1,9.6,1.2,14,3.8l-2.9,5.3c-3.4-2.1-7.3-3-11.1-3
|
|
||||||
c-12.2,0.1-21.5,9.9-21.5,21.8v38h-6.5V73.4H730.2z"/>
|
|
||||||
<g>
|
|
||||||
<path class="st8" d="M675.1,134.7c-11.5,0-21.4-7.2-25.5-17.4l0,0l0,0c0,0,0,0,0,0l52.8-14c0,0,0,0,0,0.1l5.6-1.5
|
|
||||||
c-2.3-16.5-16.2-29.3-33-29.3c-18.4,0-33.3,15.2-33.3,34c0,18.8,14.9,34,33.3,34c13.8,0,25.6-8.5,30.6-20.7l-5.3-2.3
|
|
||||||
C696.2,127.6,686.4,134.7,675.1,134.7z M647.5,106.6c0-15.5,12.3-28.1,27.5-28.1c11.9,0,22,7.7,25.9,18.5L647.9,111
|
|
||||||
C647.6,109.5,647.5,108.1,647.5,106.6z"/>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
||||||
|
Before Width: | Height: | Size: 3.1 KiB |
@@ -1,45 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Generator: Adobe Illustrator 23.0.2, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
|
|
||||||
<svg version="1.1" id="Vrstva_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px" y="0px"
|
|
||||||
viewBox="0 0 812 212" style="enable-background:new 0 0 812 212;" xml:space="preserve">
|
|
||||||
<style type="text/css">
|
|
||||||
.st0{fill:#3A1888;}
|
|
||||||
.st1{fill:#03A1C4;}
|
|
||||||
.st2{fill:#05D0DF;}
|
|
||||||
.st3{fill:#761FE8;}
|
|
||||||
.st4{fill:#FFAA01;}
|
|
||||||
.st5{fill:#F1175D;}
|
|
||||||
.st6{fill:#FB3A1B;}
|
|
||||||
.st7{fill:#FBC935;}
|
|
||||||
.st8{fill:#333359;}
|
|
||||||
</style>
|
|
||||||
<path class="st0" d="M94.3,164.2c9.2,9.2,33.8,34.3,33.8,34.3c-0.1,0.2,24.4-24.5,34.2-34.2l-34.1-34.1L94.3,164.2z"/>
|
|
||||||
<path class="st1" d="M128.3,130.2l34.1,34.1c0.1-0.1,0.1-0.1,0.2-0.2l34-34L162.5,96L128.3,130.2z"/>
|
|
||||||
<path class="st2" d="M196.6,130.1L196.6,130.1c18.9-18.9,18.9-49.4,0.1-68.3L162.5,96L196.6,130.1z"/>
|
|
||||||
<path class="st3" d="M94.1,96l-34,34c0,0,0,0,0,0l34.1,34.1c0,0,0,0,0.1,0.1l34-34L94.1,96z"/>
|
|
||||||
<path class="st4" d="M128.3,61.8L162.5,96l34.2-34.2c0,0,0,0-0.1-0.1l-34.1-34.1c0,0,0,0,0,0L128.3,61.8z"/>
|
|
||||||
<path class="st5" d="M60,61.9c-18.7,18.9-18.6,49.3,0.1,68.1l34-34L60,61.9z"/>
|
|
||||||
<path class="st6" d="M128.3,61.8L94.2,27.7l-34,34c-0.1,0.1-0.1,0.1-0.2,0.2L94.1,96L128.3,61.8z"/>
|
|
||||||
<path class="st7" d="M162.5,27.6c-18.9-18.8-49.4-18.8-68.2,0l-0.1,0.1l34.1,34.1L162.5,27.6z"/>
|
|
||||||
<path class="st8" d="M303.7,138.6v-34.9c0-8.6-4.5-16.4-13.3-16.4c-8.7,0-13.9,7.8-13.9,16.4v34.9h-16.1V73.4h14.9l1.2,7.9
|
|
||||||
c3.4-6.6,11-9,17.2-9c7.8,0,15.6,3.2,19.3,12.2c5.8-9.2,13.3-11.9,21.8-11.9c18.5,0,27.6,11.4,27.6,30.9v35.1h-16.1v-35.1
|
|
||||||
c0-8.6-3.6-15.9-12.3-15.9c-8.7,0-14.1,7.5-14.1,16.1v34.9H303.7z"/>
|
|
||||||
<path class="st8" d="M430.3,73.5h15.5v65.1h-15.2l-0.8-9.5c-3.7,7.7-13.9,11.4-21.1,11.5c-19.3,0.1-33.6-11.8-33.6-34.6
|
|
||||||
c0-22.5,14.9-34.2,34-34.1c8.7,0,17,4.1,20.7,10.6L430.3,73.5z M391.2,106c0,12.4,8.6,19.8,19.3,19.8c25.4,0,25.4-39.5,0-39.5
|
|
||||||
C399.8,86.3,391.2,93.6,391.2,106z"/>
|
|
||||||
<path class="st8" d="M459.4,165.8V73.5h15.1l1.1,9c5-7.3,13.7-10.4,21.1-10.4c20.1,0,33.4,14.9,33.4,34.1c0,19-12,34.1-32.9,34.1
|
|
||||||
c-6.9,0-17-2.1-21.7-9.3v34.9H459.4z M514,106.1c0-10.2-6.9-18.5-18.5-18.5c-11.6,0-18.5,8.3-18.5,18.5c0,10.2,7.5,18.5,18.5,18.5
|
|
||||||
C506.4,124.6,514,116.3,514,106.1z"/>
|
|
||||||
<path class="st8" d="M558.9,53.7v19.7h22.2v5.4h-22.2v39.8c0,8.8,1.9,15.1,12,15.1c3.2,0,6.7-1.1,10-2.6l2.2,5.3
|
|
||||||
c-4.1,2-8.2,3.3-12.3,3.3c-13.9,0-18.4-8.2-18.4-21V78.8h-13.9v-5.4h13.9v-19L558.9,53.7z"/>
|
|
||||||
<path class="st8" d="M604.6,52.1c0,6.9-10.4,6.9-10.4,0C594.1,45.2,604.6,45.2,604.6,52.1z M596,73.1v65.5h6.5V73.1H596z"/>
|
|
||||||
<path class="st8" d="M627.4,46.2v92.5H621V46.2H627.4z"/>
|
|
||||||
<path class="st8" d="M730.1,73.4l0.3,11.6c4.1-8.9,13.3-12.3,21.7-12.3c4.9-0.1,9.6,1.2,14,3.8l-2.9,5.3c-3.4-2.1-7.3-3-11.1-3
|
|
||||||
c-12.2,0.1-21.5,9.9-21.5,21.8v38H724V73.4H730.1z"/>
|
|
||||||
<g>
|
|
||||||
<path class="st8" d="M674.9,134.7c-11.5,0-21.4-7.2-25.5-17.4l0,0l0,0c0,0,0,0,0,0l52.8-14c0,0,0,0,0,0.1l5.6-1.5
|
|
||||||
c-2.3-16.5-16.2-29.3-33-29.3c-18.4,0-33.3,15.2-33.3,34c0,18.8,14.9,34,33.3,34c13.8,0,25.6-8.5,30.6-20.7l-5.3-2.3
|
|
||||||
C696.1,127.6,686.3,134.7,674.9,134.7z M647.4,106.6c0-15.5,12.3-28.1,27.5-28.1c11.9,0,22,7.7,25.9,18.5L647.7,111
|
|
||||||
C647.5,109.5,647.4,108.1,647.4,106.6z"/>
|
|
||||||
</g>
|
|
||||||
</svg>
|
|
||||||
|
Before Width: | Height: | Size: 3.1 KiB |