Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
スキャンデータを使った リッチなVFXを軽率に作ろう
Search
にー兄さん
March 05, 2021
Technology
0
730
スキャンデータを使った リッチなVFXを軽率に作ろう
yokohama.unity mini #7でLTと運男子たときの資料です
にー兄さん
March 05, 2021
Tweet
Share
More Decks by にー兄さん
See All by にー兄さん
軽率にAndroidXRのJetpack SceneCoreを使って3Dモデルを表示してみる / androidxr-scenecore-3dmodels
drumath2237
0
35
UnJSを使って軽率にCLIを作ってみたらめちゃくちゃ便利だった / create CLI with UnJS
drumath2237
4
1.5k
create-babylon-appを軽率にアプデしたい / update create babylon app
drumath2237
1
1.6k
Babylon.js 7注目機能を 軽率にまとめてみる/whats-new-in-babylonjs-v7
drumath2237
1
320
軽率にVFX Graphと Compute Shaderを 組み合わせるテクニック/integrate-vfxgraph-and-compute-shader
drumath2237
1
400
軽率にVue 3で リアルタイム3Dアプリを作れる ライブラリを作ってみた/vue-with-3d-app
drumath2237
3
1.9k
軽率にBabylon.jsを C#で使う技術 / using-babylonjs-with-csharp
drumath2237
1
870
今こそ軽率に理解したい WebXR Device APIとBabylon.jsの話 / understand-webxr-device-api-and-babylonjs
drumath2237
0
220
Vue・Babylon連携ライブラリ BabyuewJSについて / about-babyuewjs
drumath2237
0
190
Other Decks in Technology
See All in Technology
Pwned Labsのすゝめ
ken5scal
1
390
AI Agent時代なのでAWSのLLMs.txtが欲しい!
watany
2
220
Potential EM 制度を始めた理由、そして2年後にやめた理由 - EMConf JP 2025
hoyo
2
2.6k
Share my, our lessons from the road to re:Invent
naospon
0
140
Snowflakeの開発・運用コストをApache Icebergで効率化しよう!~機能と活用例のご紹介~
sagara
1
430
4th place solution Eedi - Mining Misconceptions in Mathematics
rist
0
140
Amazon Q Developerの無料利用枠を使い倒してHello worldを表示させよう!
nrinetcom
PRO
2
110
1行のコードから社会課題の解決へ: EMの探究、事業・技術・組織を紡ぐ実践知 / EM Conf 2025
9ma3r
10
3.7k
AIエージェント元年
shukob
0
160
【詳説】コンテンツ配信 システムの複数機能 基盤への拡張
hatena
0
230
内製化を加速させるlaC活用術
nrinetcom
PRO
2
140
AIエージェント元年@日本生成AIユーザ会
shukob
1
200
Featured
See All Featured
Done Done
chrislema
182
16k
The Art of Programming - Codeland 2020
erikaheidi
53
13k
Fantastic passwords and where to find them - at NoRuKo
philnash
51
3k
The Illustrated Children's Guide to Kubernetes
chrisshort
48
49k
The Psychology of Web Performance [Beyond Tellerrand 2023]
tammyeverts
46
2.3k
A Philosophy of Restraint
colly
203
16k
A designer walks into a library…
pauljervisheath
205
24k
Side Projects
sachag
452
42k
A Tale of Four Properties
chriscoyier
158
23k
Writing Fast Ruby
sferik
628
61k
Cheating the UX When There Is Nothing More to Optimize - PixelPioneers
stephaniewalter
280
13k
Chrome DevTools: State of the Union 2024 - Debugging React & Beyond
addyosmani
4
370
Transcript
スキャンデータを使った リッチなVFXを軽率に作ろう yokohama.unity mini #7 にー兄さん
自己紹介 にー兄さん(@ninisan_drumath) 筑波大学情報科学類3年 主にUnityを用いた開発が多い AzureKinect / VFX Graph / xR
/ Humanoid / WebGL yokohama.unity初参加なのでちょっと緊張
スライド&サンプルは全て公開しています✨ 途中で自分の3Dスキャンも出てきますが、 フリー素材(??)なのでスクショの共有は問題ないです🤔
agenda はじめに 素材の準備 Unityでの作業 最後に
はじめに
今回やりたいこと! 特定の形状の上をパーティクルが這って回るようなVFX 自分のスキャンデータを使ってやってみたい Unite2019の高橋啓治郎氏のセッションからとても影響を受けています 実現するにはちょっと工夫が必要......? →やってみよう! サンプルプロジェクトはGitHubに公開してあります! →https://github.com/drumath2237/KinFuSDFVFX
実現方針 形状に沿うように動くようにするには 形状の法線ベクトルが必要になる しかも空間上の任意の点において 物体から遠ざかる方向のベクトルが必要 それらと別のベクトルとの外積を計算すると 特定方向に向かって 形状に沿ったベクトルが得られる なにかの 3次元形状
今回使うツールと手順 1. 自分のスキャンデータを作る 2. HoudiniでSigned Distance Fieldを作成する 3. VFX Graphで演出を作る
Azure Kinect Houdini Unity VFX Graph
素材の準備
KinectFusionでスキャン KinectFusionを使うと点群を元にメッシュを張れ るらしい 詳しいセットアップの記事があったので いざやってみることに https://medium.com/kadinche-engineering/azure-kinect-dk-%E3%81%AE%E9%96%8B%E7%99%BA%E7%92%B0%E5%A2%83%E6% A7%8B%E7%AF%89%E3%81%8B%E3%82%89-kinectfusion-%E3%81%AE%E3%82%B5%E3%83%B3%E3%83%97%E3%83%AB%E3%82 %92%E5%8B%95%E3%81%8B%E3%81%99%E3%81%BE%E3%81%A7-cd7d550994fe Azure-Kinect-Samplesの中のkinfuサンプルを 使用
KinectFusionから点群データを取得 KinectFusionからply形式の点群データを出力 PositionとNormalがある (残念ながらColorはなさそう) CloudCompareとかで見ると良い感じ
SDFの作成 Signed Distance Field →点から形状への距離と勾配ベクトル(遠ざかる方向のベクトル) →これらを3Dテクスチャとしてベイクする →.vfファイルとしてVFX Graphに読み込める Houdiniによってメッシュデータから作成可能 Unity公式から出ている
VFXToolboxというアセットを使用 https://github.com/Unity-Technologies/VFXToolbox
Houdiniでの作業 1. VFXToolboxのhdaをインストール 2. ply点群ファイルをそのまま読み込み 3. Particle Fluid Surfaceノードでメッシュ化 4.
VFXToolboxでPointCacheとSDFを生成 5. pcacheファイルとvfファイル×2が得られる
Unityでの作業
VFX Graphについておさらい - GPUパーティクルシステム - パーティクルの挙動や見た目を ノードで定義 - Unity2019~Varifiedになった -
SRP環境でのみサポート 今回は表現の幅が広いHDRPを採用 Unity VFX Graph Manualより
PointCacheについて - 複数の座標をまとめたデータ(語弊あり) - メッシュの側面からパーティクルを スポーンさせたりできるようになる - フォーマットは汎用的な点群ファイルと似 通っている(.plyとか.xyzとか) -
非パラメトリック形状にとても有効 - 点群VFXが捗る捗る - 普通のメッシュであればUnityで作成可能 unity3d.comより
- 現在ではPropertyとして配列を受け渡せない - ではどうするか? - Textureに情報を焼いて渡す - ただの1次元の配列であれば height 1のテクスチャにする
- Texture2DArrayや3DTextureなどは扱えるし、 Sampleノードがちゃんとある(後述) - パフォーマンスによってはComputeShader を組み合わせてテクスチャを作成することも 余談:VFX Graphは配列を扱えない
VFX GraphでSDF/VFを扱う - .vfファイルとして読み込んだデータは 3Dテクスチャとして扱われる - Unity2020からインスペクタでプレビューされ て嬉しい - Sample
Texture3D、Load Texture3Dなどの ノードで使うことができる - SDFを使ったノードがあり、結構面白いことが できる - もっと気軽にSDFが 作れるようになったら嬉しいな
VFX Graphの処理フロー 1. PointCacheからランダムな座標で 位置を初期化 2. 現在位置から勾配ベクトルを取得 3. 勾配ベクトルと特定ベクトルの外積を計算 (今回はPerlinCurlNoise3Dとの外積)
4. 外積方向にForceを設定する 5. 散らばっていかないように空気抵抗を足す 6. Outputコンテキストへ
完成!🎉
おわりに
まとめ&お気持ち - VFX GraphはSDFを使うとリッチな表現ができる - SDFの生成はちょっと大変かも(外部ツールを使うので) - 「ビジュアライゼーションのプラットフォームとしてVFX Graphはとても有効」 by
高橋啓治郎氏 - 構想→調査→実装→リリース→LTまで8日くらいで とてもテンポよく取り組めた。脳汁すごい。サマーインターンかな? - 知らない技術の検証とかは好きなので、とても楽しかった
参考 今回のサンプルプロジェクト: https://github.com/drumath2237/KinFuSDFVFX Azure Kinect SamplesのKinectFusion: https://github.com/microsoft/Azure-Kinect-Samples/tree/master/opencv-kinfu-samples VFXToolbox: https://github.com/Unity-Technologies/VFXToolbox Unite
Tokyo 2019のVFX Graphのセッション: https://learning.unity3d.jp/3276/ VFX GraphのVectorFieldに関するマニュアル: https://docs.unity3d.com/Packages/
[email protected]
/manual/VectorFields.ht ml