Develop and Download Open Source Software

Browse Subversion Repository

Diff of /Unit1.pas

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 13 by yamat0jp, Tue Jul 14 00:24:36 2015 UTC revision 21 by yamat0jp, Sat Jul 18 22:36:44 2015 UTC
# Line 12  const Line 12  const
12    Count = 8;    Count = 8;
13    
14  type  type
15    TStoneType = (stNone, stWhite, stBlack, stError);    TStoneType = (stNone, stWhite, stBlack, stError, stEffect);
16    
17      TEffectData = record
18        X, Y: integer;
19        Left, Top: integer;
20        Stone: TStoneType;
21      end;
22    
23    TGridData = array [0 .. Count - 1] of array [0 .. Count - 1] of TStoneType;    TGridData = array [0 .. Count - 1] of array [0 .. Count - 1] of TStoneType;
24    
# Line 32  type Line 38  type
38      FTurnNumber: integer;      FTurnNumber: integer;
39      FTurnIndex: integer;      FTurnIndex: integer;
40      FActive: Boolean;      FActive: Boolean;
41        List: TList;
42        FEffectStone: TStoneType;
43        FBool: Boolean;
44        FTerminated: Boolean;
45        FIndex_X: integer;
46        FIndex_Y: integer;
47      function GetStrings(X, Y: integer): TStoneType;      function GetStrings(X, Y: integer): TStoneType;
48      procedure SetStrings(X, Y: integer; const Value: TStoneType);      procedure SetStrings(X, Y: integer; const Value: TStoneType);
49      procedure SetTurnNumber(const Value: integer);      procedure SetTurnNumber(const Value: integer);
50    public    public
51        constructor Create;
52        destructor Destroy; override;
53      procedure Clear;      procedure Clear;
54      function CalScore(Stone: TStoneType; X, Y: integer): integer;      function CalScore(Stone: TStoneType; X, Y: integer): integer;
55      function CanSetStone(Stone: TStoneType; X, Y: integer; Reverse: Boolean;      function CanSetStone(Stone: TStoneType; X, Y: integer; Reverse: Boolean;
# Line 44  type Line 58  type
58      procedure Start;      procedure Start;
59      procedure Restart;      procedure Restart;
60      procedure Pause;      procedure Pause;
61        function ListExecute: Boolean;
62        procedure Paint(Canvas: TCanvas);
63        procedure ImageCount(X, Y: integer);
64      property Strings[X, Y: integer]: TStoneType read GetStrings      property Strings[X, Y: integer]: TStoneType read GetStrings
65        write SetStrings; default;        write SetStrings; default;
66      property TurnNumber: integer read FTurnNumber write SetTurnNumber;      property TurnNumber: integer read FTurnNumber write SetTurnNumber;
# Line 66  type Line 83  type
83      MenuItem10: TMenuItem;      MenuItem10: TMenuItem;
84      MenuItem11: TMenuItem;      MenuItem11: TMenuItem;
85      MenuItem12: TMenuItem;      MenuItem12: TMenuItem;
86        Timer2: TTimer;
87        Image1: TImage;
88        Image2: TImage;
89        Image3: TImage;
90        Image4: TImage;
91        Image5: TImage;
92      procedure FormCreate(Sender: TObject);      procedure FormCreate(Sender: TObject);
93      procedure FormDestroy(Sender: TObject);      procedure FormDestroy(Sender: TObject);
94      procedure Timer1Timer(Sender: TObject);      procedure Timer1Timer(Sender: TObject);
# Line 81  type Line 104  type
104      procedure MenuItem8Click(Sender: TObject);      procedure MenuItem8Click(Sender: TObject);
105      procedure MenuItem10Click(Sender: TObject);      procedure MenuItem10Click(Sender: TObject);
106      procedure MenuItem11Click(Sender: TObject);      procedure MenuItem11Click(Sender: TObject);
107        procedure Timer2Timer(Sender: TObject);
108    private    private
109      { Private 宣言 }      { Private 宣言 }
110      StoneGrid: TStoneGrid;      StoneGrid: TStoneGrid;
# Line 111  var Line 135  var
135  begin  begin
136    if CanSetStone(Stone, X, Y, true) = true then    if CanSetStone(Stone, X, Y, true) = true then
137    begin    begin
138      if Stone = stBlack then      case Stone of
139        Stone := stWhite      stBlack:
140      else        Stone := stWhite;
141        stWhite:
142        Stone := stBlack;        Stone := stBlack;
143        stEffect:
144          Stone := FEffectStone;
145        end;
146      result := 0;      result := 0;
147      for i := 0 to Count - 1 do      for i := 0 to Count - 1 do
148        for j := 0 to Count - 1 do        for j := 0 to Count - 1 do
# Line 132  end; Line 160  end;
160  function TStoneGrid.CanSetStone(Stone: TStoneType; X, Y: integer;  function TStoneGrid.CanSetStone(Stone: TStoneType; X, Y: integer;
161    Reverse: Boolean; const Visible: Boolean): Boolean;    Reverse: Boolean; const Visible: Boolean): Boolean;
162  var  var
163    i, k: integer;    i: integer;
164    p: Boolean;    p: Boolean;
165    q: ^TPoint;    q: ^TEffectData;
   list: TList;  
166    procedure Method(m, n: integer);    procedure Method(m, n: integer);
167    var    var
168      s: TStoneType;      s: TStoneType;
169      j: integer;      j, k: integer;
170    begin    begin
171      if p = false then      if p = false then
172        Exit;        Exit;
# Line 147  var Line 174  var
174      while true do      while true do
175      begin      begin
176        s := GetStrings(X + m * i, Y + n * i);        s := GetStrings(X + m * i, Y + n * i);
177          if s = stEffect then
178            s:=FEffectStone;
179        if (s = stNone) or (s = stError) then        if (s = stNone) or (s = stError) then
180          break          break
181        else if s = Stone then        else if s = Stone then
182          if i > 1 then          if i > 1 then
183          begin          begin
184              if (result = false) and (Reverse = true) then
185                SetStrings(X, Y, Stone);
186            result := true;            result := true;
187            if Reverse = true then            if Reverse = true then
188            begin            begin
189              for j := 1 to i - 1 do              for j := 1 to i - 1 do
190              begin              begin
191                New(q);                Form1.PaintBox1.Repaint;
192                q^ := Point(X + m * j, Y + n * j);                if Visible = true then
193                list.Add(q);                begin
194                    FEffectStone:=Stone;
195                    New(q);
196                    q^.Left := X + m * j;
197                    q^.Top := Y + n * j;
198                    q^.Stone := Stone;
199                    q^.X := 0;
200                    q^.Y := 0;
201                    List.Add(q);
202                    SetStrings(q^.Left, q^.Top, stEffect);
203                    for k := 1 to 100 do
204                    begin
205                      Sleep(1);
206                      Application.ProcessMessages;
207                    end;
208                  end
209                  else
210                    SetStrings(X + m * j, Y + n * j, Stone);
211              end;              end;
212              break;              break;
213            end            end
# Line 177  var Line 225  var
225    end;    end;
226    
227  begin  begin
228    list := TList.Create;    result := false;
229    try    if Visible = true then
230      result := false;    begin
231      p := true;      FBool := FActive;
232      if GetStrings(X, Y) = stNone then      FActive := false;
233      begin    end;
234        Method(-1, -1);    p := true;
235        Method(-1, 0);    if GetStrings(X, Y) = stNone then
236        Method(-1, 1);    begin
237        Method(0, -1);      Method(-1, -1);
238        Method(0, 1);      Method(-1, 0);
239        Method(1, -1);      Method(-1, 1);
240        Method(1, 0);      Method(0, -1);
241        Method(1, 1);      Method(0, 1);
242        if (Reverse = true) and (result = true) then      Method(1, -1);
243        begin      Method(1, 0);
244          SetStrings(X, Y, Stone);      Method(1, 1);
         for i := 0 to list.Count - 1 do  
         begin  
           if Visible = true then  
           begin  
             for k := 1 to 10 do  
             begin  
               Sleep(10);  
               Application.ProcessMessages;  
             end;  
             Form1.PaintBox1.Repaint;  
           end;  
           q := list[i];  
           SetStrings(q^.X, q^.Y, Stone);  
         end;  
       end;  
     end;  
   finally  
     for i := 0 to list.Count - 1 do  
       Dispose(list[i]);  
     list.Free;  
   end;  
   if (Visible = true)and(result = true) then  
   begin  
     inc(FTurnIndex);  
     inc(FTurnNumber);  
     FBuffer[FTurnIndex] := FStrings;  
245    end;    end;
246  end;  end;
247    
# Line 239  begin Line 261  begin
261    FBuffer[0] := FStrings;    FBuffer[0] := FStrings;
262  end;  end;
263    
264    constructor TStoneGrid.Create;
265    begin
266      inherited;
267      List := TList.Create;
268    end;
269    
270    destructor TStoneGrid.Destroy;
271    var
272      i: integer;
273    begin
274      for i := 0 to List.Count - 1 do
275        Dispose(List[i]);
276      List.Free;
277      inherited;
278    end;
279    
280  function TStoneGrid.GetStrings(X, Y: integer): TStoneType;  function TStoneGrid.GetStrings(X, Y: integer): TStoneType;
281  begin  begin
282    if (X >= 0) and (X < Count) and (Y >= 0) and (Y < Count) then    if (X >= 0) and (X < Count) and (Y >= 0) and (Y < Count) then
# Line 247  begin Line 285  begin
285      result := stError;      result := stError;
286  end;  end;
287    
288    procedure TStoneGrid.ImageCount(X, Y: integer);
289    begin
290      FIndex_X := X;
291      FIndex_Y := Y;
292    end;
293    
294    function TStoneGrid.ListExecute: Boolean;
295    var
296      p: ^TEffectData;
297      i: integer;
298    begin
299      if List.Count = 0 then
300        result := false
301      else
302      begin
303        for i := 0 to List.Count - 1 do
304        begin
305          p := List.List[i];
306          if p^.X < FIndex_X - 1 then
307            p^.X := p^.X + 1
308          else if p^.Y < FIndex_Y - 1 then
309          begin
310            p^.X := 0;
311            p^.Y := p^.Y + 1;
312          end
313          else
314          begin
315            SetStrings(p^.Left, p^.Top, p^.Stone);
316            Dispose(p);
317            List[i] := nil;
318          end;
319        end;
320        for i := List.Count - 1 downto 0 do
321          if List[i] = nil then
322            List.Delete(i);
323        if List.Count = 0 then
324        begin
325          if FTerminated = true then
326            FActive:=false
327          else
328            FActive := FBool;
329          inc(FTurnIndex);
330          inc(FTurnNumber);
331          FBuffer[FTurnIndex] := FStrings;
332        end;
333        result := true;
334      end;
335    end;
336    
337  function TStoneGrid.NextStone(Stone: TStoneType): TPoint;  function TStoneGrid.NextStone(Stone: TStoneType): TPoint;
338  var  var
339    i, j, m, n: integer;    i, j, m, n: integer;
# Line 266  begin Line 353  begin
353      result := Point(-1, -1);      result := Point(-1, -1);
354  end;  end;
355    
356    procedure TStoneGrid.Paint(Canvas: TCanvas);
357    var
358      i: integer;
359      k, m, n: integer;
360      s: TBitmap;
361      p: ^TEffectData;
362    begin
363      m := Form1.Image3.Bitmap.Width;
364      n := Form1.Image3.Bitmap.Height;
365      k := Form1.Size;
366      for i := 0 to List.Count - 1 do
367      begin
368        p := List[i];
369        if p^.Stone = stBlack then
370          s := Form1.Image1.Bitmap
371        else
372          s := Form1.Image2.Bitmap;
373        Canvas.DrawBitmap(s, RectF(p^.X * m, p^.Y * n, (p^.X + 1) * m,
374          (p^.Y + 1) * n), RectF(p^.Left * k, p^.Top * k, (p^.Left + 1) * k,
375          (p^.Top + 1) * k), 1);
376      end;
377    end;
378    
379  procedure TStoneGrid.Pause;  procedure TStoneGrid.Pause;
380  begin  begin
381    FActive := false;    FTerminated:=true;
382  end;  end;
383    
384  procedure TStoneGrid.Restart;  procedure TStoneGrid.Restart;
385  begin  begin
386    FActive := true;    if FTerminated = true then
387    FTurnIndex := FTurnNumber;    begin
388        FActive := true;
389        FTurnIndex := FTurnNumber;
390        FTerminated:=false;
391      end;
392  end;  end;
393    
394  procedure TStoneGrid.SetStrings(X, Y: integer; const Value: TStoneType);  procedure TStoneGrid.SetStrings(X, Y: integer; const Value: TStoneType);
# Line 291  begin Line 405  begin
405      FTurnNumber := 0      FTurnNumber := 0
406    else    else
407      FTurnNumber := Value;      FTurnNumber := Value;
   FActive := false;  
408    FStrings := FBuffer[FTurnNumber];    FStrings := FBuffer[FTurnNumber];
409  end;  end;
410    
411  procedure TStoneGrid.Start;  procedure TStoneGrid.Start;
412  begin  begin
413    Clear;    Clear;
414      FTerminated:=false;
415    FActive := true;    FActive := true;
416  end;  end;
417    
# Line 310  var Line 424  var
424    procedure Main;    procedure Main;
425    begin    begin
426      if Index = Player1 then      if Index = Player1 then
427        Index := Player2      begin
428          Index := Player2;
429          s := '白の手番です';
430        end
431      else      else
432        begin
433        Index := Player1;        Index := Player1;
434          s := '黒の手番です';
435        end;
436    end;    end;
437    function Execute: Boolean;    function Execute: Boolean;
438    var    var
439      i, j: integer;      i, j: integer;
440        m: integer;
441        n: integer;
442    begin    begin
     result := false;  
443      for i := 0 to Count - 1 do      for i := 0 to Count - 1 do
444        for j := 0 to Count - 1 do        for j := 0 to Count - 1 do
445          if StoneGrid.CanSetStone(Index.Stone, i, j, false) = true then          if StoneGrid.CanSetStone(Index.Stone, i, j, false) = true then
# Line 326  var Line 447  var
447            result := true;            result := true;
448            Exit;            Exit;
449          end;          end;
450        result := false;
451    end;    end;
452    
453  begin  begin
# Line 336  begin Line 458  begin
458      if Execute = false then      if Execute = false then
459      begin      begin
460        StoneGrid.Pause;        StoneGrid.Pause;
       Timer1.Enabled := false;  
461        m := 0;        m := 0;
462        n := 0;        n := 0;
463        for i := 0 to Count - 1 do        for i := 0 to Count - 1 do
# Line 347  begin Line 468  begin
468              stWhite:              stWhite:
469                inc(n);                inc(n);
470            end;            end;
471          Caption := s;
472        if m > n then        if m > n then
473          s := 'Player1 Win:' + #13#10          s := 'Player1 Win:' + #13#10
474        else if m < n then        else if m < n then
# Line 355  begin Line 477  begin
477          s := 'Draw:' + #13#10;          s := 'Draw:' + #13#10;
478        Showmessage(s + '(Player1) ' + IntToStr(m) + #13#10 + '(Player2) ' +        Showmessage(s + '(Player1) ' + IntToStr(m) + #13#10 + '(Player2) ' +
479          IntToStr(n));          IntToStr(n));
480      end;      end
481    end;      else
482          Caption := s;
483      end
484      else
485        Caption := s;
486  end;  end;
487    
488  procedure TForm1.CompStone;  procedure TForm1.CompStone;
# Line 371  end; Line 497  end;
497    
498  procedure TForm1.GameStart;  procedure TForm1.GameStart;
499  begin  begin
500      Index := Player1;
501    StoneGrid.Start;    StoneGrid.Start;
502    PaintBox1.Repaint;    PaintBox1.Repaint;
503    Index := Player1;    Caption := '黒から始めます';
   Timer1.Enabled := true;  
504  end;  end;
505    
506  procedure TForm1.MenuItem10Click(Sender: TObject);  procedure TForm1.MenuItem10Click(Sender: TObject);
507  begin  begin
508    StoneGrid.Restart;    StoneGrid.Restart;
   Timer1.Enabled := true;  
509  end;  end;
510    
511  procedure TForm1.MenuItem11Click(Sender: TObject);  procedure TForm1.MenuItem11Click(Sender: TObject);
512    var
513      i: integer;
514  begin  begin
   Timer1.Enabled := false;  
515    with StoneGrid do    with StoneGrid do
516      begin
517        i := TurnNumber;
518      if Sender = MenuItem11 then      if Sender = MenuItem11 then
519        TurnNumber := TurnNumber + 1        TurnNumber := TurnNumber + 1
520      else      else
521        TurnNumber := TurnNumber - 1;        TurnNumber := TurnNumber - 1;
522    ChangePlayer;      if (i = TurnNumber) then
523          Exit
524        else
525          Pause;
526      end;
527    PaintBox1.Repaint;    PaintBox1.Repaint;
528      ChangePlayer;
529  end;  end;
530    
531  procedure TForm1.MenuItem2Click(Sender: TObject);  procedure TForm1.MenuItem2Click(Sender: TObject);
# Line 409  procedure TForm1.MenuItem6Click(Sender: Line 542  procedure TForm1.MenuItem6Click(Sender:
542  begin  begin
543    Player1.Auto := MenuItem6.IsChecked;    Player1.Auto := MenuItem6.IsChecked;
544    Player2.Auto := MenuItem7.IsChecked;    Player2.Auto := MenuItem7.IsChecked;
   MenuItem10Click(Sender);  
545  end;  end;
546    
547  procedure TForm1.MenuItem8Click(Sender: TObject);  procedure TForm1.MenuItem8Click(Sender: TObject);
548  begin  begin
549    StoneGrid.Pause;    StoneGrid.Pause;
   Timer1.Enabled := false;  
550  end;  end;
551    
552  procedure TForm1.PaintBox1Paint(Sender: TObject; Canvas: TCanvas);  procedure TForm1.PaintBox1Paint(Sender: TObject; Canvas: TCanvas);
553  var  var
554    i, j: integer;    i, j: integer;
555  begin  begin
556    Canvas.Fill.Color := TAlphaColors.White;    if StoneGrid.Active = false then
557    Canvas.FillRect(RectF(0, 0, Count * Size, Count * Size), 0, 0, [], 1);      StoneGrid.Paint(Canvas);
558    for i := 0 to Count do    for i := 0 to Count - 1 do
559    begin    begin
560      Canvas.DrawLine(PointF(i * Size, 0), PointF(i * Size, Size * Count), 1);      for j := 0 to Count - 1 do
     for j := 0 to Count do  
561      begin      begin
       Canvas.DrawLine(PointF(0, j * Size), PointF(Count * Size, j * Size), 1);  
562        case StoneGrid.Strings[i, j] of        case StoneGrid.Strings[i, j] of
563          stWhite:          stWhite:
564            Canvas.DrawEllipse(RectF(i * Size, j * Size, (i + 1) * Size,            Canvas.DrawBitmap(Image4.Bitmap, RectF(0, 0, Image4.Bitmap.Width,
565                Image4.Bitmap.Height), RectF(i * Size, j * Size, (i + 1) * Size,
566              (j + 1) * Size), 1);              (j + 1) * Size), 1);
567          stBlack:          stBlack:
568            begin            Canvas.DrawBitmap(Image3.Bitmap, RectF(0, 0, Image3.Bitmap.Width,
569              Canvas.Fill.Color := TAlphaColors.Black;              Image3.Bitmap.Height), RectF(i * Size, j * Size, (i + 1) * Size,
570              Canvas.FillEllipse(RectF(i * Size, j * Size, (i + 1) * Size,              (j + 1) * Size), 1);
571                (j + 1) * Size), 1);          stEffect:
572            end;            continue;
573          else
574            Canvas.DrawBitmap(Image5.Bitmap, RectF(0, 0, Image5.Bitmap.Width,
575              Image5.Bitmap.Height), RectF(i * Size, j * Size, (i + 1) * Size,
576              (j + 1) * Size), 1);
577        end;        end;
578          Canvas.DrawLine(PointF(0, j * Size), PointF(Count * Size, j * Size), 1);
579      end;      end;
580        Canvas.DrawLine(PointF(i * Size, 0), PointF(i * Size, Size * Count), 1);
581    end;    end;
582      Canvas.DrawLine(PointF(Count * Size, 0),
583        PointF(Count * Size, Count * Size), 1);
584      Canvas.DrawLine(PointF(0, Count * Size),
585        PointF(Count * Size, Count * Size), 1);
586  end;  end;
587    
588  procedure TForm1.PaintBox1Resize(Sender: TObject);  procedure TForm1.PaintBox1Resize(Sender: TObject);
# Line 453  end; Line 593  end;
593  procedure TForm1.FormCreate(Sender: TObject);  procedure TForm1.FormCreate(Sender: TObject);
594  begin  begin
595    StoneGrid := TStoneGrid.Create;    StoneGrid := TStoneGrid.Create;
596      StoneGrid.ImageCount(Form1.Image1.Bitmap.Width div Form1.Image3.Bitmap.Width,
597        Form1.Image1.Bitmap.Height div Form1.Image3.Bitmap.Height);
598    Player1 := TPlayer.Create;    Player1 := TPlayer.Create;
599    Player2 := TPlayer.Create;    Player2 := TPlayer.Create;
600    Player1.Stone := stBlack;    Player1.Stone := stBlack;
# Line 484  end; Line 626  end;
626  procedure TForm1.Timer1Timer(Sender: TObject);  procedure TForm1.Timer1Timer(Sender: TObject);
627  begin  begin
628    if (StoneGrid.Active = true) and (Index.Auto = true) then    if (StoneGrid.Active = true) and (Index.Auto = true) then
   begin  
     Timer1.Enabled := false;  
629      CompStone;      CompStone;
630      Timer1.Enabled := true;  end;
631    end;  
632    procedure TForm1.Timer2Timer(Sender: TObject);
633    begin
634      if (StoneGrid.Active = false)and(StoneGrid.ListExecute = true) then
635        PaintBox1.Repaint;
636  end;  end;
637    
638  procedure TForm1.FormResize(Sender: TObject);  procedure TForm1.FormResize(Sender: TObject);

Legend:
Removed from v.13  
changed lines
  Added in v.21

Back to OSDN">Back to OSDN
ViewVC Help
Powered by ViewVC 1.1.26