AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

Spiel des Lebens

Ein Thema von Stillmatic · begonnen am 7. Mai 2007 · letzter Beitrag vom 14. Mai 2007
Antwort Antwort
Seite 2 von 3     12 3      
Stillmatic

Registriert seit: 25. Apr 2007
110 Beiträge
 
#11

Re: Spiel des Lebens

  Alt 9. Mai 2007, 15:06
Bevor ich mich an die Rechnung der nächsten Generation mache muss ich zunächst einmal ein anderes problem lösen!!!

Bei unserem Programm kann man ja per Button das Spielfeld in der Höhe und Breite verändern!
Nun soll das StringGrid (Spielfeld) die Felder die Belegt sind aber ausserhalb des Spielfeldes liegen deaktiviert (also 'nicht besetzt') werden!
Z.B.

[ ] [ ] [ ] [ ] [ ]
[ ] [ ] [#] [ ] [ ]
[ ] [#] [ ] [#] [ ] ---> Sichtbarer bereich ( 5x5 )
[ ] [ ] [#] [ ] [ ]
[ ] [ ] [ ] [ ] [ ]

Und dann das Spielfeld verkleinert wird.....

[ ] [ ] [ ] [ ] [ ]
[ ] [ ] [#] [ ] [ ] ---> Sichtbarer bereich ( 5x3 )
[ ] [#] [ ] [#] [ ]

[ ] [ ] [#] [ ] [ ] ---------------------------
[ ] [ ] [ ] [ ] [ ] ---> Nicht Sichtbar


Wie könnte man das ganze umsetzen??
Das Programm ist in 4 Units aufgeteilt.
Eine für die Typen, eine für die Spielfeldvarianten,die HauptUnit mit dem Formular und dem StringGrid und eine Unit die die Spiellogik enthält( also das Array(boolean) ist dort deklariert)!
Wie könnte man das ganze Programmieren sodass, wenn in der Spiellogik Unit ein Feld belegt ist aber ausserhalb des Sichtbaren Bereiches des StringGrids liegt(HauptUnit) das Feld im Stringgrid nicht besetzt wird???
Hauptunit uses Spiellogik.
Spiellogik hat keinen Zugriff auf Hauptunit

Versteht ihr mein Problem??

*THX*
  Mit Zitat antworten Zitat
Stillmatic

Registriert seit: 25. Apr 2007
110 Beiträge
 
#12

Re: Spiel des Lebens

  Alt 9. Mai 2007, 20:51
Problem hat sich gelöst!!!!

So nun zur Berechnung der Nächsten Generation!
Wenn mann die ganze Rechnung mit den (x+1,x-1,y+1,y-1) aufbauen würde so hätten wir aber das Problem mit einem Feld das am Rand liegt bei dem es dann kein x+1 oder y+1 analog x-1 oder y-1 gibt, würde man ja ein Range Check Error bekommen da man Operationen ausserhalb des Arrays durchführen möchte!

Hätte einer von euch eine Lösung für diese Problem???

*THX*
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#13

Re: Spiel des Lebens

  Alt 10. Mai 2007, 10:10
Zitat von Stillmatic:
... so hätten wir aber das Problem mit einem Feld das am Rand liegt
Sag mal, hast du eigentlich gelesen (und verstanden), was ich oben geschrieben habe??
Thread-Beitrag #9 !
Andreas
  Mit Zitat antworten Zitat
Stillmatic

Registriert seit: 25. Apr 2007
110 Beiträge
 
#14

Re: Spiel des Lebens

  Alt 10. Mai 2007, 12:26
Ja den hab ich gelesen!
Sry hab vergessen zu erwähnen das wir ein springen eines Steines nicht Programmieren müssen!
Also die Steinchen springennicht vom Ende zum Anfang!
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#15

Re: Spiel des Lebens

  Alt 10. Mai 2007, 14:21
Zitat von Stillmatic:
Sry hab vergessen zu erwähnen das wir ein springen eines Steines nicht Programmieren müssen!
Also die Steinchen springennicht vom Ende zum Anfang!
Wikipedia ( http://de.wikipedia.org/wiki/Game_of_life#Das_Spielfeld ) sagt:
Zitat von Wikipedia:
Da ein reales Spielfeld immer einen Rand hat, muss das Verhalten dort festgelegt werden. Man kann sich den Rand z. B. durch tote Zellen belegt denken, so dass manche Gleiter ihre Bewegungsrichtung dort ändern. Eine andere Möglichkeit ist ein Torus-förmiges Spielfeld, bei dem alles, was das Spielfeld nach unten verlässt, oben wieder herauskommt und umgekehrt, und alles, was das Spielfeld nach links verlässt, rechts wieder herauskommt und umgekehrt.
Ich habe oben gezeigt, wie man ein Torus-förimiges Spielfeld baut.
Möchte man dies nicht, dann muss man doch nur in der Function FnkNachbarn prüfen, ob X und Y noch auf dem Spielfeld sind:
Delphi-Quellcode:
Function FnkNachbarn(i,j:integer):integer;
   function IstBelegt(x,y:integer):boolean;
   begin
      result := (x>=MIN_X) and (x<=MAX_X) and (y>=MIN_Y) and (y<=MAX_Y) and curGen[x,y];
   end;
var
   Nachbarn :integer;
Begin
Nachbarn:= 0;
  if IstBelegt(i,j+1) then //unten
     Nachbarn:= Nachbarn + 1;
  ...
Andreas
  Mit Zitat antworten Zitat
Stillmatic

Registriert seit: 25. Apr 2007
110 Beiträge
 
#16

Re: Spiel des Lebens

  Alt 10. Mai 2007, 21:39
Hi!!

Ich hab noch eine Frage zur genauen Berechnung der Nächsten Generation!
Wann passiert bei wievielen Nachbarn was??

Wir haben eine kleine case Anweisung geschrieben die aber irgendwie Fehlerhaft sein muss, kann da mal jemand rüber schauen??

Code:
for i := (low(UTypes.cMaxWidth)+1) to UTypes.cMaxWidth do
 Begin
  for j := (low(UTypes.cMaxHeight)+1) to UTypes.cMaxHeight do
   Begin
    FeldNachbarn := Nachbarn(i,j);
    case FeldNachbarn of
    0..1: curGen[i,j] := false;     //weniger als Zwei Nachbarn
       3: curGen[i,j] := true;      //Zelle mit drei Nachbarn --> NeuGeboren
       2: curGen[i,j] := curgen[i,j];// Nix tun
    4..8: curGen[i,j] := false;

    end;
   end;
 end;
*THX*
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#17

Re: Spiel des Lebens

  Alt 11. Mai 2007, 10:36
Deine Schleifenanfangswerte sind sehr suspekt: (low(UTypes.cMaxWidth)+1) sieht für mich falsch aus.
Du brauchst doch ZWEI Arrays: curGen[] und newGen[]. Ich sehr hier nur curGen[]. Das ist auf jeden Fall der Hauptfehler.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von TeronG
TeronG

Registriert seit: 19. Jul 2004
Ort: München
960 Beiträge
 
Delphi 2007 Professional
 
#18

Re: Spiel des Lebens

  Alt 11. Mai 2007, 10:41
Zitat von shmia:
Du brauchst doch ZWEI Arrays: curGen[] und newGen[]. Ich sehr hier nur curGen[]. Das ist auf jeden Fall der Hauptfehler.
Naja das 2te Array könnte sich ja hinterm 'Nachbarn(i,j)' verstecken.
龍 Der Unterschied zwischen Theorie und Praxis ist in der Praxis größer als in der Theorie.
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#19

Re: Spiel des Lebens

  Alt 11. Mai 2007, 11:01
Zitat von TeronG:
Zitat von shmia:
Du brauchst doch ZWEI Arrays: curGen[] und newGen[]. Ich sehr hier nur curGen[]. Das ist auf jeden Fall der Hauptfehler.
Naja das 2te Array könnte sich ja hinterm 'Nachbarn(i,j)' verstecken.
Schon möglich, dann wär's trotzdem aber noch falsch
Delphi-Quellcode:
       2: curGen[i,j] := curgen[i,j];// Nix tun
       // dann müsste es aber so sein
       2: curGen[i,j] := OldGen[i,j];// Lebewesen kopieren
Andreas
  Mit Zitat antworten Zitat
loetmann

Registriert seit: 22. Dez 2003
Ort: Rostock
33 Beiträge
 
Delphi 3 Standard
 
#20

Re: Spiel des Lebens

  Alt 11. Mai 2007, 13:39
Hallo,

meinst Du so was: http://www.a-d-k.de/game/games02/leben/leben.html
bei http://de.wikipedia.org/wiki/Conways_Spiel_des_Lebens ist das auch nochmal erklärt.

Ein Gruß
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 3     12 3      


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 13:41 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz