8
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

FOSS4GAdvent Calendar 2020

Day 15

Mapbox GL JSスタイリング - 誰でも楽しめる地図デザイン

Last updated at Posted at 2020-12-15

##はじめに
Mapbox GL JS は、米国のMapboxが主体となって開発したJavaScriptベースのWeb地図の オープンな技術標準1 で、style.jsonを編集することで様々な地図デザインをスタイルすることができます。昔ならば、地図会社の中の人しかやる機会が殆どなかった地図デザインを、今なら誰でも楽しめます。

ただ、地図データにはライン、ポリゴン、ポイントという3種類のデータの形式に加え、ズームレベルが変化するため、設定する要素が多岐にわたります。「こんな地図デザインにしたいなぁ」と思っても、なかなか思った通りには行きません。

それを支援するのが地図スタイルエディタです。これは、GUI形式でスタイル設定を可能としており、Mapbox GL JSに基づくスタイルファイルのコーディングの知識が少ない人の敷居を下げ、あるいは十分に知識がある人にとっては生産性を高めるツールとして用いられています。

代表的な2種について、以下に紹介します。

###Mapbox Studio
Mapbox GL JSの開発プロジェクトを運営しているMapboxはMapbox Studioというエディタ機能を自社サービスの一環で提供しています。こちらの記事にも書きましたが、コーディングはもちろんのこと、細かな数値設定すら行うこと無く、いろいろなアレンジができるようになっていて、初心者にはありがたいでしょう。一方、Mapbox Studioは、Mapboxが提供する製品でしか利用できないようになっているため、地図のデザインや配信環境を自分で構築したり管理したりする用途には向いていません。

###MapTiler
似たようなサービスとしては、MapTiler があります(日本ではMIERUNE がMapTiler.JPブランドで日本語によるサービスを提供しています)。MapTilerは自社サービスの一環としてMaputnik というエディタ機能を提供しています。GUI形式の設定画面によって、ほとんどコーディングを行わないで地図デザインを吟味することができます。Mapbox Studioとは違い、Maputnikはオープンソースソフトウェアであり、地図データもOpenMapTilesからダウンロードできるものもあるので、比較的ユーザー側の自由度が高いと言えます。

#地図のデザインの小ネタ
そこで、ここからが本題です。日本国内の地図デザインでよく見られるスタイルを実現するにはどうしたらよいのかを、いくつかの事例で解説します。なお、ここではMapTilerを使い、MIERUNEが提供している日本の地図のデザインをベースに変更を加えるやりかたで説明します。

##事前準備
MapTilerのアカウントを持っていない人は、最初にアカウントを作成します。

スクリーンショット 2020-12-15 14.46.41.png

ログインして、左側の「Maps」を表示させて、スクロールダウンすると、日本の地図がリストアップされます。
スクリーンショット 2020-12-15 14.46.56.png

JP MIERUNE Streetsを選び、右下にある・・・(赤○で囲った部分)をクリックし、Edit a copyを選択します。
スクリーンショット 2020-12-15 14.47.19.png

スタイル設定画面(Maputunik)が表示されます。一番左がレイヤ名、その右がそれぞれのレイヤの設定画面、右側が表示される地図デザインとなります。
スクリーンショット 2020-12-15 14.48.01.png

##その1 - 境界線のデザイン
都道府県界や市区町村界は、伝統的に点線で描かれることが多く、同時に淡い太めの線のバッファを描くこともよくあります。

本稿執筆時点のJP MIERUNE Streetsでは、都道府県境界はピンク色の一点鎖線で描かれています。
スクリーンショット 2020-12-15 14.48.50.png

これを、中心線とバッファの表現に変更してみます。
地図上で境界線をクリックすると、そのレイヤと設定が左側に表示されます(赤枠がレイヤ名)。
スクリーンショット 2020-12-15 14.49.09.png

####レイヤを複製
上の画像の黄緑色で囲まれたところに複製ボタンがあり、これをクリックすることでレイヤが複製されます。レイヤ名称は(元レイヤの名称)-copyとなります。

####複製されたレイヤに対してスタイル設定
Dasharrayの指定を解除し、一点鎖線を解消させます。
スクリーンショット 2020-12-15 14.56.59.png

####元のレイヤに対して、中心線をスタイル設定
Colorをグレーに変更します。
スクリーンショット 2020-12-15 14.59.32.png

こうすることで、境界線がクッキリわかるようになりますね。
スクリーンショット 2020-12-15 14.59.42.png

##その2 - 道路のアウトライン表示

JP MIERUNE Streetsでは、高速道路や都道府県などの主要道路のアウトラインは表示設定されていますが、一般の道路は白抜きで表現されるだけで、アウトライン表示はありません。そこで、一般道路にアウトライン表示を追加してみましょう。

####アウトライン表示の仕組み
道路のアウトラインは、道路中心線のデータを2種類作成して、一方を細く、他方をわずかに太く描画することで表示します。

一般道のレイヤ(highway-minor)を確認して、コピーを作成します。
スクリーンショット 2020-12-15 18.33.04.png

Paint PropertiesのWidth設定をZoom12:0.1を0.2に、Zoom22:100を110に変更します。さらに、低いズームレベルから高いズームレベルへ、アウトラインの色調が濃くなるように変化を持たせます。
変更前の設定
スクリーンショット 2020-12-15 18.33.57.png
変更後の設定
スクリーンショット 2020-12-15 20.39.21.png

アウトライン表示が実装された地図表示
Zoom 17
Before
スクリーンショット 2020-12-15 20.40.19.png
After
スクリーンショット 2020-12-15 20.40.07.png
Zoom 18
Before
スクリーンショット 2020-12-15 20.40.35.png
After
スクリーンショット 2020-12-15 20.40.50.png

##まとめ
上記の例のように、地図デザインはスタイルエディタを活用することで、比較的容易に変更することができます。Mapbox GL JSは、実に多様な地図表現のオプションを提供していますので、地図のデザインに興味を持つ人は、ぜひ試してみて下さい。「時間が溶ける」ことを保証します!

  1. 今月リリースされたばかりのMapbox GL JS Ver2.0では、オープンソースソフトウェアライセンスが適用され無くなってしまいました。直後に、コミュニティによるForkが行われ、MapLibre GL JSとしてオープンソースソフトウェアとして提供され続けています。

8
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
8
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?