Unity Package Manager は Unity 公式のパッケージ管理システムです。以下を行います。
Package Manager を使用して、プロジェクトの依存関係の定義、 パッケージの依存関係の解決、必要に応じたパッケージのダウンロードと追加、プロジェクトのコンテンツの統合を行うことができます。
パッケージとは何か、Unity Package Manager のしくみに関する一般的な情報は、Unity Package Manager のドキュメントを参照してください。
パッケージは以下を含むことができます。
ノート: Package Manager はパッケージ内のストリーミングアセットをサポートしていません。代わりに Addressable パッケージをご利用ください。
各パッケージには、パッケージ名、バージョン、 依存関係のリスト、リポジトリへの URL などの情報を含む パッケージマニフェスト ファイルも含まれます。
新しいパッケージを作成する手順は以下の通りです。
以下のいずれかの方法で、パッケージの空のシェルを作成します。
フォルダー構造体の レイアウト が Unity パッケージの パッケージレイアウト規則 に従っていることを確認してください。例えば、エディターと Runtime のライブラリがある場合は、それを Editor
と Runtime
フォルダーに格納してください。
パッケージにコードが含まれている場合は、作成したパッケージレイアウトに必要なアセンブリ定義ファイルがあることを確認してください。アセンブリ定義ファイルの作成と定義については、アセンブリ定義とパッケージ を参照してください。追加情報については、アセンブリ定義 を参照してください。
ノート: アセンブリ定義ファイルを加えた後にコンソールウィンドウが警告を表示する場合は、プロジェクトを保存して閉じ、再度開いてください。
ツール、ライブラリ、パッケージが必要とするアセットを加えます。
パッケージにテストを追加する。テストは、パッケージがさまざまなシナリオで期待通りに動作することを保証するために不可欠です:
Tests/Editor
に書き込みます。Tests/Runtime
に書き込みます。パッケージのサンプルがある場合は、適切なサンプルサブフォルダー に加えてください。
ノート: パッケージにはサンプルのみを加えることができますが、同じレイアウトと JSON 構造を使用して、ツールやテンプレートのパッケージの一部としてサンプルを加えることもできます。
新しいバージョンを公開するたびに、CHANGELOG.md
ファイルを更新することができます。すべての新機能やバグ修正は、このファイルにトレースがあるはずです。選択した変更ログフォーマットの詳細については、変更履歴を記録する を参照してください。
このステップは、共有しないパッケージの場合はオプションですが、共有パッケージには強く推奨されます。このようにすれば、ユーザーはどのバージョンが自分のニーズに最も適しているかを知ることができるからです。
ヒント: パッケージの package.json
マニフェストファイルの changelogUrl プロパティを設定することにより、このパッケージの変更ログをホストする外部 Web ページへのリンクを提供できます。
LICENSE.md
と THIRD PARTY NOTICES.md
ファイルに ライセンスとサードパーティの通知 を加えることができます。
このステップは、共有しないパッケージの場合は必須ではありません。ただし、共有パッケージには強く推奨されます。これは、ユーザーがパッケージを誤用したり、サードパーティのライセンスに違反することを防ぐために役立ちます。
ヒント: パッケージの package.json
マニフェストファイルの licensesUrl プロパティを設定して、このパッケージのライセンスとサードパーティのお知らせをホストする外部 Web ページへのリンクを提供できます。
パッケージを文書化する。
ヒント: パッケージの package.json
マニフェストファイルの documentationUrl プロパティを設定して、このパッケージのドキュメントをホストする外部 Web ページへのリンクを提供できます。
パッケージを 共有 します。
プロジェクトフォルダー内 にカスタムパッケージを作成する場合は、以下の手順で行います。
ノート: これらの手順は、カスタムパッケージの作成 の手順の一部です。
Unity Hub を開き、コンピューターに 空のプロジェクトを作成 します。
コンピューター上の既存のプロジェクトを使用して、パッケージをプロジェクトに埋め込む か、ローカルパッケージからインストールする こともできます。ただし、新しいプロジェクトとして開始するほうが、パッケージの内容にエラーが発生しにくくなります。
コンピューターのファイルマネージャー (Windows ファイルエクスプローラーや macOS Finder など) を使用して、プロジェクトフォルダーに移動し、Packages
サブディレクトリを見つけます。
Packages
フォルダーの中に、パッケージ名 と一致する名前で 命名規則 に沿った、パッケージの新しいサブディレクトリを作成します。例えば、パッケージ名が com.example.mypackage
の場合、サブフォルダーの名前も com.example.mypackage
とします。
ノート: これは、パッケージにアセットが含まれている場合に特に重要です。なぜなら、実際のフォルダー名に関わらず、AssetDatabase はPackages/<your-package-name>/Assets
に一致するアセットパスを探す からです。
任意のテキストエディターを開き、パッケージフォルダーのルートに package.json
という JSON ファイルを作成します。
package.json
ファイルの必須および推奨フィールド をすべて入力します。パッケージマニフェストの例 を参照してください。
Unity を再度開くと、新しいパッケージが Package Manager ウィンドウ と Project ウィンドウに表示され、パッケージコンテンツの表示や変更を行えます。Project ウィンドウで package.json
ファイルを選択すると、Inspector ウィンドウでその JSON 値を直接変更することもできます。
手順 に戻り、パッケージの作成を完了します。
Project フォルダーの外にカスタムパッケージを作成したい場合は、以下の手順に従ってください。
ノート: これらの手順は、カスタムパッケージの作成 の手順の一部です。
コンピューターのファイルマネージャー (Windows ファイルエクスプローラーや macOS Finder など) を使用して、 パッケージ用のフォルダーを作成します 。
パッケージのコンテンツをすでに作成している場合は、既存の場所を使用することもできます。
任意のテキストエディターを開き、パッケージフォルダーのルートに package.json
という JSON ファイルを作成します。
package.json
ファイルの 必須および推奨フィールド をすべて入力します。name
プロパティが 命名規則 に従っていることを確認してください。 パッケージ マニフェストの例 を参照してください。
Unity で新しいプロジェクトを作成するか、既存のプロジェクトを開きます。
Package Manager ウィンドウ を開き、先ほど作成したpackage.json
ファイルを使用して ローカルパッケージをインストール する手順に従ってください。
新しいパッケージが Package Manager ウィンドウと Project ウィンドウに表示され、パッケージのコンテンツの表示や変更を行えます。Project ウィンドウで package.json
ファイルを選択すると、Inspector ウィンドウでその JSON 値を直接変更することもできます。
手順 に戻り、パッケージの作成を完了します。
Did you find this page useful? Please give it a rating:
Thanks for rating this page!
What kind of problem would you like to report?
Thanks for letting us know! This page has been marked for review based on your feedback.
If you have time, you can provide more information to help us fix the problem faster.
Provide more information
You've told us this page needs code samples. If you'd like to help us further, you could provide a code sample, or tell us about what kind of code sample you'd like to see:
You've told us there are code samples on this page which don't work. If you know how to fix it, or have something better we could use instead, please let us know:
You've told us there is information missing from this page. Please tell us more about what's missing:
You've told us there is incorrect information on this page. If you know what we should change to make it correct, please tell us:
You've told us this page has unclear or confusing information. Please tell us more about what you found unclear or confusing, or let us know how we could make it clearer:
You've told us there is a spelling or grammar error on this page. Please tell us what's wrong:
You've told us this page has a problem. Please tell us more about what's wrong:
Thank you for helping to make the Unity documentation better!
Your feedback has been submitted as a ticket for our documentation team to review.
We are not able to reply to every ticket submitted.