本ページでは、ブロック操作用プログラムについて説明を追記頂ける方を募集しています。
説明の追記方法は、Pull Requestを送る
を参照下さい。
ブロック操作用プログラムでは、ボード情報からブロックの次の動作を決定します。
このファイルのdef GetNextMove
関数にて、ボード情報GameStatus
を入力として受け取り、次の動作決定用のデータnextMove
を返す事でブロックが動く仕様になっています。
以下は、ボード情報GameStatus
、次の動作決定用のデータnextMove
について記載します。
ボード情報には以下が含まれます。
詳細は、GameStatus
データ構造や、サンプルコードのようにGameStatusをログ出力することで確認可能です。
* field_info : フィールド情報
* block_info : ブロック情報
* judge_info : 審判情報
* debug_info : デバッグ情報
フィールドは横幅10×高さ22ブロック分の大きさです。
座標系は、左上を原点(0,0)として、x軸は右側、y軸は下側を正の方向として定義しています。
フィールドのデータは、一次元配列として定義しています。
座標(x, y)のデータは、一次元配列の[x + y * 横幅]番目にアクセスすることで取得可能です。
フィールド | 一次元配列 | |
---|---|---|
データ |
上記の一次元配列の各座標にブロックが有るか無いかを管理しています。
* `0以外` : ブロック有り
* `0` : ブロック無し
ブロックが有る場合は、各ブロックのIndex値を格納しています。
Index値はブロック情報を参照下さい。
ブロックは7種類あり、Index値と初期形状を以下の通り定義しています。
横移動と回転が可能です。
回転は時計回りに回転します。ブロックによって1周の回転に必要な回数が異なります。
ShapeI | ShapeL | ShapeJ | ShapeT | ShapeO | ShapeS | ShapeZ | |
---|---|---|---|---|---|---|---|
index値 | 1 | 2 | 3 | 4 | 5 | 6 | 7 |
初期形状 | |||||||
1周の回転に必要な回数 | 2 | 4 | 4 | 4 | 1 | 2 | 2 |
各ブロックには操作の基準となる点(以下、ブロック操作の基準点)があります。
また、ブロック操作の基準点以外の座標も取得可能です。基準点(x,y)とその周囲の座標は以下のように表します。
ブロック毎に操作の基準点(x,y)は異なります。各ブロックの形状毎の基準点とそれ以外の座標は以下の通り。
尚、基準点とそれ以外の座標については現在のブロック情報(メソッドShape_class.getCoords()
)から取得可能です。
また、各形状におけるx,y方向の最大長は、現在のブロック情報(メソッドShape_class.getBoundingOffsets()
)から取得可能です。
取得の具体的な実装方法は、ブロック操作用サンプルプログラムを参照ください。
ブロックは、ブロック操作の基準点が座標(5,1)になるように出現します。
尚、ブロックの出現時、既に基準点(x, y)にブロックが存在しているとgame over
となりフィールドがリセットされます。
主に以下を格納しています。
現在のブロック操作の基準点(x,y)
現在のブロックのIndex値
次のブロックのIndex値
以下を格納しています。
経過時間[s]
: ゲーム開始時からの経過時間スコア[点]
: ゲーム開始時から現在までに獲得した合計スコアライン数
: ゲーム開始時から現在までに消したラインの数ゲームオーバー回数
: ゲーム開始時から現在までにゲームオーバーになった回数
以下等を格納しています。
スコア内訳
: 合計スコア(消したライン、落下ボーナス)の内訳
その他、詳細はコード上のGameStatusを参照下さい。
以下のデータを、次の動作決定用のデータnextMove
に与えることで次の動作を決定します。
nextMove
は辞書型のデータであり、nextMove["strategy"]
以下の各値に応じてブロックが動きます。
direction
: 現在の形状から時計回りに何回回転するか(範囲:0〜(1周の回転に必要な回数-1) )x
: x座標のどの位置に移動するか(範囲:0-9、x座標の絶対値を指定する)y_operation
: y座標方向の操作(1:落下、0:移動)y_moveblocknum
: y座標方向に移動する場合、y座標に何ブロック分移動するか(範囲:1-21)
(今後ルール変更がある場合は、ルールに応じてnextMove
もアップデートしていく予定です。)
HOLD機能とは、ブロックを保持する機能です。この機能を使うと現在のブロックがHOLD扱いになります。
その後、もし保持しているブロックがない場合は次のブロックが落ちてきます。
もし保持しているブロックが既にある場合はそのブロックが再び落ちてきます。
プログラムから使用する場合はnextMove["strategy"]
の以下の値を調整してください。
use_hold_function
: HOLD機能を使うかどうか("y":使う、"n":使わない)
ブロック操作用サンプルプログラムを参照ください。