AGB  ·  Datenschutz  ·  Impressum  







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

Problem mit if

Ein Thema von Dr4ke · begonnen am 12. Mai 2007 · letzter Beitrag vom 12. Mai 2007
Antwort Antwort
Seite 1 von 2  1 2      
Dr4ke

Registriert seit: 12. Mai 2007
39 Beiträge
 
#1

Problem mit if

  Alt 12. Mai 2007, 20:03
Ich denke es ist ein if Befehl auf dem der Fehler liegt .. Ich poste mal den ganzen Code:

Delphi-Quellcode:
procedure TForm1.btnWuerfelnClick(Sender: TObject);
var
ergebnis,ergebnis2, addieren2, tmp, tmp2 : integer;
begin
  if Trim(edtAnzahl.Text) = 'then
tmp := 0
  else
tmp := StrToInt(edtAnzahl.Text);
  if Trim(edtAnzahlBot.Text) = 'then
tmp2 := 0
  else
tmp2 := StrToInt(edtAnzahlBot.Text);
Addieren;
ergebnis := tmp + Addieren;
addieren2 := random(6)+1;
ergebnis2 := tmp2 + addieren2 ;
edtAnzahl.Text := IntToStr(ergebnis);
edtAnzahlBot.Text := IntToStr(ergebnis2);
if StrToInt(edtAnzahl.Text) >= 21 then
ShowMessage('Du verlierst!');
NewGame;
if StrToInt(edtAnzahlBot.Text) >= 21 then
ShowMessage('Du gewinnst!');
NewGame;
if (StrToInt(edtAnzahl.Text) >= 21) and (StrToInt(edtAnzahlBot.Text) >= 21) then
ShowMessage('Draw!');
NewGame;
end;

function TForm1.Addieren : integer;
begin
Label1.Visible := False;
Addieren := random(6)+1;
end;


procedure TForm1.btnExitClick(Sender: TObject);
begin
Close;
end;

procedure TForm1.NeuesSpiel1Click(Sender: TObject);
begin
NewGame;
end;

procedure TForm1.Beenden1Click(Sender: TObject);
begin
Close;
end;

procedure TForm1.Info1Click(Sender: TObject);
begin
Application.MessageBox('Coded by Drake', 'Information', MB_OK + MB_ICONINFORMATION + MB_TASKMODAL);
end;


procedure TForm1.NewGame;
begin
edtAnzahlBot.Text:= '';
edtAnzahl.Text := '';
Label1.Visible := True;
end;

end.
Ein altbekannter Fehler: '' ist kein gültiger Integerwert.

Wenn ich nen BP auf den if setze kommt kein Fehler, aufm ShowMessage schon. Es geht um den mittleren if befehl.

Delphi-Quellcode:
if StrToInt(edtAnzahlBot.Text) >= 21 then
ShowMessage('Du gewinnst!');
NewGame;
  Mit Zitat antworten Zitat
Benutzerbild von inherited
inherited

Registriert seit: 19. Dez 2005
Ort: Rosdorf
2.022 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Problem mit if

  Alt 12. Mai 2007, 20:05

eigne dir erstmal eine vernünftige Codeformatierung an, sonst wird das eh nichts.
Desweiteren fehlen da diverse begin und end's bei den if-blöcken
Was dein Problem betrifft: Offensichtlich ist im Edit kiene Zahl eingetragen
Nikolai Wyderka

SWIM SWIM HUNGRY!
Neuer Blog: hier!
  Mit Zitat antworten Zitat
Blackheart

Registriert seit: 4. Mai 2005
846 Beiträge
 
Delphi 7 Enterprise
 
#3

Re: Problem mit if

  Alt 12. Mai 2007, 20:14
Wie inherited schon sagt es fehlen etliche begin end, Du löschst mit NewGame alle Einträge und versuchst dann etwas zu prüfen was nicht da ist.
Blackheart
  Mit Zitat antworten Zitat
Dr4ke

Registriert seit: 12. Mai 2007
39 Beiträge
 
#4

Re: Problem mit if

  Alt 12. Mai 2007, 21:12
