MapLibre GL JSとSvelteを組み合わせた開発環境を構築してみました!
GitHubに作成した環境を公開しています。ぜひご利用ください!
maplibregljs-svelte-starter
事前準備
- Svelteのプロジェクト作成
Svelte #001 – create-svelteで環境構築
実行環境
- node v20.6.1
- npm v9.8.1
MapLibre GL JSのインストール
MapLibre GL JSをSvelteのプロジェクトにインストールします。
npm install maplibre-gl
マップアプリケーションの構築
最後に、実際にマップアプリケーションを構築します。テンプレートから一部のファイル変更と削除をします。
全体構成
package.json
{
"name": "maplibregljs-svelte-starter",
"version": "1.0.0",
"scripts": {
"dev": "vite dev",
"build": "vite build",
"preview": "vite preview",
"test": "npm run test:integration && npm run test:unit",
"check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json",
"check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch",
"lint": "prettier --plugin-search-dir . --check . && eslint .",
"format": "prettier --plugin-search-dir . --write .",
"test:integration": "playwright test",
"test:unit": "vitest"
},
"keywords": [],
"author": "MapLibre User Group Japan",
"license": "ISC",
"devDependencies": {
"@fontsource/fira-mono": "^4.5.10",
"@neoconfetti/svelte": "^1.0.0",
"@playwright/test": "^1.28.1",
"@sveltejs/adapter-auto": "^2.0.0",
"@sveltejs/kit": "^1.20.4",
"@types/cookie": "^0.5.1",
"@typescript-eslint/eslint-plugin": "^6.0.0",
"@typescript-eslint/parser": "^6.0.0",
"eslint": "^8.28.0",
"eslint-config-prettier": "^8.5.0",
"eslint-plugin-svelte": "^2.30.0",
"prettier": "^2.8.0",
"prettier-plugin-svelte": "^2.10.1",
"svelte": "^4.0.5",
"svelte-check": "^3.4.3",
"tslib": "^2.4.1",
"typescript": "^5.0.0",
"vite": "^4.4.2",
"vitest": "^0.32.2"
},
"type": "module",
"dependencies": {
"maplibre-gl": "^3.3.1"
}
}
/src/routes
+layout.svelte
既存のページを削除しslotタグを残します。
<script lang="ts">
import './styles.css';
</script>
<slot />
<style></style>
/src/routes
+page.svelte
マップコンポーネントを読み込むように変更します。
<script lang="ts">
import Map from '$lib/components/MapPane.svelte';
</script>
<svelte:head>
<title>MapLibre GL JS & Svelte Starter</title>
<meta name="description" content="MapLibre GL JS & Svelte Starter" />
</svelte:head>
<Map />
<style></style>
/src/lib/components
MapPane.svelte
新規でMapLibre GL JSのマップコンポーネントを作成します。
<script setup lang="ts">
import 'maplibre-gl/dist/maplibre-gl.css';
import { Map, NavigationControl } from 'maplibre-gl';
import { onMount } from 'svelte';
onMount(() => {
const map = new Map({
container: 'map',
style: {
version: 8,
sources: {
MIERUNEMAP: {
type: 'raster',
tiles: ['https://tile.mierune.co.jp/mierune_mono/{z}/{x}/{y}.png'],
tileSize: 256,
attribution:
"Maptiles by <a href='http://mierune.co.jp/' target='_blank'>MIERUNE</a>, under CC BY. Data by <a href='http://osm.org/copyright' target='_blank'>OpenStreetMap</a> contributors, under ODbL."
}
},
layers: [
{
id: 'MIERUNEMAP',
type: 'raster',
source: 'MIERUNEMAP',
minzoom: 0,
maxzoom: 18
}
]
},
center: [139.767, 35.681],
zoom: 11
});
map.addControl(
new NavigationControl({
visualizePitch: true
})
);
});
</script>
<div id="map" />
<style>
#map {
height: 100vh;
}
</style>
ローカルサーバーで確認
npm run dev
SvelteとMapLibre GL JSを組み合わせて表示することができました!
MapLibre GL JS・Svelteについて、他にも記事を書いています。よろしければぜひ。
tags - MapLibre GL JS
tags - Svelte
- 参考文献
MapLibre GL JS
Svelte