[Figma] UIデザインの基礎

1. UIデザインの基本は “3色構成”
UIの配色は、実は 3色で十分。
🔹① ベースカラー(背景)
白・薄いグレー・黒など
→ UIの土台になる色

🔹② メインカラー(ブランドカラー)
ロゴやサービスの印象を作る色
→ ボタン・リンク・アイコンなどで使う
→ 「一番よく使う色」

🔹③ アクセントカラー(補助)
注意喚起や強調したい場所に少量使う
→ 赤・黄色・緑のような “目に入る色” を控えめに
UIはこの 3色 + グレー階調(Gray-scale)で十分!
(5〜6色以上使うと素人っぽくなりがち)

3. 色の心理効果(UI向け)

色には心理的な印象があるため、UIの目的に合わせて使います。

色 心理効果・印象 UIでの用途例
青 信頼・清潔・知性 金融、SaaS、企業系UI
緑 安心・健康・自然 成功メッセージ、チェックマーク
赤 危険・注意・緊急 エラー、削除ボタン
黄 注意・明るさ 警告(Warning)
黒 高級・強さ モダンUI、文字色
グレー 中立・控えめ 背景、境界線、無効状態

4. コントラスト(可読性)の基礎
UIで一番重要なのが 可読性(文字が読みやすいか)。
💡基本ルール
文字色と背景色のコントラストを十分にする
ベースが白なら 文字は黒〜濃いグレー
背景色は薄い色(#F7F7F7 など)
ボタンの文字は「白 × 濃い色」 or 「濃い文字 × 淡いボタン色」
コントラストの指標(WCAG)
4.5:1 以上が推奨(一般文字)
3.0:1 以上(大きい文字)

5. カラーハーモニーの種類(UIでよく使う)
① モノクロマティック(同一色系)
1つの色の明度・彩度違い
→ UIデザインで最も安全
例:青 → 濃い青 → 薄い青 → グレー

② アナログ(類似色)
隣り合う色
→ 優しい・調和しやすい
例:青、青緑、緑

③ コンプリメンタリー(補色)
反対色
→ 注意喚起に最強(エラー・アクセント)
例:青 × オレンジ
例:緑 × 赤

6. Figmaでの配色運用(超基本)
🎨 色を決めたら Style に登録する
何かオブジェクトを選択
右パネル → Fill
四角のアイコン → +(Create style)
名前をつけて保存
/Colors
Primary / Blue 500
Primary / Blue 300
Accent / Red 500
Gray / 100〜900

こうすると…
色変更すると全画面に反映される
統一感が出る
開発者へ正しい値を渡せる(ハンドオフ)

7. 最初に決めるべき “UIカラーセット” サンプル
Primary: #0066FF
Primary Light: #E5F0FF
Primary Dark: #004FCC

Accent: #FF4D4D
Success: #22C55E
Warning: #FACC15
Error: #EF4444

Gray 900
Gray 700
Gray 500
Gray 300
Gray 100
White (#FFFFFF)

[Figma/Design] Figma でのタイポグラフィ基礎

🎯 UIデザインに向いているフォントの特徴
クセが少ない(可読性が高い)
太字・中太・通常など ウェイトの種類が多い
大きさや太さを変えても破綻しない

👍 よく使われる無料フォント
● Noto Sans / Noto Sans JP(Google)
→ 一番無難。日本語も英語も揃う。

● Inter
→ グローバルで最も使われるUIフォントの1つ。
→ Figma公式フォントにも入っている。

● Roboto / Roboto Condensed
→ Android系UIで多用される。

● SF Pro(Mac)
→ iOS / macOSで使用。

2. 階層(Typographic Hierarchy)
タイポの階層とは、ユーザーが画面を見た時に
どこが重要で、どこが補足なのかが一目で分かるようにする仕組み です。

典型的な階層構造(UI用)
役割 例 サイズ(px) 重さ(Weight)
H1(大見出し) 画面タイトル 24–32 Bold / SemiBold
H2(中見出し) セクションタイトル 20–24 Medium / SemiBold
Body(本文) 説明文 14–16 Regular / Medium
Caption(補足) ラベル/注釈 12–13 Regular

3. 行間(Line Height)
行間は文章の可読性に直結する

UIデザインでの基本値は:

● 本文(14–16px)

➡ Line height:120%〜160%(1.2〜1.6)

● 見出し(20px以上)

➡ Line height:110%〜130%

Figmaでの設定方法

テキストを選択 → 右の Line height に数値入力
例:

16px フォント → Line height 24px(=150%)

4. 文字間(Letter spacing)
文字間は、視認性や雰囲気を整えるために使います。
UIの一般指標
本文(14–16px):0〜1%
字幕・小さい文字(12px前後):1~3%
大きい見出し:0%以下でも良い(−1% など)

Figmaでは
Text → Letter spacing
で数値を入力(% か px)できます。

5. 日本語タイポの注意点

✓ 日本語は欧文より“詰まりやすい”ため
→ 行間は少し広め(150%前後)がおすすめ。

✓ フォントの種類によっては縦方向の見え方が違う
→ 見出しは Noto Sans JP Bold
→ 本文は Noto Sans JP Regular
など役割でフォントウェイトを分ける。

✓ UIでは明朝体が読みにくいので避ける(特別な用途を除く)

なるほど、全然意識していなかったけど、見やすくするのですね。納得です。

[Figma] colorのstyleの登録

Fillから「+」でstyleを選択して、登録したいstyle nameを入れる

フリーのアイコンサイト
https://www.flaticon.com/

■SVGのメリット
ベクター形式:拡大・縮小しても画質が劣化しない
編集可能:Figma上で色やサイズを自由に変更できる
軽量:同じ解像度のPNGよりファイルサイズが小さい場合が多い
デザインシステムとの相性:コンポーネント化して再利用しやすい

■PNGを使う場合
ラスタ形式:解像度に依存するので拡大するとぼやける
編集不可:Figma上で色や形を直接変更できない
適した用途:
写真やテクスチャを含むアイコン
細かいグラデーションや影付きアイコン

SVGもコンポーネント化される

なるほど〜 ちょいちょい勉強になるね!

[Figma] AutoLayoutとは?

1. Auto Layoutとは?
通常のFrameは固定配置ですが、AutoLayoutを設定すると、要素を自動整列できる
– 横並び(ボタン内のアイコン+テキスト)
– 縦並び(フォームのラベル+入力欄)

2. Auto Layoutの設定方法
要素を2つ選択してShift + A

うーん

[Figma] デザインを効率化・再利用する仕組みコンポーネント

### コンポーネントとは?
Figma内で再利用できる「部品テンプレート」です。
– 元(Main component)を変更すると、コピー(Instances)全てに反映される
– チームで一貫したデザインを維持できる
– 例えば「ボタン」「カード」「ヘッダー」などで使う

まずcomponentの作成

componentをフレームで利用する

テキスト内容は変更できる

### Variants
複数のデザインパターンを切り替えられるようにする
props = hover, default, … などと選択できるようにしていく

なるほど!なかなか奥が深い!

[Figma]タイポグラフィ

左ツールバーの Text (T) を選択
画面にクリックして文字入力(例:「メールアドレス」)
ステップ2:文字の属性を変更
右パネルの Text セクションで変更可能:
Font family:フォントの種類
Weight:太さ(Regular, Bold, etc.)
Size:フォントサイズ
Line height:行の高さ
Letter spacing:文字間隔
Text decoration:下線・打ち消し線など

毎日5~10分でも変わりそうやな

Reactの環境構築 & AntDesign

$ node –version
v16.13.2
$ npx create-react-app react_app
$ yarn start
http://192.168.56.10:3000/
=> 問題なければstopする

ant designもインストール
$ npm install antd
$ npm audit fix –force

srcディレクトリ内で作業
App.js

function App(){
  return (
      <div className='App'>
        <header className='App-header'>
        </header>
      </div>
    )
}
import {
	BellFilled,
	CaretDownOutlined,
	FormOutlined,
	UserOutlined,
} from '@ant-design/icons/lib/icons';
import { Avatar, Col, Input, Row, Typography } from 'antd';

function App(){
  return (
      <div className='App'>
        <header className='App-header'>
        	<div>
        		<Title>Hpscript</Title>
        		<div>
        			<CaretDownOutlined />
        			<Input placeholder='キーワードを入力' />
        		</div>
        		<div>
        			<div>
        				<FormOutlined />
        				<Text>
        					投稿する
        				</Text>
        			</div>
        			<div>
        				<BellFilled />
        			</div>
        			<Avatar size='large' icon={<UserOutlined />} />
        		</div>
        	</div>
        </header>
      </div>
    );
}

export default App;

src/App.js
Line 14:12: ‘Title’ is not defined react/jsx-no-undef
Line 22:14: ‘Text’ is not defined react/jsx-no-undef

import { Breadcrumb } from 'antd';
import React from 'react';

const App: React.FC = () => (
	<Breadcrumb>
	    <Breadcrumb.Item>Topページ</Breadcrumb.Item>
	    <Breadcrumb.Item>
	      <a href="">ページタイトルA</a>
	    </Breadcrumb.Item>
	    <Breadcrumb.Item>
	      <a href="">ページタイトルB</a>
	    </Breadcrumb.Item>
	    <Breadcrumb.Item>ページタイトルC</Breadcrumb.Item>
	</Breadcrumb>
);

export default App;

Datepicker

import React from 'react';
import { DatePicker } from 'antd';

const App = () => {
	return <DatePicker />;
}

export default App;

First Example

import React from 'react';
import { Button, Space, DatePicker, version } from 'antd';

const App = () => (
	<div style={{padding: '0 24px '}}>
	<h1>antd version: {version}</h1>
	<Space>
		<DatePicker />
		<Button type="primary">Primary Button</Button>
	</Space>
	</div>
)

export default App;

getting start

import React, { useState } from 'react';
import { createRoot } from 'react-dom/client';
import { DatePicker, message } from 'antd';
import './index.css';

const App = () => {
  const [date, setDate] = useState(null);
  const [messageApi, contextHolder] = message.useMessage();
  const handleChange = (value) => {
    messageApi.info(`Selected Date: ${value ? value.format('YYYY-MM-DD') : 'None'}`);
    setDate(value);
  };
  return (
    <div style={{ width: 400, margin: '100px auto' }}>
      <DatePicker onChange={handleChange} />
      <div style={{ marginTop: 16 }}>
        Selected Date: {date ? date.format('YYYY-MM-DD') : 'None'}
      </div>
      {contextHolder}
    </div>
  );
};

createRoot(document.getElementById('root')).render(<App />);
export default App;
import React, { useState } from 'react';
import { createRoot } from 'react-dom/client';
import { DatePicker, message, Alert } from 'antd';
import './index.css';

const App = () => {
  const [date, setDate] = useState(null);
  const [messageApi, contextHolder] = message.useMessage();
  const handleChange = (value) => {
    messageApi.info(`Selected Date: ${value ? value.format('YYYY-MM-DD') : 'None'}`);
    setDate(value);
  };
  return (
    <div style={{ width: 400, margin: '100px auto' }}>
      <DatePicker onChange={value => this.handleChange(value)} />
      <div style={{ marginTop: 20 }}>
      	<Alert message="Selected Date" description={date ? date.format('YYYY-MM-DD') : 'None'} />
      </div>
      {contextHolder}
    </div>
  );
};

createRoot(document.getElementById('root')).render(<App />);
export default App;
import { ConfigProvider } from 'antd';
import React from 'react';


const App: React.FC = () => (
	<ConfigProvider theme={{ token: { colorPrimary: '#00b96b'} }}>
		<MyApp />
	</ConfigProvider>
);

export default App;

海外住所入力フォームのHTMLレイアウトデザイン

通常は、
「郵便番号」「住所1」「住所2」と書いている

これがebayだと「Contry」「Address」「Additional Information」「City」「State/Province」「Region」「Postal Code」の順になる

同じ様に作りたい。

World postal code というサイトで調べられるのね。
https://worldpostalcode.com/

postal code入れたらcityを自動入力できるjavascriptのライブラリとかないのかね
と思ったら、幾つかありそう

アラートメッセージの色(フォントカラー)を考える

アラートメッセージのフォントカラーを考える
Bootstrapを見てみる

#dc3545

#e83e8c

うーむ、まあこれでいいんだけど。。。

### Adobeカラーホイール
adobeカラーホイールで、メインカラーの関連色(類似色、モノクロマティック、トライアド、補色、二色分割、二重分割補色)などから合いそうな色を探す。

カラーホイール使うと、プロっぽくなりますね(苦笑)