Registriert seit: 8. Mai 2005
Ort: Sondershausen
4.274 Beiträge
Delphi 6 Personal
|
Doppelte Dreiecke in einem Array finden.... ?
20. Jun 2007, 11:55
Hi,
Ich bräuchte mal ne kleine Hilfe, es geht darum das ich Dreieckskoordinaten in einem
Array auffinden möchte.
Die Dreieckskoordinaten liegen wiefolgt vor:
Punkt 1: x1,y1,z1 Punkt 2: x2,y2,z2 Punkt 3: x3,y3,z3
Diese Koordinaten definieren in meinem Programm ein Dreieck in OpenGl. Leider sind die
Rohdaten so das es vorkommen kann das diese Dreiecke doppelt oder dreifach vorhanden
sein können. Diese möchte ich herausfiltern.
zB.:
Code:
ein vorhandenes Dreieck: Punkt 1: x1,y1,z1 Punkt 2: x2,y2,z2 Punkt 3: x3,y3,z3
ein doppeltes Dreieck: Punkt 1: x2,y2,z2 Punkt 2: x2,y2,z2 Punkt 3: x1,y1,z1
So werden die Daten aus einer Datei gelesen:
Delphi-Quellcode:
type
TVertex = array [0..2] of Single;
TFace = array [0..2] of TVertex;
T3DObject = array of TFace;
var
m3DObject: T3DObject;
FaceCount: Integer;
procedure TForm1.btnLoadFileClick(Sender: TObject);
var
F: TextFile;
begin
FaceCount := 0;
// ...
AssignFile(F, m3DOjectFileName);
{$I-}
reset(F);
if IOResult = 0 then
begin
while not eof(F) do
begin
inc(FaceCount);
SetLength(m3DObject, FaceCount + 1);
readln(F, m3DObject[FaceCount, 0, 0],
m3DObject[FaceCount, 0, 1],
m3DObject[FaceCount, 0, 2],
m3DObject[FaceCount, 1, 0],
m3DObject[FaceCount, 1, 1],
m3DObject[FaceCount, 1, 2],
m3DObject[FaceCount, 2, 0],
m3DObject[FaceCount, 2, 1],
m3DObject[FaceCount, 2, 2]);
if FaceCount mod 100 = 0 then
begin
Application.ProcessMessages;
DebugStrOut(TRUE, format('Read Line: %d', [FaceCount]), clGray);
end;
end;
end;
CloseFile(F);
{$I+}
// ...
end;
Und nun das Problemchen das finden der "Doppelganger":
Delphi-Quellcode:
procedure TForm1.btnChkOfDuplicateClick(Sender: TObject);
var
Find: TFace;
i, n: integer;
begin
DebugStrOut(TRUE, 'Begin Check of Duplicate', clGreen, [fsBold]);
for n:=0 to High(m3DObject) do
begin
Find := m3DObject[n];
for i:=0 to High(m3DObject) do
begin
if n <> i then
if (
(Find[0, 0] = m3DObject[i, 0, 0]) and
(Find[0, 1] = m3DObject[i, 0, 1]) and
(Find[0, 2] = m3DObject[i, 0, 2]) and
(Find[1, 0] = m3DObject[i, 1, 0]) and
(Find[1, 1] = m3DObject[i, 1, 1]) and
(Find[1, 2] = m3DObject[i, 1, 2]) and
(Find[2, 0] = m3DObject[i, 2, 0]) and
(Find[2, 1] = m3DObject[i, 2, 1]) and
(Find[2, 2] = m3DObject[i, 2, 2])
) or
(
(Find[0, 2] = m3DObject[i, 0, 0]) and
(Find[0, 1] = m3DObject[i, 0, 1]) and
(Find[0, 0] = m3DObject[i, 0, 2]) and
//...
) then
DebugStrOut(TRUE, '...found Duplicate @ ' + inttostr(i));
end;
end;
DebugStrOut(TRUE, 'DONE: Check of Duplicate.', clGreen, [fsBold]);
end;
gibt es eine Möglichkeit das ich mir das getippe der Folgenden Möglichkeiten erspare ?
|