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
990
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
シェーダーで魅せるMapLibreの動的ラスタータイル
satoshi7190
1
590
立方体異世界生成魔法(キュービックディメンション・ジェネレーションマジック)
satoshi7190
2
430
新宿ダンジョンを可視化してみた
satoshi7190
3
740
Webエンジニアに転生したらCSS魔導士になった件
satoshi7190
3
3.9k
Other Decks in Programming
See All in Programming
ISUCON14公式反省会LT: 社内ISUCONの話
astj
PRO
0
170
はてなにおけるfujiwara-wareの活用やecspressoのCI/CD構成 / Fujiwara Tech Conference 2025
cohalz
3
4.5k
Amazon Nova Reelの可能性
hideg
0
280
いりゃあせ、PHPカンファレンス名古屋2025 / Welcome to PHP Conference Nagoya 2025
ttskch
1
260
SpringBoot3.4の構造化ログ #kanjava
irof
2
880
Amazon Bedrock Multi Agentsを試してきた
tm2
1
270
第3回 Snowflake 中部ユーザ会- dbt × Snowflake ハンズオン
hoto17296
4
320
ペアーズでの、Langfuseを中心とした評価ドリブンなリリースサイクルのご紹介
fukubaka0825
2
280
Writing documentation can be fun with plugin system
okuramasafumi
0
110
SwiftUIで単方向アーキテクチャを導入して得られた成果
takuyaosawa
0
240
【PHP】破壊的バージョンアップと戦った話〜決断と説得
satoshi256kbyte
0
120
[JAWS-UG横浜 #80] うわっ…今年のServerless アップデート、少なすぎ…?
maroon1st
1
160
Featured
See All Featured
Building Your Own Lightsaber
phodgson
104
6.2k
Speed Design
sergeychernyshev
25
770
Faster Mobile Websites
deanohume
306
31k
Keith and Marios Guide to Fast Websites
keithpitt
410
22k
Improving Core Web Vitals using Speculation Rules API
sergeychernyshev
7
240
Let's Do A Bunch of Simple Stuff to Make Websites Faster
chriscoyier
507
140k
Art, The Web, and Tiny UX
lynnandtonic
298
20k
Refactoring Trust on Your Teams (GOTO; Chicago 2020)
rmw
33
2.8k
The Cult of Friendly URLs
andyhume
78
6.2k
Automating Front-end Workflow
addyosmani
1367
200k
Learning to Love Humans: Emotional Interface Design
aarron
274
40k
How to Create Impact in a Changing Tech Landscape [PerfNow 2023]
tammyeverts
49
2.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だけでなく地図上でも活用できる •動く表現は地図に無関心な人にも注目させることができる •コードがダサくて文章が苦手でも、見た目の評価でモチベは上がる まとめ