TypeScriptで実現するUnity WebGLネイティブプラグイン開発の改善

3K Views

October 25, 24

スライド概要

2024/10/11に実施されたHololab Conference 2024のセッションスライドです。

■セッションアーカイブはこちら


ーーー
■公式HP
https://hololab.co.jp/

■公式Twitter
https://twitter.com/HoloLabInc

profile-image

ホロラボです Unityを使用したHoloLensのアプリ開発を中心にしています。 最近では建設業でのBIMデータ、製造業でのCAD データ、空間の3Dスキャン(点群データやメッシュデータ)も扱っています。 物理世界とデジタル世界をどのように連携するか。ということを日々考えています。

シェア

またはPlayer版

埋め込む »CMSなどでJSが使えない場合

関連スライド

各ページのテキスト
1.

ViteとTypeScriptで実現する Unity WebGLネイティブプラグイン開発の改善 HoloLab Tech Showcase 2024 株式会社ホロラボ 堤海斗 1

2.

アジェンダ 1. はじめに 2. UnityとWebGLネイティブプラグイン 3. WebGLネイティブプラグイン開発の課題 4. プラグイン開発の改善 5. おわりに © 2024 HoloLab Inc. All rights reserved 2

3.

はじめに © 2024 HoloLab Inc. All rights reserved 3

4.

自己紹介 堤海斗 ソフトウェアエンジニア 普段は にー兄さんという名前で活動 業務でUnityを使ったARアプリ開発や Webフロント系の開発 Babylon.js勉強会運営 2024年度Microsoft MVP (Web)受賞 © 2024 HoloLab Inc. All rights reserved 4

5.

本日のお話 UnityのWebGLネイティブプラグイン開発はツライことがある その一部を「JS外部化」と「TypeScript化」で解決してみる試みをご紹介 Lightning Talkかつ本日最後のセッションですので、 どうぞお気を楽にしてご覧下さい~ © 2024 HoloLab Inc. All rights reserved 5

6.

UnityとWebGLネイティブプラグイン © 2024 HoloLab Inc. All rights reserved 6

7.

Unity WebGLネイティブプラグインとは WebGLビルドされたUnityプロジェクトで ブラウザから使えるJavaScriptコードを呼び出すしくみ WebブラウザやサードパーティのJavaScript SDKなどが扱える 使用例) FirebaseをWebGLで使う(Unity SDKはWebGLサポートされていない) ファイル選択やWebSocketなどそのままでは動かない機能 © 2024 HoloLab Inc. All rights reserved 7

8.
[beta]
プラグインの作り方
.jslib ファイルの中にJavaScript関数を記述
mergeInto(LibraryManager.library, {
HelloString: function (strPtr) {
window.alert(UTF8ToString(strPtr));
},
});

C#からDLL呼び出しにより実行
class WebGLPlugin{
[DllImport("__Internal")]
private static extern void HelloString(string str);
}

© 2024 HoloLab Inc. All rights reserved

8

9.

動作原理 UnityのWebGLビルドはIL2CPPビルドの後にEmscriptenによるビルドがされる jslibファイルもその過程で *.framework.js へ展開される 参考:https://docs.unity3d.com/ja/2022.3/Manual/IL2CPP.html © 2024 HoloLab Inc. All rights reserved 9

10.

WebGLネイティブプラグイン開発の課題 © 2024 HoloLab Inc. All rights reserved 10

11.

特殊なJavaScriptコードがもたらす弊害 jslibに記述するJavaScriptコードは特殊 なぜか? -> UnityやEmscriptenの仕様に依存しているから 主に下記のようなツラミがあった モジュール性の欠如 開発体験の悪さ © 2024 HoloLab Inc. All rights reserved 11

12.

コードのモジュール化が難しい import/requireによる参照が(容易に)できない -> 結果、巨大なjslibが出来上がってしまう メンテナンス難易度が上がる 開発体験の悪さ 特殊な環境ゆえにエディタによるコード補完がうまく効かない(JS由来の部分もある) 型検査がうまくできないのでビルドして初めてわかるエラーも多い しかし!jslib変更後のビルドは時間がかかる © 2024 HoloLab Inc. All rights reserved 12

13.

プラグイン開発体験の改善 © 2024 HoloLab Inc. All rights reserved 13

14.

JS外部化:Emscriptenからの解放 特殊なJSコードになるのはEmscriptenへの 依存が原因 -> JS外部化して自前でビルドしよう! Unity・Emscripten非依存になるため 開発環境の選択肢が広がる -> TypeScript / Vite / pnpm / Biomeなど モダンツールを導入しよう © 2024 HoloLab Inc. All rights reserved 14

15.

プラグイン構成と 名前空間を介したAPIアクセス © 2024 HoloLab Inc. All rights reserved 15

16.

例)WebSocket通信 © 2024 HoloLab Inc. All rights reserved 16

17.

C#とTypeScriptの処理を つなげる C#からは名前によるメソッドの参 照が必要(DllImportで指定) TypeScriptからはEmscripten独自 のAPIコールが必要 (UTF8ToStringなど) jslibが二つをつなぐ役割をすることで グローバルな名前空間を介して アクセスするフローを実装(jslib→) © 2024 HoloLab Inc. All rights reserved 17

18.

jslib由来のAPIを型定義 jslib特有のAPIは存在するがブラウザ の名前空間にしかないので、型定義で 対応する 文字列ポインタ・関数ポインタ UTF8ToString / StringToUTF8 dynCall_xxx SendMessage などもしっかり型が付いた状態で使用 可能 © 2024 HoloLab Inc. All rights reserved 18

19.

改善によって得られた恩恵 動作確認のイテレーションが高速化 jslibを変更しないのでビルドキャッシュが効いてビルドが爆速に 一部はUnityを介さずWebフロント単体で動作確認できる TypeScriptやViteによって堅牢で高速に、モジュラリティのあるコードが書けるように モダンWebフロント開発ツールを活用できる この方法の課題 main.jsを別途ビルドする必要がある サードパーティをバンドルするとmain.jsが肥大化する main.jsをコミットするとコンフリクトの原因に(解決も困難) © 2024 HoloLab Inc. All rights reserved 19

20.

おわりに © 2024 HoloLab Inc. All rights reserved 20

21.

まとめ WebGLネイティブプラグインはjslibを作成しEmscriptenを通してビルドされる 特殊な環境制約により開発体験が悪いことがある JS外部化・TypeScript化によって解決を試みた 開発体験が向上したのと同時にデメリットもあった 自分なりに開発体験向上を目指して試行中の段階です。 もしご参考になりましたら幸いです。 © 2024 HoloLab Inc. All rights reserved 21

22.

参考文献 [Unity]WebGLのプラグインをモダンに書く方法 https://qiita.com/yaegaki/items/71cdebc7798784aa3464 とても参考になりました Async/await with jslib plugin?(Unity Discussions) https://discussions.unity.com/t/async-await-with-jslib-plugin/877967 Unity WebGL C# <=> JS (jslib) https://qiita.com/gtk2k/items/9c2679d612e9b5ac7b2e WebGL: ブラウザースクリプトとの相互作用 https://docs.unity3d.com/ja/2022.3/Manual/webglinteractingwithbrowserscripting.html © 2024 HoloLab Inc. All rights reserved 22