これは何
- 私MonoのFigmaファイルを初めて触るエンジニアに最低限の機能を教える記事。
- 他のFigmaファイルに対しても8割くらいは応用が効く内容になっていると思います。
心構え
- 開発 >> デザイン
- 特にハッカソンでは、技術がメインで評価されます。
- デザインに時間がかかって動かないプロダクトを作るよりは、全てデフォルトコンポネントでダサいけれど動く物を作る方ががマシだと思ってます。
- デザイナーは実装の大変さを分かってない
- 実装が無理ゲー、もしくは膨大な時間がかかるデザインを気づかずに行っていることがあります。
- デザインを変更する方が良い場合もあるので、早めの相談待ってます。
- デザイナーはミスしがち
- プログラミングと違い、FIgmaは適当なデザインを見てもエラーを吐いてくれません。
- ミスを見つけたら速攻でデザイナーに教えてあげましょう。
はじめに
Figmaのファイル構成について
- File
- Desgin System Page
- スタイル、コンポネント、素材などをまとめている
- Layout Page
- 実際の画面のデザインをまとめている
- Prototype Page
- プロトタイプを作る用のページ
- デモ用に最適化されているので、エンジニアは見る必要なし
- Desgin System Page
命名について
- Figmaのスタイル名とプログラミング変数名を一致させるのが理想です。
- しかし、Figmaは検索の観点から命名が特徴的です(「/」使いがち)。よって、プログラミングで利用されるものと異なる場合が多いです。
- また、ハッカソンなどの場合は時間が少ないので、デザイナーとエンジニアがそれぞれ使い慣れた別の命名を利用しても良いと思っています。
サイズについて
- 8の倍数を基本としてレイアウトしています。
デザインをどこまで反映すればよいか
- 色、テキスト
- 反映してください
- コンポネント
- 最低限種類は合わせてください
- 余裕があればデザインに見栄えを近づけてください
- 間隔
- 1つのデバイスに対しては反映してください
- 多デバイスへのメディアクエリなどは後回しで
- 要素の階層、機能
- 参考程度で反映させる必要はありません
- デザイナーが変更しやすいFigmaファイルにした場合、マークアップ言語の構造と全く別物になる可能性があります。
- コンポネント
- 参考程度で実際の画面を優先してください
- コンポネントはLayout Pageにあるもので、インスタンスを同時に変更できる便利機能です。ただ、インスタンスのみを変更して配置した場合もあるので、実際の画面も適宜確認してください。
便利機能
optionで距離を測る
- オブジェクトをクリック
- optionを押しながら、別のオブジェクト上をマウスでなぞる
- 距離が表示される
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2F9a0a44f4-b7e3-212b-fd9e-317519ff1871.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=7a000af815d0dafef371789da0a51103)
commandクリックで深い層のオブジェクトを選択
- command + クリック
- 深い階層のオブジェクトを一度で選択できる
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2F9b8052c7-5ad2-e989-3d27-122bc39c5df3.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=9b292e6f0db135cedd845d3283301d8d)
command + Yでアウトラインを見る
- command + Yでアウトラインを見れる
- 重なっているオブジェクトや、Auto Layoutが見やすい
右パネルを使って
画像出力
- 出力したい画像をクリック
- 右パネル一番下のExportの「+」をクリック
- PNGやPDFなどの形式を選んで出力(PNGの場合はRetinaディスプレイに対応させるために「数x」を調節できる)
※ちなみにアイコンはコードで埋め込めるという点でGoogle Material Desginのアイコンを利用していることが多いです。その場合はFigmaから出力する必要はありません。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2F82c841ef-4313-cba4-bfa7-347b35d8c914.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=be6af303d92afb56ad76e0c845b7a56a)
InspectパネルでStyle(色、テキスト)一覧を確認
- 右上のタブをInspectにする
- 何もないところをクリック
- 右パネルにスタイル一覧が表示される
- Editアイコンをクリック
- 詳細を見れる
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2F39e78b03-7b46-72d8-7551-f51762e7365f.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=51c164010db8160675849c1adae55b40)
InspectパネルでCSSを見る
- 右上のタブをInspectにする
- 要素をクリックスすると、描画しているCSSが見える
Spacing
「Figmaのモバイル設計手法へ」から、エンジニアが最低限知っておくべき情報だけ解説します。
Auto Layout
- 機能
- CSSのFlexのようなもので、要素を縦や横に一列に並べられる
- 要素を一定の間隔を空けて並べられる
- 問題点
- 個別の間隔を指定できない
- 解決策
- 間隔を0にして、空オブジェクトを差し込む
#spacing
- オブジェクト間に差し込むカラフルなオブジェクト
- 大体8の倍数になっている
※CSSなどは各オブジェクトがmarginを持てるので、空オブジェクトを作る必要はありません。見栄えのみを参考にしてください。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2Facec86ca-b9c7-1f5b-7f4f-ec39f0b85e08.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=da6799e8e653d6f3395c4061007d1fda)
Spacing Manager
- #spacingという名前のオブジェクトの表示、非表示を切り替えられるプラグイン
- 利用方法
- Spacing Manager に飛ぶ
- Install
- Figmaファイル内の左上のアイコン → Plugin → Spacing Manager →
- Show / Hide spacings in current page(表示もしくは非表示)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2F8c7482e5-d407-bc28-e68b-aed317f12220.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=2b12bf74e8aacbe440a44a7bf0ac2a52)
Prototype
右上からPrototypeモードに切り替える。
画像遷移の詳細を知る
- 画面遷移が設定されている画面をクリックする
- 矢印をクリック
- 詳細を確認
- Navigate to は普通の画面遷移
- Overflowはダイアログなどの、元の画面の上に表示する画面遷移
- 他にも画面遷移の時間、トランジション、配置位置などが確認できる。
(矢印がない場所の画面遷移はノリで頑張って)
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F504385%2F50789b88-59df-434d-b881-3508c7648758.jpeg?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=017b4cd352b2765a1bb1de2e7049e0a1)
動きを見る
- PC
- スタートしたい画面を選択後、右上の再生ボタンをクリックする
- スマホ(おすすめ)
画面からはみ出した要素はスクロール
- Figmaは一番親のFrame(デバイスサイズのFrame)から、子要素がはみ出しているとPrototype中にスクロールできます。(デザイナーがVertical/Horizontal Scrollを指定している場合)
- このはみ出している部分を非表示にした場合は、デバイスサイズのFrameを選択 → 右パネルのClip Contentをオンにしてください