概要
Leap Motion + Unity 2017.3 + Mac で、3Dお絵かきアプリを開発してみました。
Leap MotionのUnity向けのパッケージ「LeapMotionCoreAssets」をベースにしています。
leapmotion/LeapMotionCoreAssets
前提条件
Unityの初歩的知識(シーンについてなど)、使い方が理解できていること。
以下のサイトなどで使い方を学習しておくとよいでしょう。
Unity 概要 - Unity マニュアル
環境
以下の環境で開発しました。
- Leap Motion ソフトウェア バージョン:2.3.1+31549 Firmware Revision: 1.7.0
- Unity Version 2017.3.1f1 Personal
- MacOS High Sierra バージョン 10.13.3
開発環境構築
Leap Motionのセットアップ
以下のサイトより、Leap Motionのセットアップを行います。
Desktop Setup — Leap Motion
Unityのインストール
以下のサイトを参考に、Unityのインストールを行います。
[Unity2017.3をMacにインストールする]
(https://qiita.com/shiutk/items/69b8ceaea0be09dcebea)
Unityでプロジェクトを新規作成
まず、Unityを起動し、「New Project」をクリックします。
data:image/s3,"s3://crabby-images/1bb07/1bb0700350eaa915a1dfb9beeb8ee8d8d34d4e11" alt="Start_Unity.png"
次に、Project nameとLocationを設定します。
一例として、Project nameを「3DPainting」、Locationを「/Users/ユーザ名/UnityProjects」に設定します。
data:image/s3,"s3://crabby-images/c8ea4/c8ea4e1e56554428148f95c15714bbb53540e2b5" alt="Create_Project.png"
そして、「Create project」をクリックすると、先ほど作成したプロジェクトが開きます。
data:image/s3,"s3://crabby-images/bdb13/bdb136b264a7c5c064dda8c9f281279889aacdcf" alt="Open_Project.png"
LeapMotionCoreAssetsのインポート
まず、以下のサイトより、LeapMotionCoreAssetsをダウンロードします。
バージョンは「2.3.0」にします。
(それより上のバージョンだとMacに対応していない模様。。)
Release Leap Motion Core Assets v2.3.0 · leapmotion/LeapMotionCoreAssets · GitHub
次に、「Assets」 -> 「Import Package」 -> 「Custom Package...」を選択し、ダウンロードしたLeapMotionCoreAssetsをインポートします。
インポート時、以下の画面が表示されますが、「LeapMotion+OVR」と、「OVR」のチェックを外した状態で「Import」をクリックします。(ちなみに、「OVR」とはOculusのことのようです。)
data:image/s3,"s3://crabby-images/9ce73/9ce73b62830fffe0a1c56ee7bd692bcae1810740" alt="Import_Unity_Package.png"
LeapMotionCoreAssetsを使ってみる
一例として、「VoxelHand」を使用してみます。
まず、「Assets/LeapMotion/Scenes」に移動し、「VoxelHand」をダブルクリックします。
data:image/s3,"s3://crabby-images/06e54/06e5483ae62f706f93fa62f79b3a26edf5827519" alt="Select_Scenes_VoxelHand.png"
すると、シーンが読み込まれるので、画面上部の再生ボタンをクリックします。
data:image/s3,"s3://crabby-images/9881b/9881b302d01d5cf0de2990ebb8d8558702300508" alt="Play_VoxelHand.png"
そして、LeapMotionに手をかざすと、以下のようにボクセル化された手が出現します。
data:image/s3,"s3://crabby-images/57947/579476cee3e466654183afcf23eb225bb5c5e7ee" alt="Playing_VoxelHand.png"
3Dお絵かきができるようにカスタマイズしてみる
まず、Hierarchyから「VoxelHand」を選択し、「Add Component」をクリックします。
data:image/s3,"s3://crabby-images/d7bd0/d7bd045366ad7f4a21019bd8de6db1c379bea06b" alt="Select_GameObject_VoxelHand.png"
次に、検索欄に「Trigger」と入力し、「Trigger Drawing」を選択します。
すると、VoxelHandにTrigger DrawingがComponentとして追加されます。
data:image/s3,"s3://crabby-images/9f500/9f50091831ccd89155219dbf9396b66e3915d9e9" alt="Add_Component_Trigger_Drawing.png"
同様の手順で、「Line Renderer」もComponentとして追加します。
data:image/s3,"s3://crabby-images/7ec44/7ec440dc0d66b15c7fd0e77ee8f6965fe2b6cc86" alt="Add_Component_Line_Renderer.png"
追加できたら、先ほどと同様に画面上部の再生ボタンをクリックします。
そして、LeapMotionに手をかざして、人差し指を指した状態で動かすと、指でなぞった部分が以下のように黒く描画されます。
data:image/s3,"s3://crabby-images/eb23e/eb23e44500f555269aa45a9590b5d06fb634e6ab" alt="Play_3DPainting.png"
作成したソースコード
以下にありますので、ご自由にお使いください。
hiesiea/3DPainting