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
アセットバンドルの管理について
Search
Cygames
November 30, 2015
Programming
7
7.4k
アセットバンドルの管理について
2015/11/15 Cygames Tech Fes
Cygames
November 30, 2015
Tweet
Share
More Decks by Cygames
See All by Cygames
TiDBにおけるテーブル設計と最適化の事例
cygames
3
2k
『グランブルーファンタジー』100万行を超える大規模なシステム再構築~10周年のその先へ~
cygames
11
32k
グラブルミュージアム蒼の追想 MX4Dシアターのサウンド制作事例〜ゲームの世界観とアトラクション体験の両立に必要なこと〜
cygames
0
1.1k
AIによる自然言語処理・音声解析を用いたゲーム内会話パートの感情分析への取り組み
cygames
0
2k
最大100倍高速化!PHPからJavaへのFFIを実現する、JNIを用いた高速なサーバAPIの実装方法
cygames
0
420
AIによる自然言語処理を活用したゲームシナリオの誤字検出への取り組み
cygames
0
280
ツール保守コスト大幅削減!テクニカルアーティストによるツールログサービスの開発と運用事例
cygames
0
320
C#によるクライアント/サーバーの開発言語統一がもたらす高効率な開発体制 ~プリコネ!グランドマスターズ開発事例~
cygames
25
21k
「最高のコンテンツ」を支える、Cygamesのデータベース技術の今までとこれから 〜次世代データベース「TiDB」の検証を開始したCygamesの取り組み〜
cygames
0
5.8k
Other Decks in Programming
See All in Programming
実践!難読化ガイド
mitchan
0
130
Prolog入門
qnighy
4
990
Kotlin 2.0 and Beyond
antonarhipov
2
150
null or undefined
susisu
23
6.2k
Ruby Parser progress report 2024
yui_knk
2
220
REXML改善のその後
naitoh
0
190
Debugging: All you need to know (for simultaneous interpreting)
jmatsu
2
620
Increased Performance and Developer Productivity with Jakarta EE 11
ivargrimstad
0
230
Amebaチョイス立ち上げの裏側 ~依存システムとの闘い~
daichi_igarashi
0
230
Swiftコードバトル必勝法
toshi0383
0
150
Jakarta EE meets AI
ivargrimstad
0
370
How to Break into Reading Open Source
kaspth
1
200
Featured
See All Featured
Practical Orchestrator
shlominoach
185
10k
Rebuilding a faster, lazier Slack
samanthasiow
78
8.6k
Templates, Plugins, & Blocks: Oh My! Creating the theme that thinks of everything
marktimemedia
26
2k
Imperfection Machines: The Place of Print at Facebook
scottboms
263
13k
Building Applications with DynamoDB
mza
90
6k
Ruby is Unlike a Banana
tanoku
96
11k
Understanding Cognitive Biases in Performance Measurement
bluesmoon
26
1.3k
Infographics Made Easy
chrislema
239
18k
How GitHub (no longer) Works
holman
310
140k
What the flash - Photography Introduction
edds
67
11k
Java REST API Framework Comparison - PWX 2021
mraible
PRO
27
7.4k
The Illustrated Children's Guide to Kubernetes
chrisshort
47
48k
Transcript
None
⾃自⼰己紹介 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • 中村克也 •
エンジニアマネージャー • Unityを使⽤用した社内ライブラリ開発・運⽤用 • 社外窓⼝口 • エンジニアのリクルート
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
• Cygamesでは、Unity5リリースと同時期に開発中プロ ジェクトに関してはUnity5へ移⾏行行 • Unity4からの変更更部分で⼤大きい部分は、アセットバンド ルビルド • Unity4のビルド資産を破棄して、再構築を試みる • とりあえず作って、使ってみる、後追いでリファクタリ
ング(他PJへ横展開できるように) $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
<講演ファイル> http://japan.unity3d.com/unite/unite2015/files/DAY1_̲1300_̲room2_̲Ito.pdf <サンプルプロジェクト> http://files.unity3d.com/vincent/assetbundle-‐‑‒demo/users_̲assetbundle-‐‑‒demo.zip $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
2015/3 Unity5リリース Unite2015での講演から ベースはこれを参考に進めました。
アセットバンドルに関しては、 シングルマニフェストとバリアントの2つが⼤大きな機能追加 ですが、 今回のプロジェクトでは両⽅方とも使⽤用することをやめました。 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
全アセットバンドルのCRC/依存関係/ハッシュなどを持った、 ⼀一意のファイル BuildPipeline.BuildAssetBundlesで指定した出⼒力力フォルダ名 で出⼒力力される $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
シングルマニフェストの中⾝身 個別マニフェストの中⾝身 CRC/Hash/Dependenciesの情 報を持ってて便便利利 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
なぜ使わないのか。 『1回のビルド出⼒力力で1つのシングルマニフェストが作成される』 これがネック。 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
例例えば、上記のようなフォルダを⽤用意してアセットを管理理す る場合フォルダ(カテゴリ)ごとにビルドしたい! というニーズに3つのAndroid.manifestが作成される。 root Assets Resources Bg 背景画像 Chara キャラ画像
3d 3dアセット フォルダ構成 Android.manifest (Bg) Android.manifest (Chara) Android.manifest (3d) 同名なので管理理できない $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
結果、同等の情報を持った独⾃自のリソースリストを作成する ことに。 カテゴリごとに、name/hash/version/groupをCSVでア セットバンドルビルド時に出⼒力力するように。 name hash version group bg_001.unity3d 621a0f92b9f32c8126f2aa6af5ab4cc7
00000000 common bg_002.unity3d 3d534a8f488cdf3f50837d7ed337d2c3 00000000 common bg_101.unity3d 45b0bab78240018ee411401410c2dbe2 00000000 tutorial_g1 bg_102.unity3d 4095525f35ea45a83ddf67b8ec4178ff 00000000 tutorial_g2 bg_103.unity3d 66d254f9fb533dcf90463f7d96ce2a54 00000000 every bg_104.unity3d 7798907c2e4d18a0f3b5e509377e7680 00000000 every Unity4でも同じことしてました。。 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
解決策はある 出⼒力力先を変えることで、名前が変えられる 分散出⼒力力されるマニフェストとランタイム側で複数マニフェ ストを管理理することで解決はします。 AndroidBg.manifest(Bg) AndroidChara.manifest (Chara) Android3d.manifest (3d) 開発中の運⽤用が複雑になる。
独⾃自フォーマットのリストには柔軟性で敵わない。 Groupタグとか便便利利 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
HD(⾼高画質)とSD(標準画質)を同じアセットとして扱え る仕組み $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE Hoge.unity3d.hd Hoge.unity3d.sd
別のバンドルを同じものと⾒見見なして切切り替 えする
なぜ使わないのか。 『プロジェクトにHD/SD2つのリソースを管理理する必要がある』 これがネック。 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
デザイナーには、HD版1リソースで作業させる (SD版を意識識させたくない) SD版は⾃自動⽣生成するように、対象はテクスチャです。 変換svを別途⽤用意、変換処理理を経由してアセットバンドル ビルドsvへ Repository 変換sv Build sv リソースsv
リサイズ (50%) & 減色 clone cp rsync $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
サウンドとムービーは⾃自動化しない ⾼高⾳音質(画質)/標準⾳音質(画質)は、デザイナにそれぞれ出 ⼒力力してもらい、リポジトリでHD/SDを管理理 Repository 変換sv Build sv リソースsv リサイズ (50%)
& 減色 clone cp rsync clone AB(HD)/Sound/Movie AB(SD) サウンド、ムービーも品質を分けるのでCygamesでは HD/SD-‐‑‒>High/Lowと呼ぶように $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
リソースサーバーの階層構造 00000000/High/AssetBundle/Android など 品質をデバイスのスペックに合わせて変更更する バージョン 品質 種類 プラットフォーム 00000000 High
AssetBundles Android 00000001 Low Sounds iOS 01010001 Movies PC $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
品質レベル基準 デバイスの搭載RAMで判断、アプリ初期化時にデバイス チェック。 512Mb未満は『Low』 512Mb以上は『High』 デフォルトで決まった品質レベルは、 オプション画⾯面などでユーザーが任意で切切り替えられるよう に動的に対応できるようにする。 切切り替え後は、対象の種類ごとにストレージから全削除し再 ダウンロードさせる。共存不不可。
$POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
Low版の必要性 搭載RAM512Mb未満の端末は、国内Android端末では2012 年年初発売端末までさかのぼる。 iOSはiPhone4s(2011年年)以前。 シェア的に微妙なところ、 ⾮非推奨とした上で採⽤用判断はプロジェクトにお任せ $POGJEFOUJBM $PQZSJHIU $ZHBNFT
*OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
Unity4では、PushしてPopして、ビルドシーケンスが複雑 いつロードされて破棄されてるのか不不明確 シングルマニフェスト使いたくない (前述の独⾃自リソースリスト使いたい) $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アセットバンドルは、共有アセットバンドルと固有アセット バンドルを分けて作成 CommonShader CommonMaterial Model001 ModelTexture001 CommonTexture 3DCommonShader.unity3d 3DCommonTexture.unity3d 3DCommonMaterial.unity3d
3DCharaModel001.unity3d 3D Build Group ModelMaterial001 AssetImporter::assetBundleNameを全て設定してから BuildPipeline.BuildAssetBundles() アセットの依存が残り、依存するアセットは固有バンドルに 格納されない $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
シーン単位なのか、画⾯面単位なのか、アセットのライフスパ ンを明確にして、共有アセットバンドルのロード 固有アセットバンドルのロード、アンロードを管理理する Object/ABの破棄 固有AB DL/Load Load順番は、⼦子から ある⼀一定の状態 (バトル、xx画⾯面など) 開始処理理
終了了処理理 CommonShader CommonTexture CommonMaterial Model001 共有AB DL/Load $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
①1プロジェクト構成 ソースコード(アプリ)、リソース を1つのプロジェクトに全て含める $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE Game
script resources Prein 3D UI Card resources 3D Editor script Editor script resources UI Editor script BG resources Prein Game script Title. unityproject Title. unityproject 3DWork. unityproject UIWork. unityproject ②複数プロジェクト構成 アプリとカテゴリごとのリソースで分ける 3D/UI/Cardなど、アセットバンドルビル ド⽤用プロジェクトに分ける
メリット、デメリットを考える ①1プロジェクト構成 リソース作成-‐‑‒>即時プレビュー。ゲーム上で確認したい。 プロジェクトの肥⼤大化。 ②複数プロジェクト構成 プロジェクトはシンプル。作業に必要なプロジェクトだけ使う 確認に⼿手間がかかる (ビルドしてサーバーアップして。。) ※カードビューアー、モデルビューアーといった 最終形を担保できるツールを別途⽤用意する必要がある
結果:①を採⽤用することに ソースとリソースのリポジトリは分けます $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
root Assets ①_ProjectName Resources プリインストールリソース Scenes Scripts ②_ProjectNameResources Resources アセットバンドルリソース
リソースリポジトリで管理 アプリビルド時はcloneしない ③_ProjectNameDebug xxx デバッグツールなど アプリビルド時にフォルダごと削除 Plugins StreamingAssets その他assetフォルダ プロジェクトフォルダ構成 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
1プロジェクト構成のメリットは、ローカルに置いたアセッ トを直接ロードできる アセットバンドルとローカルアセットのロードを吸収するク ラスでResourcesのロードをラップする public T LoadObject<T>(string assetName, string objectName,
bool isServerResources = true) where T : Object { if (!isServerResources) { // Resourcesから return Resources.Load<T>(objectName); } else { // AssetBundleから var o = assetManager.LoadObject(assetName, objectName, typeof(T)); if (o != null) { return (T)o; } // なければResourcesから T resource = Resources.Load<T>(objectName); return resource; } } $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
アセットバンドルのダウンロード WWW.LoadFromCacheOrDownload ・キャッシュサイズ上限 ・Caching.ready肥⼤大化 ・150⽇日制限 ⻑⾧長い運営を⾒見見据えると不不向き 前述した、独⾃自のリソースリストで管理理するようにして WWW.LoadFromCacheOrDownloadを使わないように $POGJEFOUJBM $PQZSJHIU
$ZHBNFT *OD "MM3JHIUT3FTFSWFE
・アプリ初期化時に最新のリソースリストをダウンロードしておく ・アセットバンドルを1度度DLしたらハッシュをセーブする ・ 2回⽬目以降降は、セーブしたハッシュと独⾃自リストのハッシュ、 バージョンから再DLチェック ・差分があれば再DL この繰り返し 初期化時:リソースリストダウンロード ②差分ありダウンロード(www) ③ハッシュセーブ
①セーブデータハッシュチェック $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アセットバンドルからのロード AssetBundle.CreateFromFileを使⽤用したいのですが、 BuildAssetBundleOptions.UncompressedAssetBundle 付けないとロード出来ない(無圧縮アセットバンドル) おおよそな数値ですが、実例例では 5,000アセットバンドルで2.5GBくらいになってしまった。 $POGJEFOUJBM $PQZSJHIU $ZHBNFT
*OD "MM3JHIUT3FTFSWFE
アセットバンドル⾃自体を圧縮することに。 5,000ファイル:2.5GB -‐‑‒> 450MB ※アルゴリズムは⾮非公開。 アセットバンドルビルドシーケンス アセットバンドルロードシーケンス AssetImporter.assetBundleName BuildPipeline.BuildAssetBundles
圧縮 ハッシュ生成 リソースリスト生成 www ダウンロード 解凍 AssetBundle.CreateFromMemory 管理クラスに登録 圧縮したままストレージへ保存 解凍時にメモリに乗るのでFromMemory使う $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
アジェンダ $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE • Unity4からUnity5へ •
Unity5の新要素について • シングルマニフェスト • バリアント • 依存関係 • リソース管理理 • ロードAPIと圧縮 • Jenkins連携 • おまけ • 質疑応答
$POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE アプリとアセットバンドルのビルドは、Jenkinsで⾃自動化、 NightlyBuild(安定版)と⼿手動ビルドを使い分ける 出⼒力力されたアプリは、配布サーバーへ転送される 出社と同時に、最新リソースでチェックできるように
ビルドマシン:Mac mini(2012年年モデル Intel Core i5 2.5GHz) アプリビルド30分、 アセットバンドルビルド2時間(1プラットフォーム) ビルドマシン:Mac Pro(mem
64GB DDR ECC) アプリビルド5分、 アセットバンドルビルド15分(1プラットフォーム) $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
PC High/Low BuildTarget.WebPlayer iOS High iOS Low Android High Android
Low PC/iOS/Android Low 画像コンバート $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
Mac Pro 5台! やりすぎ反省省。。 現在は1台の並列列jobで⼗十分対応できてます $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD
"MM3JHIUT3FTFSWFE
LTE7GB超過したユーザーの国内キャリアの128kbps速度度制限対策 iOSの場合、(「設定(デベロッパ)」)で通信速度度変更更できる ファイルサイズ6、7Mbくらいでダウンロードできなくなっている アセットバンドルを細かく、多くの⽅方針が功を奏して1ファイルのサイズ を軽減していた でもオーバーするものもあったサウンド、ムービーなど ダウンロードしないオプションを⽤用意 サイズオーバーしているムービーは泣く泣く削除したり。 おまけ $POGJEFOUJBM
$PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
• シングルマニフェストは使わず、依存関係は使い⽅方でカバー • バリアントは、サーバーリソースでスイッチする • LoadFromCacheOrDownloadを使わず、バージョンチェックは⾃自 作リストでまかなう • ⾮非アセットバンドル状態のリソースを使えるように •
jenkinsで常に最新のアプリ、アセットバンドルを提供するように 振り返り $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE
懇親会で気軽にお声掛けください。 質疑応答 $POGJEFOUJBM $PQZSJHIU $ZHBNFT *OD "MM3JHIUT3FTFSWFE