Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
MapLibre GL JS とCSSアニメーションでできること
Search
Satoshi Komatsu
December 16, 2022
Programming
0
1k
MapLibre GL JS とCSSアニメーションでできること
2022/12/15 MIERUNE Meetup mini #05
https://mierune.connpass.com/event/266903/
Satoshi Komatsu
December 16, 2022
Tweet
Share
More Decks by Satoshi Komatsu
See All by Satoshi Komatsu
新宿駅構内を三人称視点で探索してみる
satoshi7190
2
88
シェーダーで魅せるMapLibreの動的ラスタータイル
satoshi7190
1
590
立方体異世界生成魔法(キュービックディメンション・ジェネレーションマジック)
satoshi7190
2
440
新宿ダンジョンを可視化してみた
satoshi7190
3
750
Webエンジニアに転生したらCSS魔導士になった件
satoshi7190
3
3.9k
Other Decks in Programming
See All in Programming
Kanzawa.rbのLT大会を支える技術の裏側を変更する Ruby on Rails + Litestream 編
muryoimpl
0
220
『品質』という言葉が嫌いな理由
korimu
0
160
Amazon S3 TablesとAmazon S3 Metadataを触ってみた / 20250201-jawsug-tochigi-s3tables-s3metadata
kasacchiful
0
100
Introduction to kotlinx.rpc
arawn
0
630
テストをしないQAエンジニアは何をしているか?
nealle
0
130
DevinとCursorから学ぶAIエージェントメモリーの設計とMoatの考え方
itarutomy
1
640
Writing documentation can be fun with plugin system
okuramasafumi
0
120
ファインディの テックブログ爆誕までの軌跡
starfish719
2
1.1k
SwiftUIで単方向アーキテクチャを導入して得られた成果
takuyaosawa
0
260
Rails アプリ地図考 Flush Cut
makicamel
1
110
なぜイベント駆動が必要なのか - CQRS/ESで解く複雑系システムの課題 -
j5ik2o
7
2.5k
GitHub Actions × RAGでコードレビューの検証の結果
sho_000
0
240
Featured
See All Featured
Building Adaptive Systems
keathley
40
2.4k
Large-scale JavaScript Application Architecture
addyosmani
510
110k
Helping Users Find Their Own Way: Creating Modern Search Experiences
danielanewman
29
2.4k
StorybookのUI Testing Handbookを読んだ
zakiyama
28
5.5k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
29
2.2k
Bootstrapping a Software Product
garrettdimon
PRO
305
110k
The Language of Interfaces
destraynor
156
24k
Design and Strategy: How to Deal with People Who Don’t "Get" Design
morganepeng
129
19k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
193
16k
Reflections from 52 weeks, 52 projects
jeffersonlam
348
20k
YesSQL, Process and Tooling at Scale
rocio
171
14k
Building Your Own Lightsaber
phodgson
104
6.2k
Transcript
Satoshi Komatsu MapLibre GL JSとCSSアニメーションで できること
©Project PLATEAU / MLIT Japan 小松 聖 自己紹介 KOMATSU satoshi
今年の6月にMIERUNEに入社。 前職は岐阜県で庭師。 ひよっこエンジニアです。 フロントエンドエンジニア
©OpenStreetMap contributors 01 私がMapLibre GL JSで作るもの 02 MapLibre GL JSでのCSSの使い所 03 私がアニメーションにこだわる理由 目次
©OpenStreetMap contributors 01 私がMapLibre GL JSで 作るもの
©Project PLATEAU / MLIT Japan 私がMapLibre GL JSで作るもの •Mapboxからフォークされて誕生した オープンソースのJavaScript地図ライ
ブラリ MapLibre GL JS https://maplibre.org/
© 地理院地図 全国最新写真(シームレス) DEMOを3つ紹介 私がMapLibre GL JSで作るもの
©Project PLATEAU / MLIT Japan 私がMapLibre GL JSで作るもの 1.地図上に植林 https://codepen.io/satoshi7190/pen/ZERmWMX
©Project PLATEAU / MLIT Japan 私がMapLibre GL JSで作るもの 2.キャトルミューティレーション https://codepen.io/satoshi7190/pen/OJEGqOq
©Project PLATEAU / MLIT Japan 私がMapLibre GL JSで作るもの 3.魔法陣の発動と召喚獣の召喚 https://codepen.io/satoshi7190/pen/ExRJrLa
©OpenStreetMap contributors 02 MapLibre GL JSでの CSSの使い所
©Project PLATEAU / MLIT Japan MapLibre GL JSでのCSSの使い所 CSSとは •
Webサイトの見た目部分 を 装 飾 するマークアップ アップ 言 語 。アニメーショ ンも可能。 • さっきのDEMOはこれを 地 図 上のビジュアル表 現 に活用したもの。
©Project PLATEAU / MLIT Japan canvas要素による表現 HTML要素による表現 MapLibre GL JSでのCSSの使い所
MapLibreの地図表現に使われる要素
©Project PLATEAU / MLIT Japan MapLibre GL JSでのCSSの使い所 • ラスターレイヤー
背景地図の表示 • ポリゴン、ライン、ポイントレイヤー ベクトル形式による地物の表示 • シンボルレイヤー テキストの表示やクラスター表現 canvas要素 地図のメインになる部分
©Project PLATEAU / MLIT Japan •マーカー 検索結果の表示や、目印のような一 時的ポイントの表示 •ポップアップ 地図上の地物の詳細データ
などの表示 HTML要素 MapLibre GL JSでのCSSの使い所 メインの地図に乗っかるもの
MapLibre GL JSでのCSSの使い所 こいつらはCSSの力で・・・
MapLibre GL JSでのCSSの使い所 こんな風に変身できます。
MapLibre GL JSでのCSSの使い所 動かすこともできます
MapLibre GL JSでのCSSの使い所 •大きさが変わらないので地図 をズームアウトすると密になる •ポイント指定での表現しかでき ない •図形を曲げるなどの曲線的な 動きはCSSでは表現できない ですが・・・
MapLibre GL JSでのCSSの使い所 CSSで出来ないことはcanvasソースレイヤーで https://codepen.io/satoshi7190/pen/abKrbpp •通常のcanvas要素を地図上にプ ロットできる。 •bboxによるエリア指定で表示す るので地図の縮尺に合わせてくれ る。
•JavaScriptのコードでCSSアニ メーションよりも複雑な動きを表 現できる
©Project PLATEAU / MLIT Japan canvasソースレイヤーによる表現の例 #30000DayMapChallenge
©Project PLATEAU / MLIT Japan canvasソースレイヤーによる表現の例 https://satoshi7190.github.io/earthquake-japan/ #30DayMapChallenge Day23 「Movement」
©OpenStreetMap contributors 03 私がアニメーションに こだわる理由
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 一味違う個性を出せる
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 よりインパクトのあるデータ表現ができる ※印象操作にならないよう、ある程度加減は必要です。
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 アニメーション系のコンテンツ は、作った物をSNSの動画で 公開するだけでアウトプットが 気軽にできる。
技術記事を書いたり、コードを 公開するのに自信がない人の 最初の一歩にオススメ。
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 https://twitter.com/_jsolly/status/15956021 22506088449
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 https://twitter.com/satoshi7190/status/159 6320194435383298
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 https://twitter.com/_jsolly/status/15963231 23346886657
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 https://twitter.com/_jsolly/status/159632 3484413489153
©Project PLATEAU / MLIT Japan 私がアニメーションにこだわる理由 https://codepen.io/satoshi7190 とりあえず見た目ができたら DEMO動画をTwitterに投稿。 中身のコードが綺麗に整ったら
コードペンにコードを共有。 説明できるようになったら Qiitaで記事を書く。 https://qiita.com/satoshi7190 https://twitter.com/satoshi7190
© 地理院地図 全国最新写真(シームレス) •CSSはUIだけでなく地図上でも活用できる •動く表現は地図に無関心な人にも注目させることができる •コードがダサくて文章が苦手でも、見た目の評価でモチベは上がる まとめ