第13回:ビジュアルデザインの原則:美しさは機能する
本日の到達目標
- 「見た目の美しさ」がユーザビリティに与える影響(美的ユーザビリティ効果)を理解する。
- レイアウトの4原則(近接、整列、反復、コントラスト)を習得し、画面設計に応用できる。
- 色彩とタイポグラフィ(文字)の基礎ルールを理解し、可読性の高いUIを作成できる。
1. なぜ「見た目」が重要なのか?
エンジニア志望の諸君の中には、「見た目なんて飾りだ。機能が動けばいい」と考える者がいるかもしれない。それは大きな間違いだ。
美的ユーザビリティ効果 (Aesthetic-Usability Effect):
心理学の研究により、「ユーザーは、見た目が美しいデザインの方が、使いやすいと感じる」ことが証明されている。美しいUIはユーザーにポジティブな感情を与え、多少の不具合や操作の難しさに対して寛容にさせる。逆に、見た目が粗雑なUIは、信頼性を損ない、ユーザーの離脱を招く。美しさは、単なる装飾ではない。「機能」の一部なのだ。
2. デザインの4原則 (CRAP)
センスに頼るな。デザインは論理だ。以下の4つの原則を守るだけで、諸君のUIは劇的にプロっぽくなる。
- 1. 近接(Proximity):
- 関連する要素同士を近づけ、無関係な要素は遠ざける。
- これにより、情報のグループが直感的に伝わる。(例:見出しと本文を近づける。写真とキャプションを近づける。)
- 2. 整列(Alignment):
- 要素を適当に置くな。見えない「線」を意識して、左揃え、中央揃えなどでピシッと揃える。
- 整列されたレイアウトは、秩序と信頼感を生む。迷ったら「左揃え」が基本だ。
- 3. 反復(Repetition):
- 同じ機能や意味を持つ要素(見出しのデザイン、ボタンの形状、色)は、全体を通して繰り返す。
- 一貫性が生まれ、ユーザーは学習しやすくなる。「この形のボタンは押せるんだな」と無意識に理解させるのだ。
- 4. コントラスト (Contrast):
- 重要な要素とそうでない要素の差を、はっきりとつける。
- サイズ、色、太さでメリハリをつける。「見てほしいところ」を明確にする。(例:タイトルは極太で大きく、注釈は細く小さくグレーで。)
3. UIにおける色彩とタイポグラフィ
3-1. 色彩のルール
色は使いすぎるな。基本は以下の比率(60-30-10の法則)を守れ。
- ベースカラー (60%): 背景色。白や薄いグレーなど、目に優しい色。
- メインカラー (30%): ブランドを象徴する色。ヘッダーや見出しに使用。
- アクセントカラー (10%): 「登録する」「購入する」などのアクションボタンに使用。目立つ色(メインカラーの補色など)を選ぶ。
注意: 原色(真っ赤、真っ青)をそのまま使うと、目がチカチカして安っぽくなる。彩度を少し落とすか、明度を調整した色を使え。
3-2. タイポグラフィ(文字)
- フォント選び: Web/アプリでは、可読性の高い「ゴシック体(サンセリフ)」が基本。OS標準のフォント (Noto Sans JP, SF Pro, Robotoなど)を使うのが最も無難で読みやすい。
- 行間と余白: 文字が詰まりすぎていると読む気を失う。行間 (Line Height) は文字サイズの1.5倍~1.8倍程度に設定せよ。
- ジャンプ率: 本文と見出しのサイズ差を大きくすることで、スキャンしやすい(流し読みできる)画面になる。
演習:ビジュアル・リファイン
- 第10回・11回で作成したワイヤーフレーム (Lo-Fiプロトタイプ)から、主要な1画面を選ぶ。
- Figma等のツールを使い、本日の講義内容(4原則、色、文字)を適用して、Hi-Fi (高精細)なデザインに作り変える。
- Before/After比較:
- 元のワイヤーフレームと、リファイン後のデザインを並べ、どこをどう変えたことで「情報が伝わりやすくなったか」を解説する。
第14回: デザインシステムとアクセシビリティ
本日の到達目標
- デザインシステムの概念と、Atomic Designの考え方を理解する。
- アクセシビリティ (a11y) の重要性を理解し、誰一人取り残さないデザインを学ぶ。
- 作成したデザインのアクセシビリティチェック (コントラスト比など)を実践できる。
1. デザインシステム: 一貫性と効率化
アプリの画面数が増えてくると、「あれ、ここのボタンの色、さっきの画面と微妙に違うぞ?」という問題が発生する。これを防ぎ、開発効率を爆発的に高めるのがデザインシステムだ。
Atomic Design (アトミックデザイン)
UIを科学の「原子」に見立てて部品化する考え方。
- Atoms(原子): これ以上分割できない最小単位。(例:ボタン、入力フォーム、アイコン、色)
- Molecules (分子): 原子を組み合わせた、機能を持つ単位。(例: 検索フォーム = 入力フォーム+ボタン+アイコン)
- Organisms (有機体): 分子を組み合わせた、独立したセクション。(例:ヘッダー、商品カードリスト)
- Templates (テンプレート): 有機体を配置したページ構造。
- Pages (ページ): テンプレートに実際のコンテンツを入れた最終形。
エンジニアへのメリット:
この考え方でデザインされていれば、ReactやVue.jsなどの「コンポーネント指向」のフレームワークで実装する際、コンポーネントの粒度がそのままコードと一致する。つまり、デザインとコードが共通言語で語れるようになるのだ。
2. アクセシビリティ (Accessibility / a11y)
アクセシビリティとは、「障害者対応」だけではない。「どんな状況の、どんな人でも使えること」を指す。
- 視覚: 色覚多様性(色弱)、老眼、晴天の屋外(画面が見にくい)。
- 聴覚: 耳が聞こえない、または騒音の激しい電車内。
- 運動: 片手が塞がっている(荷物や子供を抱えている)、骨折中。
「自分は健康だから関係ない」と思うな。諸君も明日、腕を骨折するかもしれないし、年を取れば必ず老眼になる。アクセシビリティを考慮することは、未来の自分を含む全ユーザーへの配慮なのだ。
3. 最低限守るべきアクセシビリティ基準 (WCAG)
Web Content Accessibility Guidelines (WCAG)から、特に重要なポイントを抜粋する。
- コントラスト比:
- 文字色と背景色のコントラスト比は、少なくとも4.5:1以上確保する。
- 薄いグレーの文字は見にくい。Figmaのプラグインなどで必ずチェックせよ。
- 色だけに頼らない:
- エラーを「赤色」だけで示すな。色覚特性によっては赤と黒の区別がつきにくい。必ず「アイコン」や「テキスト」を併用せよ。(例:赤い枠線+! アイコン +「エラーです」の文字)
- タッチターゲットのサイズ:
- ボタンやリンクは、指で押しやすい大きさにする。AppleやGoogleのガイドラインでは、最低でも44x44 pt (または 48x48 dp) の領域が必要とされる。
- 代替テキスト (Alt Text):
- 画像には必ず、その内容を説明するテキストを設定する。スクリーンリーダー(読み上げ機能)を使うユーザーにとって、画像は「存在しない」のと同じだ。
演習:コンポーネント作成とチェック
- コンポーネント化: 自分のデザインから「ボタン」と「カード(画像+タイトル+説明)」を抜き出し、Atomic Designの考え方で整理する。
- アクセシビリティチェック:
- Figmaプラグイン (StarkやA11yなど)を使用し、メインカラーと背景色のコントラスト比を測定する。4.5:1未満なら色を修正する。
- 色覚シミュレーションを行い、色だけで情報を伝えている箇所がないか確認する。
第15回:実装へのハンドオフとUXデザイナーの未来
本日の到達目標
- デザインをエンジニアに正確に伝えるための「ハンドオフ」の手法を学ぶ。
- UXデザインの知識が、エンジニアとしてのキャリアにどう活きるかを知る。
- 半年間の講義を振り返り、自身の成長と今後の学習指針を定める。
1. ハンドオフ:デザインからコードへ
Figmaで作った絵は、まだ製品ではない。コードに変換されて初めて価値を生む。デザイナー(諸君)の意図を、実装者(未来の諸君や同僚)に100%伝える作業をハンドオフと呼ぶ。
エンジニアが喜ぶデザインデータ
- デザインスペック(指示書):
- 余白(マージン/パディング)の値、フォントサイズ、色のカラーコード (Hex/RGBA)が明確か?
- 「ここは適当に」は通用しない。8px単位のグリッドシステムなどを使い、数値を規則的にせよ。
- レスポンシブ動作の指定:
- 画面幅が縮まった時、このカードはどう変形するのか? 画像はトリミングされるのか縮小されるのか? 静止画だけでなく「動き」を言葉や図で補足せよ。
- ステータスの網羅:
- 正常系だけでなく、「データが空の時」 「読み込み中 (ローディング)」 「エラー時」 「文字数が極端に多い時」のデザインはあるか?
- アセットの書き出し:
- 画像やアイコンは、SVGや倍率別 (@2x, @3x)で書き出せるようになっているか?
諸君がエンジニアならわかるはずだ。「仕様が決まっていないデザイン」を渡されることほどの地獄はない。
2. UXエンジニアというキャリア
本講義を通して、UXデザインのプロセスを学んだ諸君は、単なる「コードが書ける人」ではなくなっているはずだ。
UXエンジニア: UXデザインの知識を持ち、プロトタイピングからフロントエンド実装までを一貫して行える職種。市場価値は極めて高い。
エンジニアとしての武器:
- 「なぜこの機能を作るのか」を理解して実装できるため、無駄な手戻りが減る。
- デザイナーと共通言語で会話でき、チームのハブになれる。
- 自分で課題を発見し、技術で解決策を提案できる。
コードは手段だ。目的は「ユーザーの課題解決」だ。この視点を持つエンジニアは、どこへ行っても重宝される。
3. 総括: UXデザインの旅は続く
半年間、課題発見からプロトタイピング、検証、そして実装への接続までを駆け抜けた。
- 第1章(原理): UXとは「おもてなし」ではなく「工学」であると学んだ。
- 第2章(発見): ユーザーリサーチで「思い込み」を破壊し、ペルソナと共感した。
- 第3章(創造): クレイジーなアイデアを形にし、テストで叩きのめされ、改善した。
- 第4章(実装): 美しさとアクセシビリティを纏わせ、現実に動くものへと昇華させた。
このプロセス (Design Thinking)は、アプリ開発だけでなく、あらゆる問題解決に応用できる。就職活動、チームビルディング、あるいは人生設計においてもだ。
最終課題:UXポートフォリオの完成
- これまでの講義で作成した成果物(リサーチ結果、HMW、ジャーニーマップ、プロトタイプ、テスト結果、最終デザイン)を一つのドキュメントにまとめる。
- STARフレームワーク (第12回参照)を意識し、「私がどのようなプロセスを経て、この解決策に辿り着いたか」というストーリーを記述する。
- 最後に、「この講義を通して、自分のエンジニアとしての視点がどう変わったか」を400字程度で振り返り記述 (Reflection)として添える。