logo
  • 現在做什麼
  • 關於我

Kalan

文章分類

  • 前端
  • 開發筆記
  • 雜談
  • 年度回顧

快速連結

  • 現在做什麼
  • 關於我
  • 聯絡我
  • 職涯思考🔗

關注我

在福岡生活的開發者,分享軟體開發與日本生活的點點滴滴。

© 2025 Kalan Made with ❤️. All rights reserved.

データの視覚化 — 台湾の性的暴行統計

作成者:カランカラン2020年11月23日 23:43
ホーム/フロントエンド
💡

質問やフィードバックがありましたら、フォームからお願いします

英語原文

目次

  1. データ整理
  2. 実装
  3. 反省

本文は台湾華語で、ChatGPT で翻訳している記事なので、不確かな部分や間違いがあるかもしれません。ご了承ください

このテーマを実装しようと思ったのは、ニュースを見て、さらにデータが比較的整っていたからです。ちょうどSvelte自体を広める良い機会でもあると思い、構想しながら実装を進めました。完成品はこちらです。

スクリーンショット 2020-11-23 23.20.38

データビジュアライゼーションは、私がじっくり研究したい分野の一つで、単に派手なグラフを作るだけではなく、ストーリーテリングの技術を磨くことができると思っています。データビジュアライゼーションは、まさにそのための良い練習材料です。

以前にもいくつかのプロジェクトを進めてきましたが、どれも少し急いで作った感があり、細部にこだわることができませんでした。これを機に、よく使うコンポーネントを整理していこうと思います。

  • 2017年に作成した労働者大事典
  • 2017年に作成したYear In Review
  • 2020年4月に作成した福岡の感染状況:現在、グラフが崩れてしまっており、当初はこんなに長引くとは思っていませんでした。

データ整理

データの大部分は衛福部から取得しました。データは非常に詳細です。ただし、データは主にExcel形式で提供されているため、処理しやすいデータ形式に変換するのにかなりの時間がかかりました。

実装

技術的には、Svelteとd3を使用して開発を行いました。自分が使いやすいグラフコンポーネントをゆっくりと実装していきたいと考えており、現在は使用シーンを観察中です。そのため、コンポーネントはまだ少し固定的な部分がありますが、今後徐々に改良していく予定です。

通常の折れ線グラフで考慮すべき要素:

  • x, y軸とティック
  • xとyのスケール設定
  • 縦線、横線のスタイル設定
  • グラフのタイトルと単位
  • テキスト設定
  • トランジション
  • ツールチップ:グラフにホバーした際の動作

d3については、ここではd3-scaleしか使用しておらず、d3のpatternは使用していません。たとえば:

d3.select('svg')
	.enter()
	.data(data)
	.append()
	...

これは、これらの操作をすべてSvelteに任せたいからです。しかし、トランジションやエンター・イグジットパターンを扱う際は少し手間がかかりました。d3はAPIを直接呼び出すことができるのですが、Svelteでは別途処理が必要です。この部分は今後どのように調整するか検討中です。また、今回新しいSnowpackを採用しましたが、開発が非常にスムーズで、皆さんにもお勧めです。

バックエンドはKotlinをAPIサーバーとして使用しています。初めて書いたのですが、とても快適でした。また、今後スケジューリングやマルチスレッドのようなタスクを行いたい場合、直接Kotlinを使う方が便利です。サーバーはApp Engineに直接デプロイしており、Gradleを使用することで非常に便利になっています。

反省

主要な部分は約2日で実装でき、その後は細部やインタラクションの調整を行いました。正直なところ、今回のインタラクションはあまり多くありませんでしたが、情報をどのように提示するかを考えることが主な目的でした。今回は単純にデータを表示することに主眼を置いていますが、今後のプロジェクトではもっと多くの可能性とインタラクションを提供したいと思っています。また、インタラクションを通じてストーリーを伝える方法も模索していきます。

← SSR のシナリオの考え方と使用方法開発プロセスを改善してみた →

この記事が役に立ったと思ったら、下のリンクからコーヒーを奢ってくれると嬉しいです ☕ 私の普通の一日が輝かしいものになります ✨

☕Buy me a coffee

目次

  1. データ整理
  2. 実装
  3. 反省