チームメンバーで安全、迅速にファイルやフォルダを共有することはプロジェクトを成功に導くために必要不可欠です。 それらを比較的簡単に実現するためのツールを実演交えて紹介します。
初めてのゲームプロジェクト バージョン管理GGJ21 オンライン
View Slide
内容- ファイル共有について- プロジェクト立ち上げ- 作業操作- 注意点- GGJ 成果物提出について
自己紹介PN: ゆーり新しいものスキ。趣味で格闘ゲームを開発しています。
プロジェクト共有について
要件- ファイル、フォルダの共有- ファイルの変更履歴- オンライン- 無料- 簡単
プロジェクトの共有方法USBメモリを介したファイル受け渡し。Google Drive 等ネットワークストレージを介したファイル受け渡し。バージョン管理を使う。
バージョン管理ツールの利点複数メンバーと共有できる。作業内容を保存できる。元に戻れる。作業内容を把握できる。
いろいろなバージョン管理名称 所感CSV 昔からある。SVN ゲーム業界で使われている。Perforce 巨大なプロジェクトで活躍。すごい。Git 一番人気。Unity Collaborate Unity専用。一番簡単。Plastic SCM 最近Unityファミリーに加わった。
GitHub DesktopGitHub社製。シンプルなUI。デザイナー向け。
いろいろなGitホスティングサービス(無料)サービス名 人数制限 容量制限GitHub 無制限 Repo 10GB LFS 1GBBitbucket 5人 Repo 2GB LFS 1GBGitLab 無制限 Repo 10GB LFS ?Unity Collaborate 3人 1GB* 2021/1月現在無料で利用できる範囲での制限
準備1. Unity Hub ダウンロード。インストール。https://unity3d.com/jp/get-unity/download2. Unityインストール。3. GitHub サインアップ。4. GitHub Desktop ダウンロード、インストール。https://desktop.github.com/5. GitHub Desktop に GitHub アカウントを紐付ける。
プロジェクト立ち上げ
リポジトリフォルダやファイルの変更履歴の保存場所。ローカルとリモートがある。プル … リモートの内容をローカルに反映。プッシュ … ローカルの内容をリモートに反映。
プロジェクト作成手順1. Unityプロジェクト作成。2. Gitリポジトリ作成。3. GitリポジトリをGitHubのリモートリポジトリへパブリッシュ。
プロジェクト参加手順1. GitHubで招待してもらう。2. Gitリポジトリをローカルにクローンする。
操作
History 履歴更新履歴を見ることができる。
Changes 変更内容変更したファイルとその中身を確認できる。中身を確認できるのはテキストのみ。
Discard 破棄ファイルを元の状態に戻します。
Commit コミット変更内容を確定する。1行のメッセージをつける必要がある。1つの作業完了で1回コミットするとよい。
Undo アンドゥ直前のコミット操作をなかったことにする。何回でも戻れる。サーバーにプッシュするとアンドゥできなくなる。
リモートに新しい変更があるか確認する場合 > Fetch フェッチ。リモートに新しい変更がある場合 > Pull プル。ローカルに新しい変更がある場合 > Push プッシュ。Sync 同期
Merge マージふたつの作業内容をいい感じに合成する。ローカルでマージした後にプッシュすることで確定。
Conflict 衝突同時期に同じファイルを操作してしまった場合に発生。どちらが正しいファイルかを選択するか、もしくは合成する必要がある。テキストの場合は自動的に合成してくれる。
Branch ブランチ他人に影響を与えない自分だけの道を作れる。Mainから分岐する。Mainに合流させることで、プロジェクトを反映する。
注意点
GitHub(無料)の制限制限内容- 1ファイルサイズ制限 100MB。超える場合はLFSを使う。- ストレージ容量 Repo 10GB, LFS 1GB。- 帯域制限 Download Max 1GB / 月。パブリックで開発した場合- 再配布禁止のアセットのプッシュ禁止。制限を超えるには ...- 別サービスを使う- 有料プランを選択- 自分でホスティングする容量使いすぎないように工夫する。
無視するファイルGitHubを使えば意識する必要は少ない。バージョン管理する必要のないファイルパターンを`.gitignore` ファイルに保存する。キャッシュやテンポラリフォルダを追加する。
ファイルへの書き出しシーンを保存する。.unity ファイルプロジェクトを保存する。.meta .mat .asset .json ファイル等CTRL+S でだいたいOK。
Metaファイルの扱いUnity独自の機構。アセット、フォルダ1つに1つのMetaファイル。アセットの参照情報やインポート設定等が含まれる。一緒にコミットする必要がある。
巨大なファイル (GitHub)100MB以上のファイルはGit LFSを使う。`.gitattributes` ファイルにファイルパターンを保存する。LFSストレージは1GBまで無料。
空フォルダUnityでは空フォルダに対応するMetaファイルが作られるがGitではフォルダのみが作られることはない。フォルダには中身が必要。対応策- Unityでは空フォルダを作らないように気をつける。- 空フォルダ削除ツールを用意する。Uni Empty Folder Deleter https://github.com/baba-s/UniEmptyFolderDeleter- 無視する。
GGJ成果物提出について
ファイル構造これらのフォルダをzipで圧縮してアップロードする。クラウドストレージを利用する場合はリンクを貼る。恒久的にアクセスできるようにしておく必要がある。/src ソースコードやアセットファイルなど全て。/release 実行ファイル。README.txt付きで。/press ゲームのPR画像(press.jpg: 1024x768以上)。/other その他のメディア。プレイ動画など。license.txt クリエイティブコモンズライセンス 4.0
削除しておくべきファイル、フォルダダウンロードしたアセットのライセンスを確認する。> 必ずライセンス表記に従う。> 再配布が可能か?再配布墓のアセットを削除する。.git フォルダを削除する。> .gitフォルダにはファイルの変更履歴がふくまれているため。再構成するための手順をテキストファイルに記述する。
再配布禁止なもの自作したもの 。> 問題なし。Webからコピペしたコードなど 。> ほとんど問題なしだが、ライセンス表記があれば従う。Webからダウンロードしたもの。> ライセンスを確認し、従う。AssetStore にあるもの。> ほとんど再配布禁止。別のライセンス表記があれば従う。
終わりに- チームの決定を優先する。- わからないことやトラブルがあれば内容を Discord #質問チャンネルへ。- リモートデスクトップを活用する。