Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Programmieren allgemein (https://www.delphipraxis.net/40-programmieren-allgemein/)
-   -   Schiffe versenken "Kein gültiger Integerwert" (https://www.delphipraxis.net/174265-schiffe-versenken-kein-gueltiger-integerwert.html)

Mulgatree 12. Apr 2013 19:58

Schiffe versenken "Kein gültiger Integerwert"
 
Moinsen! Ich programmiere im Moment Schiffe versenken, um die einsamen Informatik-Schulstunden ein bisschen interessanter zu gestalten. Allerdings bin ich hierbei auf ein Problem gestoßen.
Ich bemale beim Starten des Programmes ein TImage mit einem Raster, auf dessen Grundlage anschließend das Spiel ablaufen soll. Um die ersten Grundlagen wie auf ein Feld schiessen schonmal zu haben hab ich mir diese Prozedur als erstes Vorgenommen.
Delphi-Quellcode:
procedure TForm1.b_schussClick(Sender: TObject);
var a, b: integer;
begin
a:=BBelegung(e_zbuch.Text);
b:=ZBelegung(StrToInt(e_zzahl.Text));
img_raster1.Canvas.FillRect(rect(a, b, (a+20), (b+20)));
end;
Delphi-Quellcode:
function TForm1.BBelegung(A:string): integer;
var Vergleich, Ascii, c, d: integer;
begin
d:=StrToInt(A);
c:=0;
Vergleich:=65;
Ascii:=ord(d);
while Vergleich <> Ascii do
  begin
    inc(c, 20);
    inc(Vergleich)
end;
result:=c;
end;
Um zu wissen, auf welche Stelle der Spieler schiesst, hab ich mir das System von TImage.canvas.fillrect genauer angeguckt und stütze mich hierbei auf ein selbst entwickeltes System. Grundsätzlich sollte dies auch funktionieren, allerdings bekomme ich immer, wenn ich in e_zbuch ein Buchstabe eingebe und die function ausführe die Fehlermeldung, dass "B kein gültiger Integerwert" sei und werde an die Stelle
Delphi-Quellcode:
a:=BBelegung(e_zbuch.Text);
verwiesen
Das die function einen integer erwartet und der e_zbuch.text vorher umgewandelt wird hab ich auch schon ausprobiert, das funktioniert genauso nicht.
Weiß jemand weiter?:?:

Volker Z. 12. Apr 2013 20:25

AW: Schiffe versenken "Kein gültiger Integerwert"
 
Hallo,

was glaubst Du kommt bei Deiner Zuweisung d := StrToInt(A); in der Methode BBelegung wohl raus, wenn Du den Buchstaben B im Parameter A übergibst?
Delphi-Quellcode:
d := StrToInt ('B'); // Geht nicht "B kein gültiger Integerwert"
d := StrToInt ('1'); // Geht schon

d := Ord ('B'); // Geht auch d = 66
d := Ord ('b'); // Geht auch d = 98
Gruß

s.h.a.r.k 12. Apr 2013 20:28

AW: Schiffe versenken "Kein gültiger Integerwert"
 
Naja, was glaubst du denn was StrToInt macht?! :wink:
Delphi-Quellcode:
var
  s : string;
  i : Integer;
begin
  s := '1';
  i := StrToInt(s); // Das hier funktioniert

  s := 'Delphi';
  i := StrToInt(s); // Das klappt nicht
end;

Mulgatree 12. Apr 2013 20:34

AW: Schiffe versenken "Kein gültiger Integerwert"
 
Danke für die Antworten, aber inwiefern muss ich ich das jetzt abändern? :D

p80286 12. Apr 2013 21:53

AW: Schiffe versenken "Kein gültiger Integerwert"
 
Gegenfrage, was willst Du eigentlich erreichen?
rein formal sollte dies funktionieren:
Delphi-Quellcode:
function TForm1.BBelegung(A:string): integer;
var Vergleich, Ascii, c, d: integer;
begin
  d:=StrToInt(A);
  c:=0;
  Vergleich:=65;
  Ascii:=d;
while Vergleich <> Ascii do
   begin
     inc(c, 20);
     inc(Vergleich)
end;
 result:=c;
end;
Gruß
K-H

Volker Z. 13. Apr 2013 00:10

AW: Schiffe versenken "Kein gültiger Integerwert"
 
Hallo,

vermutlich sollen in Dein TEdit e_zbuch die Buchstaben [A..J] eingegeben werden, im TEdit e_zzahl wohl die Ziffern [1..10].

Wenn dem so ist, dann könntest Du über den Objektinspektor die Eigenschaften
Code:
CharCase  | ecUpperCase
MaxLength | 1
für Dein TEdit e_zbuch setzen (was das bringt kannst Du in der OH nachlesen).

Den Rest eventuell so:
Delphi-Quellcode:
procedure TForm1.b_schussClick(Sender: TObject);
var
  a, b : integer;
begin
  a := BBelegung;
  b := ZBelegung;
  img_raster1.Canvas.FillRect(Rect(a, b, (a + 20), (b + 20)));
end;

function TForm1.BBelegung : Integer;
var
  s : string;
  c : Char;
begin
  s := Trim (e_zbuch.Text);
  if s = '' then
    raise Exception.Create ('Der Eingabewerte für e_zbuch darf nicht leer sein');
 
  c := s [1];
  if not (c in ['A'..'J']) then
    raise Exception.Create ('Als Eingabewerte für e_zbuch sind nur die Buchstaben A bis J erlaubt');

  Result := 20 * (Ord (c) - 65)
end;

function TForm1.ZBelegung : Integer;
begin
  if Trim (e_zzahl.Text) = '' then
    raise Exception.Create ('Der Eingabewerte für e_zzahl nicht leer sein');

  try
    Result := StrToInt (e_zzahl.Text);
    if (Result < 1) or (Result > 10) then
      raise Exception.Create ('Als Eingabewerte für e_zzahl sind nur die Zahlen 1 bis 10 erlaubt');

    Result := 20 * (Result - 1)
  except
    raise Exception.Create ('Als Eingabewerte für e_zzahl sind nur die Zahlen 1 bis 10 erlaubt')
  end
end;
Wenn Dir das mit dem werfen der Exceptions nicht gefällt, dann kannst Du natürlich auch einen negativen Wert zurückliefern und entsprechend in Deiner b_schussClick behandeln.

Gruß

Mulgatree 13. Apr 2013 10:14

AW: Schiffe versenken "Kein gültiger Integerwert"
 
Danke für die Antwort Volker Z.!
Funktioniert und habe ich direkt eingebaut! :)


Alle Zeitangaben in WEZ +1. Es ist jetzt 01:04 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-2025 by Thomas Breitkreuz