2017-10-07 11:43:26 +09:00
|
|
|
---
|
|
|
|
title: Sketch 3 plugin 'StickyGrid'
|
|
|
|
date: 2014-12-03 09:00:00 +09:00
|
2019-08-14 21:24:49 +09:00
|
|
|
redirect_from: "/blog/2014/12/03/sketch-plugin-stickygrid-ja"
|
2017-10-07 11:43:26 +09:00
|
|
|
---
|
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
選択したシェイプのポイントをグリッドに吸い付かせるプラグイン StickyGrid を作りました。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-08-06 15:04:24 +09:00
|
|
|

|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
Vector ツールで軽くスケッチしてからこのプラグインを適用することで、簡単に幾何学的なオブジェクトを作ることが出来る。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
|
|
|
# インストール
|
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
[リリースページ](https://github.com/uetchy/Sketch-StickyGrid/releases/latest)から zip アーカイブをダウンロードし、**StickyGrid.sketchplugin** をダブルクリックしてインストールする。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
もし、より*CLI-way*がお好みであれば、以下のコマンドでもインストールすることが出来る。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
|
|
|
```bash
|
|
|
|
cd $HOME/Library/Application Support/com.bohemiancoding.sketch3/Plugins
|
|
|
|
git clone https://github.com/uetchy/Sketch-StickyGrid.git
|
|
|
|
```
|
|
|
|
|
|
|
|
# 使い方
|
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
吸い付かせたいシェイプを 1 つ、または複数選択して **`ctrl` + `⌘` + `G`** を押すと、パスがグリッドの交差点に吸い付く。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
ショートカット以外にも、メニューから**Plugins > Sketch-StickyGrid > Snap to Grid**を選んでも良い。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
|
|
|
シェイプはもちろん、グルーピングされたシェイプも、逆にシェイプポイントだけでも吸い付く。
|
|
|
|
|
|
|
|
# プラグインの開発にあたって
|
|
|
|
|
|
|
|
## プラグインのデバッグ
|
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
デバッギングには[Sketch-DevTools](https://github.com/turbobabr/sketch-devtools)を使っていましたが、最新版の Sketch では使えなくなってしまった。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
その代わりに Mac 標準アプリの **Console.app** を使う方法が公式デベロッパーサイトの記事 [Debugging - Sketch Developer](http://developer.sketchapp.com/code-examples/debugging/) で紹介されている。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
スクリプト内で`log`関数を呼び出すと、Console.app にログが出力される。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
|
|
|
```js
|
2022-12-24 03:20:02 +09:00
|
|
|
log(context.document.gridSize);
|
2017-10-07 11:43:26 +09:00
|
|
|
```
|
|
|
|
|
|
|
|
## ドキュメントの情報源
|
|
|
|
|
|
|
|
ドキュメントは公式デベロッパーサイト [Sketch Developer](http://developer.sketchapp.com) があるものの、パス編集に関するドキュメントは全くなかった。
|
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
そこで、[class-dump](http://stevenygard.com/projects/class-dump/) を使って Sketch.app のヘッダーファイルを抽出し、ひたすら **目 grep** をしてシェイプ操作とグリッドに関する API を探し出し、プラグインの実装に役立てた。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
また、先人によって公開されている数多の Sketch プラグインのソースを見ることも、開発の助けになった。
|
2017-10-07 11:43:26 +09:00
|
|
|
|
|
|
|
# 結論
|
|
|
|
|
2018-07-19 20:53:12 +09:00
|
|
|
苦行僧じみた Sketch プラグインの開発には **class-dump** と **Console.app** が必携。
|