Huch, da hab ich wohl was übersehen. :O

Sry, bin noch bloody beginner ;D
  Mit Zitat antworten Zitat
Dr4ke

Registriert seit: 12. Mai 2007
39 Beiträge
 
#5

Re: Problem mit if

  Alt 12. Mai 2007, 21:20
Hmm, ich bekomme zwar keine Fehlermeldung mehr, aber auch keine Zahlen mehr in dei Textfelder ...

Delphi-Quellcode:
procedure TForm1.btnWuerfelnClick(Sender: TObject);
var
ergebnis,ergebnis2, addieren2, tmp, tmp2 : integer;
begin
  if Trim(edtAnzahl.Text) = 'then
tmp := 0
  else
tmp := StrToInt(edtAnzahl.Text);
  if Trim(edtAnzahlBot.Text) = 'then
tmp2 := 0
  else
tmp2 := StrToInt(edtAnzahlBot.Text);
Addieren;
ergebnis := tmp + Addieren;
addieren2 := random(6)+1;
ergebnis2 := tmp2 + addieren2 ;
edtAnzahl.Text := IntToStr(ergebnis);
edtAnzahlBot.Text := IntToStr(ergebnis2);

if StrToInt(edtAnzahl.Text) >= 21 then
begin
ShowMessage('Du verlierst!');
NewGame;
end
else
if StrToInt(edtAnzahlBot.Text) >= 21 then
begin
ShowMessage('Du gewinnst!');
NewGame;
end
else
begin
if (StrToInt(edtAnzahl.Text) >= 21) and (StrToInt(edtAnzahlBot.Text) >= 21) then
ShowMessage('Draw!');
NewGame;
end;
end;

function TForm1.Addieren : integer;
begin
Label1.Visible := False;
Addieren := random(6)+1;
end;


procedure TForm1.btnExitClick(Sender: TObject);
begin
Close;
end;

procedure TForm1.NeuesSpiel1Click(Sender: TObject);
begin
NewGame;
end;

procedure TForm1.Beenden1Click(Sender: TObject);
begin
Close;
end;

procedure TForm1.Info1Click(Sender: TObject);
begin
Application.MessageBox('Coded by Drake', 'Information', MB_OK + MB_ICONINFORMATION + MB_TASKMODAL);
end;


procedure TForm1.NewGame;
begin
edtAnzahlBot.Text:= '';
edtAnzahl.Text := '';
Label1.Visible := True;
end;

end.
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.336 Beiträge
 
Delphi XE2 Professional
 
#6

Re: Problem mit if

  Alt 12. Mai 2007, 21:25
wundert dich das:

Delphi-Quellcode:
{...}
if StrToInt(edtAnzahlBot.Text) >= 21 then
begin
ShowMessage('Du gewinnst!');
NewGame;
end
else
begin
if (StrToInt(edtAnzahl.Text) >= 21) and (StrToInt(edtAnzahlBot.Text) >= 21) then
ShowMessage('Draw!');
NewGame;
end;
end;
Wenn man diesen Code liest (das aber sehr schwer ist) wird immer als letzte Anweisung "NewGame" ausgegeben.
Und dort leerst du deine Edits.

Ändere mal deine Formatierung!
Denn so hättest du es gesehen:

Delphi-Quellcode:
begin
{...}

if StrToInt(edtAnzahlBot.Text) >= 21 then
  begin
    ShowMessage('Du gewinnst!');
    NewGame;
  end
else
  begin
    if (StrToInt(edtAnzahl.Text) >= 21) and (StrToInt(edtAnzahlBot.Text) >= 21) then
      ShowMessage('Draw!');
    
    NewGame; //<--- Das wird immer ausgelöst, da die If-Abfrage drüber nicht für "NewGame" gilt (begin...end !!!)
  end;
end;
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Dr4ke

Registriert seit: 12. Mai 2007
39 Beiträge
 
#7

Re: Problem mit if

  Alt 12. Mai 2007, 21:34
Oh, du hast recht .. Kann mir da vll. jmd. ne Lösung geben? Ich komm nichtmehr ganz damit klar ;D
  Mit Zitat antworten Zitat
