Commit 0dc88914a06240dfca63a5e031922ec11f8796b6
1 parent
6a6bbd9f
Exists in
master
refactoring, separating the issues, bug fix on appending stuff
Showing
11 changed files
with
560 additions
and
364 deletions
Show diff stats
cultural_matrix.lpr
... | ... | @@ -16,10 +16,15 @@ uses |
16 | 16 | cthreads, |
17 | 17 | {$ENDIF}{$ENDIF} |
18 | 18 | Interfaces // this includes the LCL widgetset |
19 | - , StrUtils, Forms, form_matrixgame, form_chooseactor, game_actors, | |
20 | - game_experiment, game_file_methods, game_resources, game_control, | |
21 | - string_methods, game_actors_point; | |
19 | + , StrUtils, Forms, Classes, sysutils, Dialogs | |
20 | + , form_matrixgame, form_chooseactor, game_actors | |
21 | + , zhelpers | |
22 | + ; | |
22 | 23 | |
24 | + | |
25 | +var | |
26 | + ID : TStringList; | |
27 | + F : string; | |
23 | 28 | const |
24 | 29 | PAdmin : array [0..3] of string = ('--admin','--adm','-admin','-adm'); |
25 | 30 | PPlayer : array [0..3] of string = ('--player','--play','-player','-play'); |
... | ... | @@ -30,15 +35,38 @@ const |
30 | 35 | begin |
31 | 36 | //RequireDerivedFormResource := True; |
32 | 37 | Application.Initialize; |
38 | + F := ExtractFilePath(Application.ExeName)+PathDelim+'id'; | |
39 | + ID := TStringList.Create; | |
40 | + if FileExists(F) then | |
41 | + try | |
42 | + ID.LoadFromFile(F); | |
43 | + F := ID.Text; | |
44 | + finally | |
45 | + ID.Free; | |
46 | + end | |
47 | + else | |
48 | + try | |
49 | + ID.Text := s_random(32); | |
50 | + ID.SaveToFile(F); | |
51 | + F := ID.Text; | |
52 | + except | |
53 | + on E: Exception do | |
54 | + begin | |
55 | + ID.Free; | |
56 | + ShowMessage(E.Message); | |
57 | + Exit; | |
58 | + end; | |
59 | + end; | |
33 | 60 | Application.CreateForm(TFormMatrixGame, FormMatrixGame); |
61 | + FormMatrixGame.SetID(F); | |
34 | 62 | if Paramcount > 0 then |
35 | 63 | begin |
36 | 64 | if AnsiMatchStr(lowercase(ParamStr(0)), PAdmin) then |
37 | - FormMatrixGame.GameActor := gaAdmin; | |
65 | + FormMatrixGame.SetGameActor(gaAdmin); | |
38 | 66 | if AnsiMatchStr(lowercase(ParamStr(0)), PPlayer) then |
39 | - FormMatrixGame.GameActor := gaPlayer; | |
67 | + FormMatrixGame.SetGameActor(gaPlayer); | |
40 | 68 | if AnsiMatchStr(lowercase(ParamStr(0)), PWatcher) then |
41 | - FormMatrixGame.GameActor := gaWatcher; | |
69 | + FormMatrixGame.SetGameActor(gaWatcher); | |
42 | 70 | end |
43 | 71 | else |
44 | 72 | begin |
... | ... | @@ -46,14 +74,15 @@ begin |
46 | 74 | if Form1.ShowModal = 1 then |
47 | 75 | begin |
48 | 76 | case Form1.GameActor of |
49 | - gaAdmin:FormMatrixGame.GameActor := gaAdmin; | |
50 | - gaPlayer: FormMatrixGame.GameActor := gaPlayer; | |
51 | - gaWatcher: {FormMatrixGame.GameActor := gaWatcher}; | |
77 | + gaAdmin:FormMatrixGame.SetGameActor(gaAdmin); | |
78 | + gaPlayer: FormMatrixGame.SetGameActor(gaPlayer); | |
79 | + gaWatcher: FormMatrixGame.SetGameActor(gaWatcher); | |
52 | 80 | end; |
53 | 81 | end |
54 | 82 | else Exit; |
55 | 83 | Form1.Free; |
56 | 84 | end; |
85 | + | |
57 | 86 | Application.Run; |
58 | 87 | end. |
59 | 88 | ... | ... |
form_matrixgame.lfm
1 | 1 | object FormMatrixGame: TFormMatrixGame |
2 | - Left = 301 | |
3 | - Height = 632 | |
4 | - Top = 130 | |
5 | - Width = 1278 | |
6 | - HorzScrollBar.Page = 1278 | |
2 | + Left = 190 | |
3 | + Height = 657 | |
4 | + Top = 94 | |
5 | + Width = 1518 | |
6 | + HorzScrollBar.Page = 1492 | |
7 | 7 | VertScrollBar.Page = 542 |
8 | 8 | AutoScroll = True |
9 | 9 | Caption = 'FormMatrixGame' |
10 | - ClientHeight = 622 | |
11 | - ClientWidth = 1278 | |
10 | + ClientHeight = 657 | |
11 | + ClientWidth = 1518 | |
12 | 12 | Font.Name = 'Monospace' |
13 | 13 | OnActivate = FormActivate |
14 | - OnCreate = FormCreate | |
15 | 14 | LCLVersion = '1.6.0.4' |
16 | 15 | object StringGridMatrix: TStringGrid |
17 | 16 | AnchorSideLeft.Control = Owner |
... | ... | @@ -38,7 +37,7 @@ object FormMatrixGame: TFormMatrixGame |
38 | 37 | OnBeforeSelection = StringGridMatrixBeforeSelection |
39 | 38 | OnDrawCell = StringGridMatrixDrawCell |
40 | 39 | end |
41 | - object GBIndividualPoints: TGroupBox | |
40 | + object GBIndividualAB: TGroupBox | |
42 | 41 | Left = 796 |
43 | 42 | Height = 122 |
44 | 43 | Top = 0 |
... | ... | @@ -113,9 +112,9 @@ object FormMatrixGame: TFormMatrixGame |
113 | 112 | end |
114 | 113 | end |
115 | 114 | object GBGrupo: TGroupBox |
116 | - AnchorSideLeft.Control = GBIndividualPoints | |
115 | + AnchorSideLeft.Control = GBIndividualAB | |
117 | 116 | AnchorSideLeft.Side = asrBottom |
118 | - AnchorSideTop.Control = GBIndividualPoints | |
117 | + AnchorSideTop.Control = GBIndividualAB | |
119 | 118 | Left = 976 |
120 | 119 | Height = 122 |
121 | 120 | Top = 0 |
... | ... | @@ -153,8 +152,8 @@ object FormMatrixGame: TFormMatrixGame |
153 | 152 | AnchorSideBottom.Side = asrBottom |
154 | 153 | Left = 0 |
155 | 154 | Height = 124 |
156 | - Top = 498 | |
157 | - Width = 1492 | |
155 | + Top = 533 | |
156 | + Width = 1518 | |
158 | 157 | Anchors = [akLeft, akRight, akBottom] |
159 | 158 | AutoSize = True |
160 | 159 | Caption = 'Escolhas na última jogada' |
... | ... | @@ -163,7 +162,7 @@ object FormMatrixGame: TFormMatrixGame |
163 | 162 | ChildSizing.HorizontalSpacing = 10 |
164 | 163 | ChildSizing.ControlsPerLine = 6 |
165 | 164 | ClientHeight = 107 |
166 | - ClientWidth = 1488 | |
165 | + ClientWidth = 1514 | |
167 | 166 | TabOrder = 3 |
168 | 167 | object GBLastChoiceP0: TGroupBox |
169 | 168 | Left = 10 |
... | ... | @@ -339,65 +338,13 @@ object FormMatrixGame: TFormMatrixGame |
339 | 338 | ClientWidth = 332 |
340 | 339 | TabOrder = 4 |
341 | 340 | Visible = False |
342 | - object rgMatrixType: TRadioGroup | |
343 | - Left = 10 | |
344 | - Height = 59 | |
345 | - Top = 8 | |
346 | - Width = 119 | |
347 | - AutoFill = True | |
348 | - AutoSize = True | |
349 | - Caption = 'MatrixType' | |
350 | - ChildSizing.LeftRightSpacing = 6 | |
351 | - ChildSizing.EnlargeHorizontal = crsHomogenousChildResize | |
352 | - ChildSizing.EnlargeVertical = crsHomogenousChildResize | |
353 | - ChildSizing.ShrinkHorizontal = crsScaleChilds | |
354 | - ChildSizing.ShrinkVertical = crsScaleChilds | |
355 | - ChildSizing.Layout = cclLeftToRightThenTopToBottom | |
356 | - ChildSizing.ControlsPerLine = 1 | |
357 | - ClientHeight = 42 | |
358 | - ClientWidth = 115 | |
359 | - ItemIndex = 0 | |
360 | - Items.Strings = ( | |
361 | - 'Rows' | |
362 | - 'Rows & Cols' | |
363 | - ) | |
364 | - OnClick = rgMatrixTypeClick | |
365 | - TabOrder = 0 | |
366 | - end | |
367 | - object CheckBoxDrawDots: TCheckBox | |
368 | - Left = 10 | |
369 | - Height = 21 | |
370 | - Top = 80 | |
371 | - Width = 119 | |
372 | - AutoSize = False | |
373 | - Caption = 'DrawDots' | |
374 | - OnChange = CheckBoxDrawDotsChange | |
375 | - TabOrder = 1 | |
376 | - end | |
377 | - object Button1: TButton | |
378 | - Left = 10 | |
379 | - Height = 25 | |
380 | - Top = 112 | |
381 | - Width = 119 | |
382 | - Caption = 'Button1' | |
383 | - OnClick = Button1Click | |
384 | - TabOrder = 2 | |
385 | - end | |
386 | - object Button2: TButton | |
387 | - Left = 10 | |
388 | - Height = 25 | |
389 | - Top = 144 | |
390 | - Width = 119 | |
391 | - Caption = 'Button2' | |
392 | - TabOrder = 3 | |
393 | - end | |
394 | 341 | object GBExperiment: TGroupBox |
395 | - Left = 159 | |
342 | + Left = 8 | |
396 | 343 | Height = 172 |
397 | 344 | Top = 8 |
398 | - Width = 178 | |
345 | + Width = 218 | |
399 | 346 | AutoSize = True |
400 | - Caption = 'Experiment' | |
347 | + Caption = 'Experimento' | |
401 | 348 | ChildSizing.LeftRightSpacing = 20 |
402 | 349 | ChildSizing.TopBottomSpacing = 20 |
403 | 350 | ChildSizing.HorizontalSpacing = 30 |
... | ... | @@ -406,19 +353,19 @@ object FormMatrixGame: TFormMatrixGame |
406 | 353 | ChildSizing.Layout = cclLeftToRightThenTopToBottom |
407 | 354 | ChildSizing.ControlsPerLine = 2 |
408 | 355 | ClientHeight = 155 |
409 | - ClientWidth = 174 | |
410 | - TabOrder = 4 | |
356 | + ClientWidth = 214 | |
357 | + TabOrder = 0 | |
411 | 358 | object LabelExpCond: TLabel |
412 | 359 | Left = 20 |
413 | 360 | Height = 15 |
414 | 361 | Top = 20 |
415 | - Width = 88 | |
362 | + Width = 128 | |
416 | 363 | AutoSize = False |
417 | 364 | Caption = 'Condição:' |
418 | 365 | ParentColor = False |
419 | 366 | end |
420 | 367 | object LabelExpCondCount: TLabel |
421 | - Left = 138 | |
368 | + Left = 178 | |
422 | 369 | Height = 15 |
423 | 370 | Top = 20 |
424 | 371 | Width = 16 |
... | ... | @@ -430,12 +377,12 @@ object FormMatrixGame: TFormMatrixGame |
430 | 377 | Left = 20 |
431 | 378 | Height = 15 |
432 | 379 | Top = 45 |
433 | - Width = 88 | |
380 | + Width = 128 | |
434 | 381 | Caption = 'Generation:' |
435 | 382 | ParentColor = False |
436 | 383 | end |
437 | 384 | object LabelExpGenCount: TLabel |
438 | - Left = 138 | |
385 | + Left = 178 | |
439 | 386 | Height = 15 |
440 | 387 | Top = 45 |
441 | 388 | Width = 16 |
... | ... | @@ -446,12 +393,12 @@ object FormMatrixGame: TFormMatrixGame |
446 | 393 | Left = 20 |
447 | 394 | Height = 15 |
448 | 395 | Top = 70 |
449 | - Width = 88 | |
396 | + Width = 128 | |
450 | 397 | Caption = 'Cycle:' |
451 | 398 | ParentColor = False |
452 | 399 | end |
453 | 400 | object LabelExpCycleCount: TLabel |
454 | - Left = 138 | |
401 | + Left = 178 | |
455 | 402 | Height = 15 |
456 | 403 | Top = 70 |
457 | 404 | Width = 16 |
... | ... | @@ -462,28 +409,28 @@ object FormMatrixGame: TFormMatrixGame |
462 | 409 | Left = 20 |
463 | 410 | Height = 15 |
464 | 411 | Top = 95 |
465 | - Width = 88 | |
412 | + Width = 128 | |
466 | 413 | Caption = 'Prox. Jog.:' |
467 | 414 | ParentColor = False |
468 | 415 | end |
469 | 416 | object LabelExpNxtPlayerCount: TLabel |
470 | - Left = 138 | |
417 | + Left = 178 | |
471 | 418 | Height = 15 |
472 | 419 | Top = 95 |
473 | 420 | Width = 16 |
474 | 421 | Caption = 'NA' |
475 | 422 | ParentColor = False |
476 | 423 | end |
477 | - object Label21: TLabel | |
424 | + object LabelExpInterlocks: TLabel | |
478 | 425 | Left = 20 |
479 | 426 | Height = 15 |
480 | 427 | Top = 120 |
481 | - Width = 88 | |
482 | - Caption = 'NA' | |
428 | + Width = 128 | |
429 | + Caption = 'Entrelaçamentos:' | |
483 | 430 | ParentColor = False |
484 | 431 | end |
485 | - object Label22: TLabel | |
486 | - Left = 138 | |
432 | + object LabelExpInterlocksCount: TLabel | |
433 | + Left = 178 | |
487 | 434 | Height = 15 |
488 | 435 | Top = 120 |
489 | 436 | Width = 16 |
... | ... | @@ -502,18 +449,9 @@ object FormMatrixGame: TFormMatrixGame |
502 | 449 | TabOrder = 5 |
503 | 450 | Visible = False |
504 | 451 | end |
505 | - object Button3: TButton | |
506 | - Left = 1176 | |
507 | - Height = 25 | |
508 | - Top = 216 | |
509 | - Width = 75 | |
510 | - Caption = 'Button3' | |
511 | - OnClick = Button3Click | |
512 | - TabOrder = 6 | |
513 | - end | |
514 | 452 | object ChatPanel: TPanel |
515 | - AnchorSideLeft.Control = GBIndividualPoints | |
516 | - AnchorSideTop.Control = GBIndividualPoints | |
453 | + AnchorSideLeft.Control = GBIndividualAB | |
454 | + AnchorSideTop.Control = GBIndividualAB | |
517 | 455 | AnchorSideTop.Side = asrBottom |
518 | 456 | AnchorSideRight.Control = GBGrupo |
519 | 457 | AnchorSideRight.Side = asrBottom |
... | ... | @@ -525,7 +463,7 @@ object FormMatrixGame: TFormMatrixGame |
525 | 463 | BorderSpacing.Top = 10 |
526 | 464 | ClientHeight = 354 |
527 | 465 | ClientWidth = 350 |
528 | - TabOrder = 7 | |
466 | + TabOrder = 6 | |
529 | 467 | object ChatMemoRecv: TMemo |
530 | 468 | AnchorSideBottom.Control = ChatSplitter |
531 | 469 | Left = 6 |
... | ... | @@ -573,4 +511,36 @@ object FormMatrixGame: TFormMatrixGame |
573 | 511 | WantTabs = True |
574 | 512 | end |
575 | 513 | end |
514 | + object GBIndividual: TGroupBox | |
515 | + AnchorSideLeft.Control = GBIndividualAB | |
516 | + AnchorSideTop.Control = GBIndividualAB | |
517 | + Left = 796 | |
518 | + Height = 122 | |
519 | + Top = 0 | |
520 | + Width = 170 | |
521 | + AutoSize = True | |
522 | + Caption = 'Pontuação Individual' | |
523 | + ChildSizing.LeftRightSpacing = 35 | |
524 | + ChildSizing.TopBottomSpacing = 45 | |
525 | + ChildSizing.Layout = cclLeftToRightThenTopToBottom | |
526 | + ChildSizing.ControlsPerLine = 1 | |
527 | + ClientHeight = 105 | |
528 | + ClientWidth = 166 | |
529 | + TabOrder = 7 | |
530 | + Visible = False | |
531 | + object LabelIndCount: TLabel | |
532 | + Left = 35 | |
533 | + Height = 15 | |
534 | + Top = 45 | |
535 | + Width = 96 | |
536 | + Align = alClient | |
537 | + Alignment = taCenter | |
538 | + AutoSize = False | |
539 | + Caption = '0' | |
540 | + Color = clDefault | |
541 | + Layout = tlCenter | |
542 | + ParentColor = False | |
543 | + Transparent = False | |
544 | + end | |
545 | + end | |
576 | 546 | end | ... | ... |
form_matrixgame.pas
... | ... | @@ -20,6 +20,7 @@ uses |
20 | 20 | //, zmq_pub_sub |
21 | 21 | , game_zmq_actors |
22 | 22 | , game_actors |
23 | + , game_control | |
23 | 24 | ; |
24 | 25 | |
25 | 26 | type |
... | ... | @@ -28,12 +29,9 @@ type |
28 | 29 | |
29 | 30 | TFormMatrixGame = class(TForm) |
30 | 31 | btnConfirmRow: TButton; |
31 | - Button1: TButton; | |
32 | - Button2: TButton; | |
33 | - Button3: TButton; | |
34 | - CheckBoxDrawDots: TCheckBox; | |
32 | + GBIndividual: TGroupBox; | |
35 | 33 | GBLastChoice: TGroupBox; |
36 | - GBIndividualPoints: TGroupBox; | |
34 | + GBIndividualAB: TGroupBox; | |
37 | 35 | GBGrupo: TGroupBox; |
38 | 36 | GBAdmin: TGroupBox; |
39 | 37 | GBLastChoiceP0: TGroupBox; |
... | ... | @@ -51,8 +49,9 @@ type |
51 | 49 | LabelExpCycleCount: TLabel; |
52 | 50 | LabelExpNxtPlayer: TLabel; |
53 | 51 | LabelExpNxtPlayerCount: TLabel; |
54 | - Label21: TLabel; | |
55 | - Label22: TLabel; | |
52 | + LabelExpInterlocks: TLabel; | |
53 | + LabelExpInterlocksCount: TLabel; | |
54 | + LabelIndCount: TLabel; | |
56 | 55 | LabelIndACount: TLabel; |
57 | 56 | LabelIndBCount: TLabel; |
58 | 57 | LabelCurrentColor1: TLabel; |
... | ... | @@ -70,32 +69,25 @@ type |
70 | 69 | Panel4: TPanel; |
71 | 70 | Panel5: TPanel; |
72 | 71 | PanelCurrentColor1: TPanel; |
73 | - rgMatrixType: TRadioGroup; | |
74 | 72 | ChatSplitter: TSplitter; |
75 | 73 | StringGridMatrix: TStringGrid; |
76 | 74 | procedure btnConfirmRowClick(Sender: TObject); |
77 | - procedure Button1Click(Sender: TObject); | |
78 | - procedure Button3Click(Sender: TObject); | |
79 | 75 | procedure ChatMemoSendKeyPress(Sender: TObject; var Key: char); |
80 | 76 | procedure CheckBoxDrawDotsChange(Sender: TObject); |
81 | 77 | procedure FormActivate(Sender: TObject); |
82 | - procedure FormCreate(Sender: TObject); | |
83 | - procedure rgMatrixTypeClick(Sender: TObject); | |
84 | 78 | procedure StringGridMatrixBeforeSelection(Sender: TObject; aCol, aRow: integer); |
85 | 79 | procedure StringGridMatrixDrawCell(Sender: TObject; aCol, aRow: integer; |
86 | 80 | aRect: TRect; aState: TGridDrawState); |
87 | 81 | private |
88 | - //FZMQAdmin : TZMQAdmin; | |
89 | - FZMQActor : TZMQActor; | |
90 | - FGameActor : TGameActor; | |
91 | - //FGameActors : TGameActors; | |
92 | - function GetSelectedColorF(AStringGrid : TStringGrid) : UTF8string; | |
93 | - function GetSelectedRowF(AStringGrid : TStringGrid) : UTF8string; | |
94 | - function GetRowColor(ARow : integer) : TColor; | |
95 | - procedure SetGameActor(AValue: TGameActor); | |
96 | - procedure MessageReceived(AMessage : TStringList); | |
82 | + FGameControl : TGameControl; | |
83 | + FID: string; | |
84 | + FMustDrawDots: Boolean; | |
85 | + FMustDrawDotsClear: Boolean; | |
86 | + FRowBase: integer; | |
97 | 87 | public |
98 | - property GameActor : TGameActor read FGameActor write SetGameActor; | |
88 | + procedure SetID(S : string); | |
89 | + procedure SetGameActor(AValue: TGameActor); | |
90 | + property ID : string read FID; | |
99 | 91 | end; |
100 | 92 | |
101 | 93 | var |
... | ... | @@ -107,7 +99,6 @@ uses LCLType, game_resources; |
107 | 99 | |
108 | 100 | // uses datamodule; |
109 | 101 | var |
110 | - RowBase: integer = 0; | |
111 | 102 | MustDrawSelection : Boolean; // work around until a bug fix for ClearSelection is released |
112 | 103 | |
113 | 104 | {$R *.lfm} |
... | ... | @@ -118,6 +109,7 @@ procedure TFormMatrixGame.StringGridMatrixDrawCell(Sender: TObject; aCol, aRow: |
118 | 109 | aRect: TRect; aState: TGridDrawState); |
119 | 110 | var |
120 | 111 | OldCanvas: TCanvas; |
112 | + RowBase : integer; | |
121 | 113 | |
122 | 114 | procedure SaveOldCanvas; |
123 | 115 | begin |
... | ... | @@ -166,10 +158,11 @@ var |
166 | 158 | TStringGrid(Sender).Canvas.Brush.Color := Color; |
167 | 159 | TStringGrid(Sender).Canvas.Pen.Color := Color; |
168 | 160 | TStringGrid(Sender).Canvas.Rectangle(aRect); |
169 | - if CheckBoxDrawDots.Checked then | |
170 | - if (Odd(aRow + RowBase) and not Odd(aCol)) or | |
171 | - (not Odd(aRow + RowBase) and Odd(aCol)) then | |
172 | - DrawDots; | |
161 | + if Assigned(FGameControl) then | |
162 | + if FGameControl.MustDrawDots then | |
163 | + if (Odd(aRow + RowBase) and not Odd(aCol)) or | |
164 | + (not Odd(aRow + RowBase) and Odd(aCol)) then | |
165 | + DrawDots; | |
173 | 166 | end; |
174 | 167 | //function GetTextX(S : String): Longint; |
175 | 168 | //begin |
... | ... | @@ -177,6 +170,8 @@ var |
177 | 170 | //end; |
178 | 171 | |
179 | 172 | begin |
173 | + if Assigned(FGameControl) then | |
174 | + RowBase:=FGameControl.RowBase; | |
180 | 175 | SaveOldCanvas; |
181 | 176 | try |
182 | 177 | //if (aRow >= RowBase) and (aCol = 10) then |
... | ... | @@ -184,7 +179,7 @@ begin |
184 | 179 | |
185 | 180 | if (aCol <> 0) and (aRow > (RowBase-1)) then |
186 | 181 | begin |
187 | - DrawLines(GetRowColor(aRow)); | |
182 | + DrawLines(GetRowColor(aRow,RowBase)); | |
188 | 183 | |
189 | 184 | if (gdSelected in aState) and MustDrawSelection then |
190 | 185 | begin |
... | ... | @@ -226,111 +221,42 @@ begin |
226 | 221 | end; |
227 | 222 | end; |
228 | 223 | |
229 | -function TFormMatrixGame.GetSelectedColorF(AStringGrid : TStringGrid): UTF8string; | |
230 | -var LColor : TColor; | |
231 | -begin | |
232 | - LColor := GetRowColor(AStringGrid.Selection.Top); | |
233 | - case LColor of | |
234 | - ccYellow: Result := 'Y'; | |
235 | - ccBlue : Result := 'B'; | |
236 | - ccGreen: Result := 'G'; | |
237 | - ccRed: Result := 'R'; | |
238 | - ccMagenta: Result := 'M'; | |
239 | - end; | |
240 | -end; | |
241 | - | |
242 | -function TFormMatrixGame.GetSelectedRowF(AStringGrid: TStringGrid): UTF8string; | |
243 | -begin | |
244 | - Result := IntToStr(AStringGrid.Selection.Top); | |
245 | -end; | |
246 | - | |
247 | -function TFormMatrixGame.GetRowColor(ARow: integer): TColor; | |
248 | -var LRow : integer; | |
249 | -begin | |
250 | - if RowBase = 1 then | |
251 | - LRow := aRow -1 | |
252 | - else LRow := aRow; | |
253 | - | |
254 | - case LRow of | |
255 | - 0,5 :Result := ccYellow; | |
256 | - 1,6 :Result := ccGreen; | |
257 | - 2,7 :Result := ccRed; | |
258 | - 3,8 :Result := ccBlue; | |
259 | - 4,9 :Result := ccMagenta; | |
260 | - end; | |
261 | -end; | |
262 | - | |
263 | 224 | procedure TFormMatrixGame.SetGameActor(AValue: TGameActor); |
264 | 225 | |
265 | 226 | procedure SetZMQAdmin; |
266 | 227 | begin |
267 | - FZMQActor := TZMQAdmin.Create(Self); | |
228 | + FGameControl := TGameControl.Create(TZMQAdmin.Create(Self)); | |
268 | 229 | GBAdmin.Visible:= True; |
269 | 230 | end; |
270 | 231 | |
271 | 232 | procedure SetZMQPlayer; |
272 | 233 | begin |
273 | - FZMQActor := TZMQPlayer.Create(Self); | |
234 | + FGameControl := TGameControl.Create(TZMQPlayer.Create(Self)); | |
274 | 235 | btnConfirmRow.Visible := True; |
275 | 236 | StringGridMatrix.Enabled := True; |
237 | + | |
238 | + FGameControl.SendMessage(K_ARRIVED); | |
276 | 239 | end; |
277 | 240 | |
278 | 241 | procedure SetZMQWatcher; |
279 | 242 | begin |
280 | - FZMQActor := TZMQWatcher.Create(Self); | |
243 | + FGameControl := TGameControl.Create(TZMQWatcher.Create(Self)); | |
281 | 244 | end; |
282 | 245 | |
283 | 246 | begin |
284 | - if FGameActor=AValue then Exit; | |
285 | - FGameActor:=AValue; | |
286 | - | |
287 | - case FGameActor of | |
247 | + case AValue of | |
288 | 248 | gaAdmin: SetZMQAdmin; |
289 | 249 | gaPlayer: SetZMQPlayer; |
290 | 250 | gaWatcher: SetZMQWatcher; |
291 | 251 | end; |
292 | - | |
293 | - FZMQActor.OnMessageReceived:=@MessageReceived; | |
294 | - FZMQActor.Start; | |
252 | + FGameControl.SetID(FID); | |
295 | 253 | end; |
296 | 254 | |
297 | -procedure TFormMatrixGame.MessageReceived(AMessage: TStringList); | |
298 | - | |
299 | - procedure SendChat; | |
300 | - begin | |
301 | - ChatMemoRecv.Lines.Append(('['+AMessage[1]+']: ')+AMessage[2]); | |
302 | - end; | |
303 | - | |
304 | - procedure PlayerChoice; | |
305 | - begin | |
306 | - | |
307 | - end; | |
308 | - | |
309 | - procedure PlayerArrived; | |
310 | - begin | |
311 | - WriteLn('arrived'); | |
312 | - end; | |
313 | - | |
314 | - procedure PlayerLogin; | |
315 | - begin | |
316 | - WriteLn('login'); | |
317 | - end; | |
318 | - | |
319 | - procedure PlayerLogout; | |
320 | - begin | |
321 | - WriteLn('logout'); | |
322 | - end; | |
255 | +procedure TFormMatrixGame.SetID(S: string); | |
323 | 256 | begin |
324 | - case AMessage[0] of | |
325 | - 'Player.Choice' : PlayerChoice; | |
326 | - 'Player.Arrived' : PlayerArrived; | |
327 | - 'Player.Login' : PlayerLogin; | |
328 | - 'Player.Logout': PlayerLogout; | |
329 | - 'Player.SendChat','Admin.SendChat': SendChat; | |
330 | - end; | |
257 | + FID := S; | |
331 | 258 | end; |
332 | 259 | |
333 | - | |
334 | 260 | procedure TFormMatrixGame.CheckBoxDrawDotsChange(Sender: TObject); |
335 | 261 | begin |
336 | 262 | StringGridMatrix.Invalidate; |
... | ... | @@ -342,85 +268,17 @@ begin |
342 | 268 | StringGridMatrix.FocusRectVisible := False; |
343 | 269 | end; |
344 | 270 | |
345 | - | |
346 | -procedure TFormMatrixGame.FormCreate(Sender: TObject); | |
347 | -begin | |
348 | - GameActor := gaNone; | |
349 | -end; | |
350 | - | |
351 | -procedure TFormMatrixGame.rgMatrixTypeClick(Sender: TObject); | |
352 | - | |
353 | - procedure WriteGridFixedNames(AStringGrid: TStringGrid; WriteCols: boolean); | |
354 | - var | |
355 | - i: integer; | |
356 | - begin | |
357 | - with AStringGrid do | |
358 | - for i := 0 to 9 do | |
359 | - begin | |
360 | - Cells[0, i + RowBase] := IntToStr(i + 1); | |
361 | - if WriteCols then | |
362 | - Cells[i + 1, 0] := chr(65 + i); | |
363 | - end; | |
364 | - end; | |
365 | - | |
366 | -begin | |
367 | - case rgMatrixType.ItemIndex of | |
368 | - // rows only | |
369 | - 0: | |
370 | - begin | |
371 | - StringGridMatrix.Clean; | |
372 | - StringGridMatrix.FixedRows := 0; | |
373 | - StringGridMatrix.RowCount := 10; | |
374 | - StringGridMatrix.Height:=305; | |
375 | - StringGridMatrix.Options := [goFixedHorzLine, goHorzLine, goDrawFocusSelected, goRowSelect]; | |
376 | - RowBase := 0; | |
377 | - WriteGridFixedNames(StringGridMatrix, False); | |
378 | - end; | |
379 | - // rows and cols | |
380 | - 1: | |
381 | - begin | |
382 | - StringGridMatrix.Clean; | |
383 | - StringGridMatrix.FixedRows := 1; | |
384 | - StringGridMatrix.RowCount := 11; | |
385 | - StringGridMatrix.Height:=335; | |
386 | - StringGridMatrix.Options := [goFixedHorzLine, goHorzLine, goDrawFocusSelected, goRowSelect, goVertLine]; | |
387 | - RowBase := 1; | |
388 | - WriteGridFixedNames(StringGridMatrix, True); | |
389 | - end; | |
390 | - end; | |
391 | - | |
392 | -end; | |
393 | - | |
394 | 271 | procedure TFormMatrixGame.StringGridMatrixBeforeSelection(Sender: TObject; aCol, aRow: integer); |
395 | 272 | begin |
396 | 273 | if MustDrawSelection then Exit; |
397 | 274 | MustDrawSelection := True; |
398 | 275 | end; |
399 | 276 | |
400 | -procedure TFormMatrixGame.Button1Click(Sender: TObject); | |
401 | -begin | |
402 | - | |
403 | -end; | |
404 | - | |
405 | -procedure TFormMatrixGame.Button3Click(Sender: TObject); | |
406 | -begin | |
407 | - //S := TStringList.Create; | |
408 | - //S.Add('Player.Arrived'); | |
409 | - //S.Add(TZMQAdmin(FZMQActor).ID); | |
410 | - TZMQAdmin(FZMQActor).SendMessage(['Player.Arrived', TZMQAdmin(FZMQActor).ID]); | |
411 | - //S.Free; | |
412 | -end; | |
413 | - | |
414 | 277 | procedure TFormMatrixGame.ChatMemoSendKeyPress(Sender: TObject; var Key: char); |
415 | 278 | begin |
416 | 279 | if Key = Char(VK_RETURN) then |
417 | 280 | begin |
418 | - if FZMQActor.ClassType = TZMQAdmin then | |
419 | - TZMQAdmin(FZMQActor).SendMessage(['Admin.SendChat', CPlayerNamesMale[0], ChatMemoSend.Lines.Text]); | |
420 | - | |
421 | - if FZMQActor.ClassType = TZMQPlayer then | |
422 | - TZMQPlayer(FZMQActor).SendMessage(['Player.SendChat', CPlayerNamesFemale[0], ChatMemoSend.Lines.Text]); | |
423 | - | |
281 | + FGameControl.SendMessage(K_CHAT_M); | |
424 | 282 | with ChatMemoSend do |
425 | 283 | begin |
426 | 284 | Clear; |
... | ... | @@ -434,17 +292,11 @@ end; |
434 | 292 | |
435 | 293 | procedure TFormMatrixGame.btnConfirmRowClick(Sender: TObject); |
436 | 294 | begin |
437 | - if FZMQActor.ClassType = TZMQPlayer then | |
438 | - begin | |
439 | - //StringGridMatrix.ClearSelections; | |
440 | - //MustDrawSelection := False; | |
441 | - StringGridMatrix.Enabled:= False; | |
442 | - btnConfirmRow.Visible:=False; | |
443 | - TZMQPlayer(FZMQActor).SendMessage(['Player.Choice', | |
444 | - TZMQPlayer(FZMQActor).ID, | |
445 | - GetSelectedRowF(StringGridMatrix), | |
446 | - GetSelectedColorF(StringGridMatrix)]); | |
447 | - end; | |
295 | + //StringGridMatrix.ClearSelections; | |
296 | + //MustDrawSelection := False; | |
297 | + StringGridMatrix.Enabled:= False; | |
298 | + btnConfirmRow.Visible:=False; | |
299 | + FGameControl.SendMessage(K_CHOICE); | |
448 | 300 | end; |
449 | 301 | |
450 | 302 | end. | ... | ... |
units/game_actors.pas
... | ... | @@ -10,9 +10,13 @@ uses |
10 | 10 | ; |
11 | 11 | type |
12 | 12 | |
13 | + | |
13 | 14 | TGameActor = ( gaNone, gaAdmin, gaPlayer, gaWatcher ); |
14 | 15 | TGamePlayerStatus = (gpsWaiting, gpsPlaying, gpsPlayed); |
15 | 16 | |
17 | + TGameMatrix = (gmRows,gmColumns, gmDots,gmClearDots); | |
18 | + TGameMatrixType = set of TGameMatrix; | |
19 | + | |
16 | 20 | TGameRow = (grNone, |
17 | 21 | grOne,grTwo,grThree,grFour,grFive,grSix,grSeven,grEight,grNine,grTen, // 10 rows |
18 | 22 | grEven,grOdd, |
... | ... | @@ -107,6 +111,7 @@ type |
107 | 111 | end; |
108 | 112 | |
109 | 113 | TCondition = record |
114 | + ConditionName : string; | |
110 | 115 | Contingencies : TContingencies; // for producing points during the condition |
111 | 116 | |
112 | 117 | Points : record |
... | ... | @@ -138,6 +143,8 @@ type |
138 | 143 | Color : TGameColor; |
139 | 144 | end; |
140 | 145 | |
146 | + PPlayer = ^TPlayer; | |
147 | + | |
141 | 148 | TPlayer = record |
142 | 149 | ID, |
143 | 150 | Nicname, | ... | ... |
units/game_control.pas
... | ... | @@ -2,12 +2,15 @@ unit game_control; |
2 | 2 | |
3 | 3 | {$mode objfpc}{$H+} |
4 | 4 | |
5 | +{$DEFINE DEBUG} | |
6 | + | |
5 | 7 | interface |
6 | 8 | |
7 | 9 | uses |
8 | - Classes, SysUtils | |
10 | + Classes, SysUtils, Graphics, Grids | |
9 | 11 | , game_zmq_actors |
10 | 12 | , game_experiment |
13 | + , game_actors | |
11 | 14 | ; |
12 | 15 | |
13 | 16 | type |
... | ... | @@ -16,32 +19,314 @@ type |
16 | 19 | |
17 | 20 | TGameControl = class(TComponent) |
18 | 21 | private |
22 | + FID: string; | |
23 | + FMustDrawDots: Boolean; | |
24 | + FMustDrawDotsClear: Boolean; | |
25 | + FRowBase : integer; | |
26 | + FActor : TGameActor; | |
19 | 27 | FZMQActor : TZMQActor; |
20 | 28 | FExperiment : TExperiment; |
21 | - public | |
22 | - constructor Create(AZMQActor : TZMQActor; AOwner : TComponent); overload; | |
23 | - procedure SendMessage(AMessage : array of UTF8string); | |
29 | + function GetActorNicname(AID:string; Brackets : Boolean = False) : string; | |
30 | + function MessageHas(const A_CONST : string; AMessage : TStringList): Boolean; | |
31 | + procedure SetMatrixType(AStringGrid : TStringGrid; AMatrixType:TGameMatrixType; | |
32 | + var ARowBase:integer; var ADrawDots, ADrawClear : Boolean); | |
24 | 33 | procedure ReceiveMessage(AMessage : TStringList); |
34 | + function GetSelectedColorF(AStringGrid : TStringGrid) : UTF8string; | |
35 | + function GetSelectedRowF(AStringGrid : TStringGrid) : UTF8string; | |
36 | + procedure SetMustDrawDots(AValue: Boolean); | |
37 | + procedure SetMustDrawDotsClear(AValue: Boolean); | |
38 | + procedure SetRowBase(AValue: integer); | |
39 | + public | |
40 | + constructor Create(AZMQActor : TZMQActor); reintroduce; | |
41 | + destructor Destroy; override; | |
42 | + procedure SetID(S:string); | |
43 | + procedure SendMessage(AMessage : UTF8string); | |
44 | + property ID : string read FID; | |
45 | + property RowBase : integer read FRowBase write SetRowBase; | |
46 | + property MustDrawDots: Boolean read FMustDrawDots write SetMustDrawDots; | |
47 | + property MustDrawDotsClear:Boolean read FMustDrawDotsClear write SetMustDrawDotsClear; | |
25 | 48 | end; |
26 | 49 | |
50 | + function GetRowColor(ARow : integer;ARowBase:integer) : TColor; | |
51 | + | |
52 | +const | |
53 | + K_ARRIVED = '.Arrived'; | |
54 | + K_CHAT_M = '.ChatM'; | |
55 | + K_CHOICE = '.Choice'; | |
56 | + //K_RESPONSE = | |
57 | + | |
27 | 58 | implementation |
28 | 59 | |
60 | +uses form_matrixgame, game_resources, string_methods, zhelpers; | |
61 | + | |
62 | +const | |
63 | + GA_ADMIN = 'Admin'; | |
64 | + GA_PLAYER = 'Player'; | |
65 | + //GA_WATCHER = 'Watcher'; | |
66 | + | |
67 | +function GetRowColor(ARow: integer; ARowBase:integer): TColor; | |
68 | +var LRow : integer; | |
69 | +begin | |
70 | + if ARowBase = 1 then | |
71 | + LRow := aRow -1 | |
72 | + else LRow := aRow; | |
73 | + | |
74 | + case LRow of | |
75 | + 0,5 :Result := ccYellow; | |
76 | + 1,6 :Result := ccGreen; | |
77 | + 2,7 :Result := ccRed; | |
78 | + 3,8 :Result := ccBlue; | |
79 | + 4,9 :Result := ccMagenta; | |
80 | + end; | |
81 | +end; | |
82 | + | |
29 | 83 | { TGameControl } |
30 | 84 | |
31 | -constructor TGameControl.Create(AZMQActor: TZMQActor; AOwner: TComponent); | |
85 | +function TGameControl.GetActorNicname(AID: string; Brackets: Boolean): string; | |
86 | +var i : integer; | |
87 | +begin | |
88 | + if FExperiment.PlayersCount > -1 then | |
89 | + begin | |
90 | + for i:= 0 to FExperiment.PlayersCount do | |
91 | + if FExperiment.Player[i].ID = AID then | |
92 | + begin | |
93 | + if Brackets then | |
94 | + Result := '['+FExperiment.Player[i].Nicname+']' | |
95 | + else | |
96 | + Result := FExperiment.Player[i].Nicname; | |
97 | + Break; | |
98 | + end | |
99 | + end | |
100 | + else | |
101 | + begin | |
102 | + WriteLn('TGameControl.GetActorNicname:Using Harcoded Nicame'); | |
103 | + Result := '[UNKNOWN]'; | |
104 | + end; | |
105 | +end; | |
106 | + | |
107 | +function TGameControl.MessageHas(const A_CONST: string; AMessage: TStringList): Boolean; | |
108 | +begin | |
109 | + Result := Pos(A_CONST,AMessage[0])>0; | |
110 | +end; | |
111 | + | |
112 | +procedure TGameControl.SetMatrixType(AStringGrid: TStringGrid; | |
113 | + AMatrixType: TGameMatrixType; var ARowBase: integer; var ADrawDots, | |
114 | + ADrawClear: Boolean); | |
115 | + | |
116 | + procedure WriteGridFixedNames(ASGrid: TStringGrid; WriteCols: boolean); | |
117 | + var | |
118 | + i: integer; | |
119 | + begin | |
120 | + with ASGrid do | |
121 | + for i := 0 to 9 do | |
122 | + begin | |
123 | + Cells[0, i + ARowBase] := IntToStr(i + 1); | |
124 | + if WriteCols then | |
125 | + Cells[i + 1, 0] := chr(65 + i); | |
126 | + end; | |
127 | + end; | |
128 | + | |
129 | +begin | |
130 | + AStringGrid.Clean; | |
131 | + if gmRows in AMatrixType then | |
132 | + begin | |
133 | + ARowBase := 0; | |
134 | + AStringGrid.FixedRows := 0; | |
135 | + AStringGrid.RowCount := 10; | |
136 | + AStringGrid.Height:=305; | |
137 | + AStringGrid.Options := [goFixedHorzLine, goHorzLine, goDrawFocusSelected, goRowSelect]; | |
138 | + WriteGridFixedNames(AStringGrid, False); | |
139 | + end; | |
140 | + | |
141 | + if gmColumns in AMatrixType then | |
142 | + begin | |
143 | + ARowBase := 1; | |
144 | + AStringGrid.Clean; | |
145 | + AStringGrid.FixedRows := 1; | |
146 | + AStringGrid.RowCount := 11; | |
147 | + AStringGrid.Height:=335; | |
148 | + AStringGrid.Options := [goFixedHorzLine, goHorzLine, goDrawFocusSelected, goRowSelect, goVertLine]; | |
149 | + WriteGridFixedNames(AStringGrid, True); | |
150 | + end; | |
151 | + | |
152 | + ADrawDots := gmDots in AMatrixType; | |
153 | + ADrawClear:= gmClearDots in AMatrixType; | |
154 | +end; | |
155 | + | |
156 | +function TGameControl.GetSelectedColorF(AStringGrid: TStringGrid): UTF8string; | |
157 | +begin | |
158 | + Result := GetRowColorString(GetRowColor(AStringGrid.Selection.Top,RowBase)); | |
159 | +end; | |
160 | + | |
161 | +function TGameControl.GetSelectedRowF(AStringGrid: TStringGrid): UTF8string; | |
162 | +begin | |
163 | + Result := IntToStr(AStringGrid.Selection.Top); | |
164 | +end; | |
165 | + | |
166 | +procedure TGameControl.SetMustDrawDots(AValue: Boolean); | |
167 | +begin | |
168 | + if FMustDrawDots=AValue then Exit; | |
169 | + FMustDrawDots:=AValue; | |
170 | +end; | |
171 | + | |
172 | +procedure TGameControl.SetMustDrawDotsClear(AValue: Boolean); | |
173 | +begin | |
174 | + if FMustDrawDotsClear=AValue then Exit; | |
175 | + FMustDrawDotsClear:=AValue; | |
176 | +end; | |
177 | + | |
178 | +procedure TGameControl.SetRowBase(AValue: integer); | |
179 | +begin | |
180 | + if FRowBase=AValue then Exit; | |
181 | + case AValue of | |
182 | + 0 : FExperiment.MatrixType := [gmRows]; | |
183 | + 1 : FExperiment.MatrixType := [gmRows,gmColumns]; | |
184 | + end; | |
185 | + FRowBase:=AValue; | |
186 | +end; | |
187 | + | |
188 | +constructor TGameControl.Create(AZMQActor: TZMQActor); | |
32 | 189 | begin |
33 | - inherited Create(AOwner); | |
190 | + inherited Create(AZMQActor.Owner); | |
34 | 191 | FZMQActor := AZMQActor; |
192 | + FZMQActor.SetID(ID); | |
193 | + FZMQActor.OnMessageReceived:=@ReceiveMessage; | |
194 | + FZMQActor.Start; | |
195 | + | |
196 | + if FZMQActor.ClassType = TZMQAdmin then | |
197 | + FActor := gaAdmin; | |
198 | + if FZMQActor.ClassType = TZMQPlayer then | |
199 | + FActor := gaPlayer; | |
200 | + if FZMQActor.ClassType = TZMQWatcher then | |
201 | + FActor := gaWatcher; | |
202 | + | |
203 | + RowBase:= 0; | |
204 | + MustDrawDots:=False; | |
205 | + MustDrawDotsClear:=False; | |
206 | + | |
207 | + {$IFDEF DEBUG} | |
208 | + case FActor of | |
209 | + gaAdmin:begin | |
210 | + FExperiment := TExperiment.Create(AZMQActor.Owner); | |
211 | + end; | |
212 | + gaPlayer:begin | |
213 | + | |
214 | + end; | |
215 | + end; | |
216 | + {$ENDIF} | |
35 | 217 | end; |
36 | 218 | |
37 | -procedure TGameControl.SendMessage(AMessage: array of UTF8string); | |
219 | +destructor TGameControl.Destroy; | |
38 | 220 | begin |
221 | + inherited Destroy; | |
222 | +end; | |
39 | 223 | |
224 | +procedure TGameControl.SetID(S: string); | |
225 | +begin | |
226 | + FID := S; | |
40 | 227 | end; |
41 | 228 | |
42 | -procedure TGameControl.ReceiveMessage(AMessage: TStringList); | |
229 | +procedure TGameControl.SendMessage(AMessage: UTF8string); | |
230 | +var | |
231 | +{$IFDEF DEBUG} | |
232 | + i : integer; | |
233 | +{$ENDIF} | |
234 | + M : array of UTF8string; | |
235 | + | |
236 | + procedure SetM(A: array of UTF8String); | |
237 | + var i : integer; | |
238 | + begin | |
239 | + SetLength(M,Length(A)); | |
240 | + for i := 0 to Length(A) -1 do | |
241 | + M[i] := A[i]; | |
242 | + end; | |
243 | + | |
43 | 244 | begin |
245 | + case AMessage of | |
246 | + K_ARRIVED : SetM([ | |
247 | + AMessage | |
248 | + , FZMQActor.ID | |
249 | + ]); | |
250 | + | |
251 | + K_CHOICE : SetM([ | |
252 | + AMessage | |
253 | + , FZMQActor.ID | |
254 | + , GetSelectedRowF(FormMatrixGame.StringGridMatrix) | |
255 | + , GetSelectedColorF(FormMatrixGame.StringGridMatrix) | |
256 | + ]); | |
257 | + | |
258 | + K_CHAT_M : SetM([ | |
259 | + AMessage | |
260 | + , GetActorNicname(FZMQActor.ID, True) | |
261 | + , FormMatrixGame.ChatMemoSend.Lines.Text | |
262 | + ]); | |
263 | + | |
264 | + end; | |
265 | + | |
266 | + case FActor of | |
267 | + gaAdmin: begin | |
268 | + if not FExperiment.ResearcherCanChat then Exit; | |
269 | + M[0] := GA_ADMIN+M[0]; | |
270 | + TZMQAdmin(FZMQActor).SendMessage(M); | |
271 | + end; | |
272 | + gaPlayer:begin | |
273 | + M[0] := GA_PLAYER+M[0]; | |
274 | + TZMQPlayer(FZMQActor).SendMessage(M); | |
275 | + end; | |
276 | + //gaWatcher:begin // Cannot SendMessages | |
277 | + // M[0] := GA_WATCHER+M[0]; | |
278 | + // TZMQWatcher(FZMQActor).SendMessage(M); | |
279 | + end; | |
44 | 280 | |
281 | +{$IFDEF DEBUG} | |
282 | + for i := 0 to Length(M)-1 do | |
283 | + WriteLn(M[i]); | |
284 | +{$ENDIF} | |
285 | +end; | |
286 | + | |
287 | +procedure TGameControl.ReceiveMessage(AMessage: TStringList); | |
288 | + | |
289 | + function MHas(const C : string) : Boolean; | |
290 | + begin | |
291 | + Result := MessageHas(C,AMessage); | |
292 | + end; | |
293 | + | |
294 | + procedure ReceiveActor; | |
295 | + var Data: TStringList; | |
296 | + begin | |
297 | + Data := TStringList.Create; | |
298 | + try | |
299 | + WriteLn('arrived'); | |
300 | + | |
301 | + finally | |
302 | + Data.Free; | |
303 | + end; | |
304 | + end; | |
305 | + | |
306 | + procedure ReceiveChoice; | |
307 | + begin | |
308 | + | |
309 | + end; | |
310 | + | |
311 | + procedure ReceiveChat; | |
312 | + begin | |
313 | + FormMatrixGame.ChatMemoRecv.Lines.Append(('['+AMessage[1]+']: ')+AMessage[2]); | |
314 | + end; | |
315 | + | |
316 | + procedure ReceiveLogin; | |
317 | + begin | |
318 | + WriteLn('login'); | |
319 | + end; | |
320 | + | |
321 | + procedure ReceiveLogout; | |
322 | + begin | |
323 | + WriteLn('logout'); | |
324 | + end; | |
325 | + | |
326 | +begin | |
327 | + if MHas(K_ARRIVED) then ReceiveActor; | |
328 | + if MHas(K_CHAT_M) then ReceiveChat; | |
329 | + if MHas(K_CHOICE) then ReceiveChoice; | |
45 | 330 | end; |
46 | 331 | |
47 | 332 | end. | ... | ... |
units/game_experiment.pas
... | ... | @@ -14,7 +14,8 @@ type |
14 | 14 | |
15 | 15 | { TExperiment } |
16 | 16 | |
17 | - TPlayersPlaying = array of integer; | |
17 | + TPlayers = array of TPlayer; | |
18 | + TConditions = array of TCondition; | |
18 | 19 | |
19 | 20 | TExperiment = class(TComponent) |
20 | 21 | private |
... | ... | @@ -22,23 +23,27 @@ type |
22 | 23 | FExperimentName, |
23 | 24 | FFilename, |
24 | 25 | FResearcher : string; |
26 | + FMatrixType: TGameMatrixType; | |
25 | 27 | FRegData : TRegData; |
26 | 28 | FGenPlayersAsNeeded : Boolean; |
27 | - FPlayersPlaying : TPlayersPlaying; | |
28 | - FPlayers : array of TPlayer; | |
29 | + FPlayersPlaying : TList; | |
30 | + FPlayers : TPlayers; | |
29 | 31 | FCurrentCondition : integer; |
30 | - FConditions : array of TCondition; | |
32 | + FConditions : TConditions; | |
33 | + FResearcherCanChat: Boolean; | |
31 | 34 | FShowChat: Boolean; |
32 | 35 | function GetCondition(I : Integer): TCondition; |
33 | 36 | function GetConditionsCount: integer; |
34 | 37 | function GetContingency(ACondition, I : integer): TContingency; |
35 | 38 | function GetPlayer(I : integer): TPlayer; |
36 | 39 | function GetPlayersCount: integer; |
37 | - function GetPlayersPlaying: TPlayersPlaying; | |
40 | + function GetPlayersPlaying: TList; | |
38 | 41 | procedure SetCondition(I : Integer; AValue: TCondition); |
39 | 42 | procedure SetContingency(ACondition, I : integer; AValue: TContingency); |
43 | + procedure SetMatrixType(AValue: TGameMatrixType); | |
40 | 44 | procedure SetPlayer(I : integer; AValue: TPlayer); |
41 | - procedure SetPlayersPlaying(AValue: TPlayersPlaying); | |
45 | + procedure SetPlayersPlaying(AValue: TList); | |
46 | + procedure SetResearcherCanChat(AValue: Boolean); | |
42 | 47 | public |
43 | 48 | constructor Create(AOwner:TComponent);override; |
44 | 49 | constructor Create(AFilename: string; AOwner:TComponent); overload; |
... | ... | @@ -50,9 +55,10 @@ type |
50 | 55 | function AppendContingency(ACondition : integer) : integer;overload; |
51 | 56 | function AppendContingency(ACondition : integer;AContingency : TContingency) : integer;overload; |
52 | 57 | function AppendPlayer : integer;overload; |
53 | - function AppendPlayer(APlayer : TPlayer) : integer;overload; | |
58 | + function AppendPlayer(APlayer : TPlayer) : integer; overload; | |
54 | 59 | procedure SaveToFile(AFilename: string); overload; |
55 | 60 | procedure SaveToFile; overload; |
61 | + property ResearcherCanChat : Boolean read FResearcherCanChat write SetResearcherCanChat ; | |
56 | 62 | property Researcher : string read FResearcher write FResearcher; |
57 | 63 | property Condition[I : Integer]: TCondition read GetCondition write SetCondition; |
58 | 64 | property ConditionsCount : integer read GetConditionsCount; |
... | ... | @@ -62,9 +68,10 @@ type |
62 | 68 | property ExperimentName : string read FExperimentName write FExperimentName; |
63 | 69 | property GenPlayersAsNeeded : Boolean read FGenPlayersAsNeeded write FGenPlayersAsNeeded; |
64 | 70 | property Player[I : integer] : TPlayer read GetPlayer write SetPlayer; |
65 | - property PlayersCount : integer read GetPlayersCount; | |
66 | - property PlayersPlaying : TPlayersPlaying read GetPlayersPlaying write SetPlayersPlaying; | |
71 | + property PlayersCount : integer read GetPlayersCount; // how many players per turn? | |
72 | + property PlayersPlaying : TList read GetPlayersPlaying write SetPlayersPlaying; // how many players are playing? | |
67 | 73 | property ShowChat : Boolean read FShowChat write FShowChat; |
74 | + property MatrixType : TGameMatrixType read FMatrixType write SetMatrixType; | |
68 | 75 | end; |
69 | 76 | |
70 | 77 | resourcestring |
... | ... | @@ -72,7 +79,7 @@ resourcestring |
72 | 79 | |
73 | 80 | implementation |
74 | 81 | |
75 | -uses game_file_methods, game_actors_point; | |
82 | +uses game_file_methods, game_actors_point,Dialogs; | |
76 | 83 | |
77 | 84 | { TExperiment } |
78 | 85 | |
... | ... | @@ -98,19 +105,28 @@ end; |
98 | 105 | |
99 | 106 | function TExperiment.GetPlayersCount: integer; |
100 | 107 | begin |
101 | - Result := High(FPlayers); | |
108 | + if Length(FPlayers) = 0 then | |
109 | + Result := High(FPlayers) | |
110 | + else | |
111 | + Result := -1; | |
102 | 112 | end; |
103 | 113 | |
104 | -function TExperiment.GetPlayersPlaying: TPlayersPlaying; | |
105 | -var i:integer; | |
114 | +function TExperiment.GetPlayersPlaying: TList; | |
115 | +var | |
116 | + i:integer; | |
117 | + P:PPlayer; | |
106 | 118 | begin |
107 | - if Length(FPlayersPlaying) = 0 then | |
108 | - for i := Low(FPlayers) to High(FPlayers) do | |
109 | - if Player[i].Status = gpsPlaying then | |
110 | - begin | |
111 | - SetLength(FPlayersPlaying, Length(FPlayersPlaying)+1); | |
112 | - FPlayersPlaying[High(FPlayersPlaying)] := i; | |
113 | - end; | |
119 | + if FPlayersPlaying.Count > 0 then | |
120 | + FPlayersPlaying.Clear; | |
121 | + | |
122 | + for i := Low(FPlayers) to High(FPlayers) do | |
123 | + if Player[i].Status = gpsPlaying then | |
124 | + begin | |
125 | + P := nil; | |
126 | + P^ := Player[i]; | |
127 | + FPlayersPlaying.Add(P); | |
128 | + end; | |
129 | + | |
114 | 130 | Result := FPlayersPlaying; |
115 | 131 | end; |
116 | 132 | |
... | ... | @@ -127,32 +143,35 @@ begin |
127 | 143 | FConditions[ACondition].Contingencies[I] := AValue; |
128 | 144 | end; |
129 | 145 | |
146 | +procedure TExperiment.SetMatrixType(AValue: TGameMatrixType); | |
147 | +begin | |
148 | + if FMatrixType=AValue then Exit; | |
149 | + FMatrixType:=AValue; | |
150 | +end; | |
151 | + | |
152 | + | |
130 | 153 | procedure TExperiment.SetPlayer(I : integer; AValue: TPlayer); |
131 | 154 | begin |
132 | 155 | if (I >= Low(FPlayers)) and (I <= High(FPlayers)) then |
133 | 156 | FPlayers[I] := AValue; |
134 | 157 | end; |
135 | 158 | |
136 | -procedure TExperiment.SetPlayersPlaying(AValue: TPlayersPlaying); | |
137 | -var i : integer; LAllEqualDontSet : Boolean; | |
159 | +procedure TExperiment.SetPlayersPlaying(AValue: TList); | |
138 | 160 | begin |
139 | - LAllEqualDontSet := True; | |
140 | - if Length(FPlayersPlaying) = Length(AValue) then | |
141 | - for i := Low(AValue) to High(AValue) do | |
142 | - if not FPlayersPlaying[i] <> AValue[i] then | |
143 | - begin | |
144 | - LAllEqualDontSet := False; | |
145 | - Break; | |
146 | - end; | |
147 | - if LAllEqualDontSet then Exit; | |
148 | - SetLength(FPlayersPlaying,Length(AValue)); | |
149 | - for i := Low(AValue) to High(AValue) do | |
150 | - FPlayersPlaying[i] := AValue[i]; | |
161 | + if FPlayersPlaying = AValue then Exit; | |
162 | + FPlayersPlaying := AValue; | |
163 | +end; | |
164 | + | |
165 | +procedure TExperiment.SetResearcherCanChat(AValue: Boolean); | |
166 | +begin | |
167 | + if FResearcherCanChat=AValue then Exit; | |
168 | + FResearcherCanChat:=AValue; | |
151 | 169 | end; |
152 | 170 | |
153 | 171 | constructor TExperiment.Create(AOwner: TComponent); |
154 | 172 | begin |
155 | 173 | inherited Create(AOwner); |
174 | + FPlayersPlaying := TList.Create; | |
156 | 175 | LoadExperimentFromResource(Self); |
157 | 176 | end; |
158 | 177 | |
... | ... | @@ -164,6 +183,7 @@ end; |
164 | 183 | |
165 | 184 | destructor TExperiment.Destroy; |
166 | 185 | begin |
186 | + FPlayersPlaying.Free; | |
167 | 187 | inherited Destroy; |
168 | 188 | end; |
169 | 189 | |
... | ... | @@ -189,35 +209,36 @@ end; |
189 | 209 | |
190 | 210 | function TExperiment.AppendCondition(ACondition: TCondition): integer; |
191 | 211 | begin |
192 | - FConditions[AppendCondition] := ACondition; | |
212 | + SetLength(FConditions, Length(FConditions)+1); | |
193 | 213 | Result := High(FConditions); |
214 | + FConditions[Result] := ACondition; | |
194 | 215 | end; |
195 | 216 | |
196 | 217 | function TExperiment.AppendContingency(ACondition: integer): integer; |
197 | 218 | begin |
198 | 219 | SetLength(FConditions[ACondition].Contingencies, Length(FConditions[ACondition].Contingencies)+1); |
199 | - //FConditions[ACondition].Contingencies[High(FConditions[ACondition].Contingencies)].Consequence := TConsequence.Create(Self); | |
200 | - //FConditions[ACondition].Contingencies[High(FConditions[ACondition].Contingencies)].Consequence.Points.A := TGamePoint.Create(Self); | |
201 | 220 | Result := High(FConditions[ACondition].Contingencies); |
202 | 221 | end; |
203 | 222 | |
204 | 223 | function TExperiment.AppendContingency(ACondition: integer; |
205 | 224 | AContingency: TContingency): integer; |
206 | 225 | begin |
207 | - FConditions[ACondition].Contingencies[AppendContingency(ACondition)] := AContingency; | |
226 | + SetLength(FConditions[ACondition].Contingencies, Length(FConditions[ACondition].Contingencies)+1); | |
208 | 227 | Result := High(FConditions[ACondition].Contingencies); |
228 | + FConditions[ACondition].Contingencies[Result] := AContingency; | |
209 | 229 | end; |
210 | 230 | |
211 | 231 | function TExperiment.AppendPlayer: integer; |
212 | 232 | begin |
213 | 233 | SetLength(FPlayers, Length(FPlayers)+1); |
214 | - Result := High(FPlayers); | |
234 | + Result := Length(FPlayers)-1; | |
215 | 235 | end; |
216 | 236 | |
217 | 237 | function TExperiment.AppendPlayer(APlayer: TPlayer): integer; |
218 | 238 | begin |
219 | - FPlayers[AppendPlayer] := APlayer; | |
239 | + SetLength(FPlayers, Length(FPlayers)+1); | |
220 | 240 | Result := High(FPlayers); |
241 | + FPlayers[Result] := APlayer; | |
221 | 242 | end; |
222 | 243 | |
223 | 244 | procedure TExperiment.SaveToFile(AFilename: string); | ... | ... |
units/game_file_methods.pas
... | ... | @@ -39,11 +39,21 @@ begin |
39 | 39 | with AExperiment do |
40 | 40 | begin |
41 | 41 | Researcher := VAL_RESEARCHER; |
42 | + ResearcherCanChat:=True; | |
42 | 43 | ExperimentName:='Test Experiment'; |
43 | 44 | ExperimentAim:='This is a test experiment.'; |
44 | 45 | GenPlayersAsNeeded:=True; |
45 | 46 | CurrentCondition := 0; |
47 | + AppendPlayer(C_PLAYER_TEMPLATE); | |
48 | + AppendPlayer(C_PLAYER_TEMPLATE); | |
46 | 49 | i := AppendCondition(C_CONDITION_TEMPLATE); |
50 | + with Condition[i] do | |
51 | + begin | |
52 | + ConditionName := SEC_CONDITION+IntToStr(i+1); | |
53 | + Turn.Count:=0; | |
54 | + Turn.Value:=0; | |
55 | + Turn.Random:=False; | |
56 | + end; | |
47 | 57 | //j := AppendContingency(i,C_METACONTINGENCY_A1); |
48 | 58 | end; |
49 | 59 | end; |
... | ... | @@ -240,6 +250,7 @@ var |
240 | 250 | s1 := DEF_END; |
241 | 251 | end; |
242 | 252 | EndCriterium := GetEndCriteria(s1); |
253 | + ConditionName := ReadString(LS,KEY_COND_NAME,LS); | |
243 | 254 | Points.Count := GetPoints(ReadString(LS, KEY_POINTS_COUNT,DEF_POINTS)); |
244 | 255 | Points.OnStart := GetPoints(ReadString(LS, KEY_POINTS_ONSTART,DEF_POINTS)); |
245 | 256 | Turn.Count:= ReadInteger(LS, KEY_TURN_COUNT,1); | ... | ... |
units/game_resources.pas
... | ... | @@ -20,6 +20,7 @@ resourcestring |
20 | 20 | KEY_RESEARCHER = 'Pesquisador.Responsável'; |
21 | 21 | KEY_GEN_PLAYER_AS_NEEDED = 'GerarJogadoresAutomaticamente'; |
22 | 22 | KEY_CURRENT_CONDITION = 'ComeçarNaCondição'; |
23 | + KEY_MATRIX_TYPE= 'TipoDaMatrix'; | |
23 | 24 | |
24 | 25 | SEC_PLAYER = 'Jogador.'; |
25 | 26 | KEY_PLAYER_TEMP = 'Data.X'; |
... | ... | @@ -34,12 +35,7 @@ resourcestring |
34 | 35 | KEY_PLAYER_STATUS = 'Status'; |
35 | 36 | |
36 | 37 | SEC_CONDITION = 'Condição.'; |
37 | - KEY_CONTINGENCY = 'Contingência.'; | |
38 | - KEY_METACONTINGENCY = 'Metacontingência.'; | |
39 | - | |
40 | - KEY_RESPONSE = '.RespostaEsperada'; // ROW,COLOR,OPCODE | |
41 | - KEY_CONSEQUE = '.Consequência'; // A,B,G,CSQCODE | |
42 | - KEY_CONSEQUE_MESSAGE = '.Consequência.Mensagem'; | |
38 | + KEY_COND_NAME = 'Nome'; | |
43 | 39 | |
44 | 40 | KEY_TURN_VALUE = 'Rodada.NúmeroDeJogadores'; // 3 |
45 | 41 | KEY_TURN_COUNT = 'Rodada.IniciarNaJogada'; // 1 |
... | ... | @@ -56,7 +52,14 @@ resourcestring |
56 | 52 | KEY_PROMPT_STYLE = 'Questão.Estilo'; // string |
57 | 53 | KEY_PROMPT_MESSAGE = 'Questão.Mensagem'; // string |
58 | 54 | |
59 | - KEY_ENDCRITERIA = '.Critério.DeFinalizaçãoDaCondição'; //2,50,10,30, | |
55 | + KEY_ENDCRITERIA = 'Critério.DeFinalizaçãoDaCondição'; //2,50,10,30, | |
56 | + | |
57 | + KEY_CONTINGENCY = 'Contingência.'; | |
58 | + KEY_METACONTINGENCY = 'Metacontingência.'; | |
59 | + | |
60 | + KEY_RESPONSE = '.RespostaEsperada'; // ROW,COLOR,OPCODE | |
61 | + KEY_CONSEQUE = '.Consequência'; // A,B,G,CSQCODE | |
62 | + KEY_CONSEQUE_MESSAGE = '.Consequência.Mensagem'; | |
60 | 63 | |
61 | 64 | VAL_RESEARCHER = 'Pesquisador'; |
62 | 65 | |
... | ... | @@ -93,6 +96,21 @@ const |
93 | 96 | 'Nicole','Luísa','Daniela','Núria','Bruna', |
94 | 97 | 'Victória','Alícia','Rafaela','Helena','Miriam'); |
95 | 98 | |
99 | + C_PLAYER_TEMPLATE : TPlayer = ( | |
100 | + ID : ''; | |
101 | + Nicname : ''; | |
102 | + Login :''; | |
103 | + Password : ''; | |
104 | + Status : gpsWaiting; | |
105 | + Data : nil; | |
106 | + Choice : ( | |
107 | + Current : (Row:grNone; Color:gcNone;); | |
108 | + Last : (Row:grNone; Color:gcNone;); | |
109 | + ); | |
110 | + Points : (A:0; B:0); | |
111 | + Turn : -1; | |
112 | + ); | |
113 | + | |
96 | 114 | //C_OPERANT_1 : TContingency = |
97 | 115 | // ( |
98 | 116 | // Consequence : ( |
... | ... | @@ -238,6 +256,7 @@ const |
238 | 256 | |
239 | 257 | C_CONDITION_TEMPLATE : TCondition = |
240 | 258 | ( |
259 | + ConditionName : ''; | |
241 | 260 | Contingencies : nil; |
242 | 261 | |
243 | 262 | Points : ( | ... | ... |
units/game_zmq_actors.pas
... | ... | @@ -12,21 +12,24 @@ uses |
12 | 12 | |
13 | 13 | type |
14 | 14 | |
15 | + // Everything sent is received by everybody connected. | |
16 | + | |
15 | 17 | { TZMQActor } |
16 | 18 | |
17 | 19 | TZMQActor = class(TComponent) |
18 | 20 | private |
21 | + FID: UTF8string; | |
19 | 22 | FSubscriber: TZMQPollThread; |
20 | 23 | FOnMessageReceived : TMessRecvProc; |
21 | - function GetActorID: UTF8string; virtual; | |
22 | 24 | protected |
23 | 25 | procedure MessageReceived(AMultipartMessage : TStringList); |
24 | 26 | public |
25 | 27 | constructor Create(AOwner : TComponent); override; |
26 | 28 | destructor Destroy; override; |
27 | 29 | procedure Start; virtual; |
30 | + procedure SetID(S:string); | |
28 | 31 | property OnMessageReceived : TMessRecvProc read FOnMessageReceived write FOnMessageReceived; |
29 | - property ID : UTF8string read GetActorID; | |
32 | + property ID : UTF8string read FID; | |
30 | 33 | end; |
31 | 34 | |
32 | 35 | { TZMQPlayer } |
... | ... | @@ -34,13 +37,11 @@ type |
34 | 37 | TZMQPlayer = class(TZMQActor) |
35 | 38 | private |
36 | 39 | FPusher : TZMQPusher; |
37 | - function GetActorID: UTF8string; override; | |
38 | 40 | public |
39 | 41 | constructor Create(AOwner : TComponent); override; |
40 | 42 | destructor Destroy; override; |
41 | 43 | procedure Start; override; |
42 | 44 | procedure SendMessage(AMessage : array of UTF8string); |
43 | - property ID : UTF8string read GetActorID; | |
44 | 45 | end; |
45 | 46 | |
46 | 47 | { TZMQAdmin } |
... | ... | @@ -100,11 +101,6 @@ begin |
100 | 101 | FPusher.SendMessage(AMessage); |
101 | 102 | end; |
102 | 103 | |
103 | -function TZMQPlayer.GetActorID: UTF8string; | |
104 | -begin | |
105 | - Result := FPusher.ID; | |
106 | -end; | |
107 | - | |
108 | 104 | constructor TZMQPlayer.Create(AOwner: TComponent); |
109 | 105 | begin |
110 | 106 | inherited Create(AOwner); |
... | ... | @@ -125,10 +121,9 @@ end; |
125 | 121 | |
126 | 122 | { TZMQActor } |
127 | 123 | |
128 | -function TZMQActor.GetActorID: UTF8string; | |
124 | +procedure TZMQActor.SetID(S: string); | |
129 | 125 | begin |
130 | - AbstractError; | |
131 | - Result := ''; | |
126 | + FID := S; | |
132 | 127 | end; |
133 | 128 | |
134 | 129 | procedure TZMQActor.MessageReceived(AMultipartMessage: TStringList); | ... | ... |
units/string_methods.pas
... | ... | @@ -5,7 +5,7 @@ unit string_methods; |
5 | 5 | interface |
6 | 6 | |
7 | 7 | uses |
8 | - Classes, SysUtils, LazFileUtils | |
8 | + Classes, SysUtils, Graphics, LazFileUtils | |
9 | 9 | , game_actors |
10 | 10 | , game_resources |
11 | 11 | ; |
... | ... | @@ -21,6 +21,7 @@ function GetConsequenceStyleFromString(s:string):TGameConsequenceStyle; |
21 | 21 | function GetConsequenceStyleString(AStyle: TGameConsequenceStyle): string; |
22 | 22 | function GetResponseString(ACriteria : TCriteria) : string; |
23 | 23 | function GetResponseFromString(S: string) : TCriteria; |
24 | +function GetRowColorString(C: TColor):string; | |
24 | 25 | |
25 | 26 | implementation |
26 | 27 | |
... | ... | @@ -207,6 +208,17 @@ begin |
207 | 208 | else Break; |
208 | 209 | end; |
209 | 210 | |
211 | +function GetRowColorString(C: TColor): string; | |
212 | +begin | |
213 | + case C of | |
214 | + ccYellow: Result := 'Y'; | |
215 | + ccBlue : Result := 'B'; | |
216 | + ccGreen: Result := 'G'; | |
217 | + ccRed: Result := 'R'; | |
218 | + ccMagenta: Result := 'M'; | |
219 | + end; | |
220 | +end; | |
221 | + | |
210 | 222 | //function ValidateString(S: String): string; |
211 | 223 | ////var |
212 | 224 | //// i:integer; | ... | ... |
units/zmq_network.pas
... | ... | @@ -14,7 +14,6 @@ unit zmq_network; |
14 | 14 | interface |
15 | 15 | |
16 | 16 | uses Classes, SysUtils, Process |
17 | - | |
18 | 17 | , zmqapi |
19 | 18 | //, zmq_client |
20 | 19 | ; |
... | ... | @@ -32,7 +31,6 @@ type |
32 | 31 | constructor Create; |
33 | 32 | destructor Destroy; override; |
34 | 33 | procedure SendMessage(AMultipartMessage : array of UTF8string); |
35 | - property ID : UTF8string read FID; | |
36 | 34 | end; |
37 | 35 | |
38 | 36 | { TZMQPubThread } |
... | ... | @@ -74,8 +72,6 @@ type |
74 | 72 | |
75 | 73 | implementation |
76 | 74 | |
77 | -uses zhelpers; | |
78 | - | |
79 | 75 | { TZMQSubscriber } |
80 | 76 | |
81 | 77 | procedure TZMQPollThread.MessageReceived; |
... | ... | @@ -140,7 +136,6 @@ end; |
140 | 136 | |
141 | 137 | constructor TZMQPusher.Create; |
142 | 138 | begin |
143 | - FID := s_random(20); | |
144 | 139 | FContext := TZMQContext.create; |
145 | 140 | FPusher := FContext.Socket( stPush ); |
146 | 141 | FPusher.connect('tcp://localhost:5057'); | ... | ... |