8/4、5に開催された東北ITコンセプト福島GameJam in 南相馬 2012に参加してきた。30時間で即興のチームでゲームを作るという催しだ。
前回、技術的な話を書いたので、今回は全体的な感想を。
福島GameJamは昨年に引き続き2回目の開催。今回は、高校生も含む地元の若い人の姿も多く、ITによる震災復興という目標に少しは近づけたかもしれない。
ぼくのチームは8名で、全員がプログラマという無茶な構成。内訳は、ある程度の経験者4名、若い人4名。
SEGAの石畑さんがチームにいたが、ぼくは開発中はバーチャロン・シリーズのプログラマの人だと気づかなかった。というか、開発で頭がいっぱいだった。バーチャロンはかなり夢中になったゲームだったので、緊張しかねないので、開発中は気づかなくてよかったかもしれない。
それぞれのメンバーの経験したことがある開発環境はバラバラだった。若い人たちはC(やC++)を習っているところだが、さすがにこれでゲームを作り始めると30時間では終わらない予感。話し合った結果、enchant.jsで開発することになった。
ゲームの企画を考えて、個々のタスクに落としていく。ぼくは、各メンバーがコーディングできるように、最初にゲームのフレームの部分を作ることになった。その間、他のメンバーはコードが書けないので、絵を描くことになった。
プログラマに絵を描かせるなんて…。
そもそも絵を描くツールすらパソコンに入っていない。スッポンを描け、ヒバリを描け、馬を描け、風船を描け…。想像を絶するタスクが割り当てられる。
ゲームのフレーム部分ができたのは、1日目の夜。2D横スクロールのマップ上をスッポンが這って移動し、風船などのNPCにつかまって障害を乗り越え、それぞれのステージのゴールを目指すというもの。
あんまりJavaScriptに慣れた人はいないので、その後も、苦しい戦いが続く。というか、Cしか習っていない若い人は、オブジェクトがどうのと言われてもよくわからなかったかもしれない。また、JavaScriptの場合、クラスベースの言語と異なるし、同じものを記述する方法が何種類もあるので、最初はわかりにくいだろう。
また、設計上、コードを再利用しようとしてコンフリクトするよりも、個々のプログラマの裁量にまかせる方針にした。しかし、その辺をうまく共有しそこねて、作業は多くなるわ、コードのコミットとマージでボトルネックが発生するわ、となかなか厳しい開発となった。
うまく基本を設計しようとすると、作業分担できるようになるまでに、時間がかなり必要となる。30時間内で、基本設計と個々のコーディングの時間配分はなかなか難しいものを感じた。
昨年参加したときは、チーム構成はプログラマ2名+グラフィッカ3名だった。ある程度の経験者のプログラマ2名だと、プログラムを完全に分業できるように分担することは容易で、ほとんどこの問題は発生しなかった。
半分が若い人で、全員プログラマだと、どう分担するかは悩ましい問題だ。経験者1名+若い人1名のサブチーム4つに分けて、個々に完全に分業できる形で開発するなど、特殊なチーム構成に応じた対応が必要だったかもしれない。
作ったゲームは、以下のリンクから遊ぶことができる。ところどころバグっていて、音が出なかったり、地面に埋もれたりする。
なお、プログラマ8名というありえないチャレンジに対して、Unity社からUnity賞をいただきました。どうもありがとうございます。
いずれにせよ、とてもチャレンジングな環境で苦しい戦いを戦ったチームのみんなに感謝します。 もちろん、運営や他のチームや関わったみなさんにも。
また、ふだんチームで開発しないので、いろいろと参考になることが多かった。
帰ってきて、リリース版のコードを読み直してみた(バグを修正しちゃおうか、敢えてこのままにしようかちょっと悩んでいる。というか、実はほとんどリファクタリングもしちゃったコードが手元にある)。若い人たちの書いたコードを見て思ったことなど。
- コーディング規約に対する留意
コーディング規約を決めていたわけではないが、変数、定数の命名方法などは、周りに合わせた方がいい。また、インデントは適切に行なった方がいい。
というのも、バグを見つけて直すのは、下手をするとコードを捨てて1から書き直した方が楽なくらい激しく大変なので、読みやすく間違いを見つけやすく書いた方がいいということ。 - 状態の管理があやしいところがある
状態遷移図を書いてから、コードを書いた方がいい。
というのも、状態も、バグりやすく直しにくいので、きちんと最初の段階から管理する必要があるので。 - 他人に影響するコードの追加・修正
コードを追加・修正するときは、他人に影響しないように行なった方がいい。難しい場合は、相談した上で。
若い人の書いたコードを見て、学校でプログラムの書き方を教えているが、そこで何が不足しているのかについて、いろいろ参考になることが多かった。今後、是非、役立てたいと思う。これは、ぼくにとっては、本当に大きな経験となった。