welcome: please sign in

2009-12-06 01:37:38時点のリビジョン27

メッセージを消す
location: 盤の表現

盤の表現

整数型の2次元配列 ban で盤面の状態を表すことにします。

ban[x][y]で左からx番目、上からy番目を表すとすると、盤の大きさが4×4の場合 配列と位置の対応はこのようになります。

各位置にどのピースが置かれているかを、この配列の要素の値で表します。

各ピースに番号をつけ、これを値として使うことにします。

16個のピースが図のとおりの位置にある場合、配列の内容は次のようになります。

値と配列を対応させた表を示します。

後の課題でbanの内容をこのように初期化します。


データの初期化

インスタンス変数の初期化はどこで行うべきでしょうか。

次の方法が考えられます。

  1. コンストラクタ内で行う。
  2. 初期化を行うメソッドを別に用意し、その中で行う。
  3. 呼び出し側で行う。

いずれの方法をとるかは、つぎのことを考慮して決めます。


盤を表示する

配列 ban の内容にしたがって画像を指定の位置に表示するプログラムを作ります。

メインメソッドとコンストラクタは前回までと同様に記述しなさい。

読み込む画像ファイルは game0.png を使いなさい。

33,34行目の ??? の部分に正しい式を記述しなさい。

   1 import javax.swing.*;
   2 import java.awt.*;
   3 
   4 public class Game12 extends JPanel
   5 {
   6         int haba;
   7         int yoko, tate;
   8         String fname;
   9         Image img;
  10         int[][] ban;
  11         
  12         public static void main(String[] args)
  13         {
  14                 ...
  15                 Game12 p;
  16                 
  17                 ...
  18                 p = new Game12();
  19                 p.haba = 100;
  20                 p.yoko = 4;
  21                 p.tate = 4;
  22                 p.fname = "game0.png";
  23                 p.shokika();
  24                 ...
  25         }
  26         
  27         void shokika()
  28         {
  29                 int x, y;
  30                 
  31                 ImageIcon ii = new ImageIcon(fname);
  32                 img = ii.getImage();
  33                 ban = new int[yoko][tate];
  34                 初期化
  35         }
  36         
  37         public void paintComponent(Graphics g)
  38         {
  39                 int dx, dy, sx, sy;
  40                 
  41                 for(dy = 0; dy < tate; dy++)
  42                         for(dx = 0; dx < yoko; dx++)
  43                         {
  44                                 sx = 計算式;
  45                                 sy = 計算式;
  46                                 g.drawImage(img,
  47                                         dx*haba, dy*haba, (dx+1)*haba, (dy+1)*haba,
  48                                         sx*haba, sy*haba, (sx+1)*haba, (sy+1)*haba,
  49                                         this);
  50                         }
  51         }
  52 }