Benutzerbild von inherited
inherited

Registriert seit: 19. Dez 2005
Ort: Rosdorf
2.022 Beiträge
 
Turbo Delphi für Win32
 
#8

Re: Problem mit if

  Alt 12. Mai 2007, 21:35
Lösung: Formattier den Code mal ordentlich durch, dann passiert sowas nicht.
Nikolai Wyderka

SWIM SWIM HUNGRY!
Neuer Blog: hier!
  Mit Zitat antworten Zitat
Benutzerbild von Helmi
Helmi

Registriert seit: 29. Dez 2003
Ort: Erding, Republik Bayern
3.336 Beiträge
 
Delphi XE2 Professional
 
#9

Re: Problem mit if

  Alt 12. Mai 2007, 21:50
So, z. B., könnte so was aussehen.
Der Code würde auch funktionieren, wenn du ihn gegen deinen ersetzt.
Nur bin ich mir nicht sicher, welche Delphi-Version du verwendest - deswegen kann es sein, dass bei alten Versionen < 7 (oder schon < 6??) bei StrToIntDef Probleme bekommen könntest.

Schau dir einfach mal die Formatierung an und sag mir dann welche besser lesbar ist, deine oder meine.
Ach ja - es wird dir auffallen, dass Kommentare verwendet wurden - die sind nie verkehrt!

Delphi-Quellcode:
var
  ergebnis, ergebnis2, addieren2, tmp, tmp2 : integer;

begin
  //Variablen initialisieren
  tmp := 0;
  tmp2 := 0;

  if not (Trim(edtAnzahl.Text) = '') then
    tmp := StrToInt(edtAnzahl.Text);

  if not (Trim(edtAnzahlBot.Text) = '') then
    tmp2 := StrToInt(edtAnzahlBot.Text);

// Addieren; //<== unnötig, da es sich um eine function handelt
//Achtung: Bei Random im OnCreate der Form "Randomize" nicht vergessen!!

  //Berechnungen
  ergebnis := tmp + Addieren;
  addieren2 := random(6) + 1;
  ergebnis2 := tmp2 + addieren2;

  //Ausgabe
  edtAnzahl.Text := IntToStr(ergebnis);
  edtAnzahlBot.Text := IntToStr(ergebnis2);

  //Prüfungen
  tmp := StrToIntDef(edtAnzahl.Text, 0);
  tmp2 := StrToIntDef(edtAnzahlBot.Text, 0);
            //StrToIntDef geben bei einer Exception den Defaultwert zurück,
            //hier 0

  //"edtAnzahl" prüfen
  if tmp >= 21 then
    begin
      ShowMessage('Du verlierst!');
      NewGame;
    end
  else
    //"edtAnzahlBot" prüfen
    if tmp2 >= 21 then
      begin
        ShowMessage('Du gewinnst!');
        NewGame;
      end
    else
      //"editAnzahl" und "edtAnzahlBot" prüfen
      if (tmp >= 21) and (tmp2 >= 21) then
        begin
          ShowMessage('Draw!');
          NewGame;
        end;
mfg
Helmi

>> Theorie ist Wissen, dass nicht funktioniert - Praxis ist, wenn alles funktioniert und keiner weiss warum! <<
  Mit Zitat antworten Zitat
Dr4ke

Registriert seit: 12. Mai 2007
39 Beiträge
 
#10

Re: Problem mit if

  Alt 12. Mai 2007, 22:02
Zitat:
Schau dir einfach mal die Formatierung an und sag mir dann welche besser lesbar ist, deine oder meine.
Ich hoffe das war eine Rhetorikfrage.

Ja, dein Code funktioniert einwandfrei. Danke.

//EDIT: Da ich am blitzen eurer Augen sehe das ihr das Ergebnis unbedingt sehen wollt, könnt ihr sie im Anhang downloaden.
Angehängte Dateien
Dateityp: exe spiel_669.exe (402,5 KB, 4x aufgerufen)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 2  1 2      


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 05:50 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