was ist neu ¦  programmier tips ¦  indy artikel ¦  intraweb artikel ¦  informationen ¦  links ¦  interviews
 sonstiges ¦  tutorials ¦  Add&Win Gewinnspiel

Tips (1541)

Dateien (137)
Datenbanken (90)
Drucken (35)
Grafik (114)
IDE (21)
Indy (5)
Internet / LAN (130)
IntraWeb (0)
Mathematik (76)
Multimedia (45)
Oberfläche (107)
Objekte/
ActiveX (51)

OpenTools API (3)
Sonstiges (126)
Strings (83)
System (266)
VCL (242)

Tips sortiert nach
Komponente


Tip suchen

Tip hinzufügen

Add&Win Gewinnspiel

Werbung

29 Visitors Online


 
...eine Linie zeichnen, ohne die LineTo Funktion zu verwenden?
Autor: Peter Bone
Homepage: http://www.geocities.com/peter_bone_uk
[ Tip ausdrucken ]  

Tip Bewertung (28):  
     


{
  Enables you do draw a line if for some reason you
  cannot use the delphi LineTo procedure.
  For example, for drawing higher resolution lines
  or drawing lines in 2D arrays.
}

procedure DrawLine(APoint1, APoint2: TPoint; ACanvas: TCanvas);
var
  
Lpixel, LMaxAxisLength: integer;
  LRatio: Real;
begin
  
LMaxAxisLength := Max(abs(APoint1.X - APoint2.X), abs(APoint1.Y - APoint2.Y));
  for Lpixel := 0 to LMaxAxisLength do 
  begin
    
LRatio := Lpixel / LMaxAxisLength;
    ACanvas.Pixels[APoint1.X + Round((APoint2.X - APoint1.X) * LRatio),
      APoint1.Y + Round((APoint2.Y - APoint1.Y) * LRatio)] :=
      ACanvas.Pen.Color;
  end;
end;

// Draw a double resolution line
procedure DrawLineDouble(APoint1, APoint2: TPoint; ACanvas: TCanvas);
var
  
Lpixel, LMaxAxisLength: integer;
  LRatio: Real;
  LPoint: TPoint;
begin
  
LMaxAxisLength := max(abs(APoint1.X - APoint2.X), abs(APoint1.Y - APoint2.Y));
  for Lpixel := 0 to LMaxAxisLength do 
  begin
    
LRatio := Lpixel / LMaxAxisLength;
    LPoint.X := APoint1.X + Round((APoint2.X - APoint1.X) * LRatio);
    LPoint.Y := APoint1.Y + Round((APoint2.Y - APoint1.Y) * LRatio);
    with ACAnvas do 
    begin
      
Pixels[LPoint.X * 2, LPoint.Y * 2] := clBlack;
      Pixels[(LPoint.X * 2) + 1, LPoint.Y * 2] := clBlack;
      Pixels[LPoint.X * 2, (LPoint.Y * 2) + 1] := clBlack;
      Pixels[(LPoint.X * 2) + 1, (LPoint.Y * 2) + 1] := clBlack;
    end;
  end;
end;

 

Bewerten Sie diesen Tipp:

dürftig
ausgezeichnet


Copyright © by SwissDelphiCenter.ch
All trademarks are the sole property of their respective owners