すっかり気がついていませんでしたが、Mapillaryで、機械学習成果として検知された標識や地物をフィルタして表示したり、ダウンロードしたりする機能が追加されていました。
これまでも、OSMを編集するにあたってMapillaryの道路標識の自動認識はとても重要な手がかりのひとつでしたが、認識される数があまりにも多いため、編集している途中で「やってられんな」という状態になることが(個人的に)課題でした。
これが、データをダウンロードできることにより、画期的に視認性が高まり、編集や管理がしやすくなりました。
ここでは、フィルタリングした標識データを使って、JOSMで効率的に地図編集を行う方法をまとめます。
必要となるJOSMプラグイン
今回の作業では、以下のJOSMプラグインを利用します。
- opendata
- Mapillary
- todo
Mapillaryで対象のデータをフィルタ
Mapillaryの地図表示画面を開きます。
対象となる場所まで表示を移動させ、画面左上のフィルタアイコンをクリックします。
Show Traffic signsの項目から、対象となる標識を選びます。複数選ぶことも可能です。
対象となる項目の数はかなり多いのですが、検索窓に文字列を入力すると対象の項目をフィルタできます。
試しに、one way
と入力してみましょう。
大文字小文字は区別されませんが、スペースは正しく入力する必要があります。
日本で使われるのは、右向きの白い矢印(Regulatory: One way right (g1)
)と、左向きの矢印(Regulatory: One way left (g1)
)です。
それぞれ選択してフィルタに項目を追加すると、その標識のみ表示される状態になります。
対象の標識アイコンが表示されない場合、zoom14くらいまで地図を拡大するか、標識がありそうな位置まで表示を移動させてください。
データを表示させた状態でダウンロード
対象のデータを表示させた状態で、downloadボタンを押してください。
geojson形式でデータがダウンロードされます。
geojson.ioで変換
ダウンロードされたgeojsonファイル(mapillary-traffic-signs.json
)を、geojson.ioを使ってCSVに変換します。
geojson.ioを開き、Mapillaryからダウンロードしたgeojsonをドラッグアンドドロップすると、地図上にポイントが表示されます。
その状態で、geojson.ioのメニューからCSVで保存を選び、保存してください。
CSVファイルをJOSMで読み込み
JOSMを開きます。
oepndataプラグインを利用することで、JOSMはCSVファイルを読み込むことができるようになっています。CSVファイルをJOSMへドラッグアンドドロップしてください。
測地系はWGS84測地系 (EPSG:4326)
を選びます。
CSVファイルがレイヤとして追加されます。(この例の場合、points(1).csv
)
JOSMのtodoプラグインでリスト化(オプション)
このままだとどのポイントを編集したか分かりづらいので、todoプラグインを使ってチェックができるようにします。
CSVのレイヤを有効化し、すべての地物を Ctrl+A
で全選択します。
その状態でtodoプラグインを開き、+
のアイコンを押して、すべての地物を作業リストに追加します。
対象の地点のOSMデータをダウンロードして編集
項目を選択した状態でズーム
ボタンをクリックすると、対象のノードの位置にジャンプします。
ジャンプしたら、通常の編集と同様、その地点のOSMデータをダウンロードして編集します。
ただしその際、必ず「新しいレイヤとしてダウンロード」するようにして、CSVデータとは別のレイヤで作業するようにしてください。
もしCSVデータと同じレイヤにOSMデータをダウンロードして作業してしまうと、編集結果をアップロードする際、Mapillaryから抽出したCSVも一緒にOSMにアップロードしてしまうことになります。
謎のゴミデータがOSMに登録されてしまうことになりますので、注意が必要な箇所です。
JOSMメニューの「画像」→「その他」からMapillaryプラグインを有効化し、画像を確認しながら編集します。
また、追補情報として、同じく「その他」の中にあるMapillary Traffic Signs
レイヤや、Mapillary point features
レイヤを有効化しておくと、対象となる画像の選定を簡単に行うことができるでしょう。
編集や確認が終わったら、todoプラグインでマーク
を押すと、対象の消込が行われ、次の対象への移動が実行されます。
適度なところでOSMにアップロードしましょう!(繰り返しますが、CSVファイルに含まれるデータをアップロードしないようにしましょう!)
日本の標識とMapillary featureの対応表
Mapillaryで認識される標識は大量にあり、単純にスクロールさせて対象を探すのは効率がよろしくありません。
と、いうわけで、日本でよく使われそうな標識とMapillary feature名称の対応表です。
元のデータはこちら。
- 標識: https://www.mapillary.com/developer/api-documentation/traffic-signs?locale=ja_J
- 地物: https://www.mapillary.com/developer/api-documentation/points?locale=ja_JP
対応表
標識アイコン | 標識名称 | Mapillaryフィルタ名 | Mapillary APIでの名称 | OSM wiki |
---|---|---|---|---|
一方通行(左向き) | Regulatory: One Way left (g1) | regulatory--one-way-left--g1 | Key:oneway | |
一方通行(右向き) | Regulatory: One Way right (g1) | regulatory--one-way-right--g1 | Key:oneway | |
重量制限 | Regulatory: Weight Limit (g1) | regulatory--weight-limit--g1 | Key:maxweight | |
最大幅 | Regulatory: Width Limit (g1) | regulatory--width-limit--g1 | Key:maxwidth | |
高さ制限 | Information: Height Limit (g1) | information--height-limit--g1 | Key:maxheight |
(そのうち追記予定)
画像出典: 地図に使える素材 FreeSozai.jp