AGB  ·  Datenschutz  ·  Impressum  







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

procedure Übergabefehler

Ein Thema von brandtson · begonnen am 18. Jun 2004 · letzter Beitrag vom 19. Jun 2004
Antwort Antwort
brandtson

Registriert seit: 27. Nov 2003
Ort: HH
23 Beiträge
 
Delphi 6 Professional
 
#1

Re: procedure Übergabefehler

  Alt 19. Jun 2004, 13:11
Hi Luckie,

ich hoffe dies hilft Licht ins Dunkle zu bringen.

Delphi-Quellcode:
procedure TestSingleBox ({ In: }
                         BoxIntensity: TRoiIntensity;
                         x1,y1,x2,y2: integer; Imageintensity: TImageintensity;
                         Bewegungsradius, Genauigkeit, Akt_Schicht, SliceChange: integer;
                         isrotation: boolean; alpha, alphamax: integer;
                         {In - Out}
                         var Drawstate: integer;
                         var BestSlice, BestX, BestY: TBestSLice;
                         var SliceRotationHits, SliceRotationHitsX,
                         SliceRotationHitsY: TImageintensity);
TRoiIntensity und TImageintensity sind beides zweidimensionale dynamische arrays. Übergeben wird der procedure folgendes:

Delphi-Quellcode:
          TestsingleBox(SingleBoxInt,
                        Drawbox.x1, Drawbox.y1, Drawbox.x2, Drawbox.y2, Nextimageintensities,
                        motionradius, accuracy, Slicechanger, strtoint(Schichtsprungedit.text),
                        checkboxalpha.checked, strtoint(editalpha.Text),
                        strtoint(editalphamax.Text),
                        Drawbox.drawstate,
                        BestSlice, BestX, BestY,
                        SliceRotationHits, SliceRotationHitsX, SliceRotationHitsY);
Die Variablen stimmen im typus vollkommen überein, es gibt keine exceptions und er meckert auch nicht beim compilieren! Wenn noch mehr code gebraucht wird einfach sagen, ich wusste jetzt nicht so, was da helfen könnte.

Hier noch mal die gesammte procedure und ich weiss, dass labels schlechter Stil sind.

Delphi-Quellcode:
var i,j,x,y: integer;
    TestRoiArray: TRoiIntensity;
    matches, Pixel: integer;
    BoxMatches: TMatching;
    x_res_vek, y_res_vek: integer;
    alphacounter : integer;
    RotateIntensity: Timageintensity;
    rotationcounter: integer;


label rotation;

begin

  Boxkoordinaten.x1 := x1;
  Boxkoordinaten.y1 := y1;
  Boxkoordinaten.x2 := x2;
  Boxkoordinaten.y2 := y2;


  matches := 0;
  Pixel := 0;
  x_res_vek := 0;
  y_res_vek := 0;
  rotationcounter := 0;
  alphacounter := alpha;

  setlength (TestRoiArray, length(Boxintensity));
  setlength (BoxMatches, (Bewegungsradius *2), (Bewegungsradius *2));
  setlength (rotateintensity, length(imageintensity), length(imageintensity));


  for x := 0 to measureForm.ezDICOMX.DCMimageWid -1 do begin
    for y := 0 to measureform.ezDICOMX.DCMimageHt -1 do begin
      rotateintensity[x,y] := imageintensity[x,y];
    end;
  end;


  rotation:

  for x := (-Bewegungsradius) to Bewegungsradius-1 do begin
    for y := (-Bewegungsradius) to Bewegungsradius-1 do begin

      for i := 0 to MeasureForm.ezDICOMX.DCMimageWid-1 do begin
        for j := 0 to Measureform.ezDICOMX.DCMimageHt-1 do begin

          if ((((i > (x1 + x)) and (i < (x2 + x))) and ((j > (y1 + y)) and (j < (y2 + y))))) then begin
            TestRoiArray[Pixel] := rotateintensity[i,j];
            inc(Pixel);
          end;
        end;
      end;

      IsEqualBoxValue(BoxIntensity, TestRoiArray,Genauigkeit, Pixel, Matches);
      Boxmatches[(x + Bewegungsradius), (y + Bewegungsradius)] := Matches;
      Pixel := 0;
      Matches := 0;

    end;
  end;

  BoxCoordinatesCheck(Boxmatches, Bewegungsradius, Akt_Schicht,SliceChange, x_res_vek, y_res_vek,
                      BestSlice, BestX, BestY);


  if isrotation then begin
    SlicerotationHits[akt_schicht + 1, rotationcounter] := Boxmatches[x_res_vek, y_res_vek];
    SlicerotationHitsX[akt_schicht + 1, rotationcounter] := (x_res_vek - Bewegungsradius);
    SlicerotationHitsY[akt_schicht + 1, rotationcounter] := (y_res_vek - Bewegungsradius);
  end;

  if isrotation then begin
    if alphacounter <= alphamax then begin
      rotatematrix(rotateintensity, imageintensity, alphacounter);
      alphacounter := alphacounter + alpha;
      rotationcounter := rotationcounter +1;
      goto rotation;
    end;
  end;

  Drawstate := 0;

end;
Danke fürs drüberschauen, ich hoffe ich mache nur einen ganz simplen Fehler, damit es wieder funktioniert.
  Mit Zitat antworten Zitat
Antwort Antwort


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 04:58 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