summaryrefslogtreecommitdiff
path: root/src/corelib/x11
diff options
context:
space:
mode:
authorgraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-11-06 09:24:14 +0000
committergraemeg <graemeg@ae50a9b5-8222-0410-bf8d-8a13f76226bf>2007-11-06 09:24:14 +0000
commitd3d2a9b7658dd7f1c2521bad60c7b97af67bdfcf (patch)
tree039408a53d3a0e3f4d8d737c0c941ee803becd2c /src/corelib/x11
parent5bf8e89254b2316be9fb701825b16e45807e394a (diff)
downloadfpGUI-d3d2a9b7658dd7f1c2521bad60c7b97af67bdfcf.tar.xz
* Removed code duplication from the previous patch in X11 SetLineStyle.
Diffstat (limited to 'src/corelib/x11')
-rw-r--r--src/corelib/x11/gfx_x11.pas115
1 files changed, 37 insertions, 78 deletions
diff --git a/src/corelib/x11/gfx_x11.pas b/src/corelib/x11/gfx_x11.pas
index 97601011..014efc8b 100644
--- a/src/corelib/x11/gfx_x11.pas
+++ b/src/corelib/x11/gfx_x11.pas
@@ -80,8 +80,6 @@ type
end;
- { TfpgCanvasImpl }
-
TfpgCanvasImpl = class(TfpgCanvasBase)
private
FDrawing: boolean;
@@ -125,12 +123,9 @@ type
public
constructor Create; override;
destructor Destroy; override;
-
end;
- { TfpgWindowImpl }
-
TfpgWindowImpl = class(TfpgWindowBase)
protected
FWinFlags : TXWindowStateFlags;
@@ -213,15 +208,6 @@ var
LastWinClickTime: longword;
-//const
- // map X11 event types to custom event types
-// MSG_SCROLL = 65;
-// MSG_RESIZE = 66;
-// MSG_POPUPCLOSE = 67;
-// MSG_MOVE = 68;
-// MSG_DOUBLECLICK = 69;
-
-
// some externals
// defines:
@@ -1514,73 +1500,46 @@ const
var
aCapStyle: Longint;
begin
- if awidth < 0 then begin
+ aCapStyle := CapNotLast;
+ if awidth < 0 then
+ begin
{ Alternative line drawing - Using X algorithm instead of hardware algorithm }
awidth := -awidth;
- aCapStyle := CapNotLast;
- if (awidth > 1) and (astyle = lsSolid) then aCapStyle := CapButt;
- case AStyle of
- lsDot:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 1,
- LineOnOffDash, aCapStyle, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDot, 2);
- end;
- lsDash:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 1,
- LineOnOffDash, aCapStyle, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDash, 2);
- end;
- lsDashDot:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 1,
- LineOnOffDash, aCapStyle, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDashDot, 4);
- end;
- lsDashDotDot:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 1,
- LineOnOffDash, aCapStyle, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDashDotDot, 6);
- end;
- else // which includes lsSolid
- XSetLineAttributes(xapplication.display, Fgc, awidth,
- LineSolid, aCapStyle, JoinMiter);
- end; { case }
- end
- else begin
+ if (awidth > 1) and (astyle = lsSolid) then
+ aCapStyle := CapButt;
+ end
+ else
awidth := 0;
- case AStyle of
- lsDot:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 0,
- LineOnOffDash, CapNotLast, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDot, 2);
- end;
- lsDash:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 0,
- LineOnOffDash, CapNotLast, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDash, 2);
- end;
- lsDashDot:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 0,
- LineOnOffDash, CapNotLast, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDashDot, 4);
- end;
- lsDashDotDot:
- begin
- XSetLineAttributes(xapplication.display, Fgc, 0,
- LineOnOffDash, CapNotLast, JoinMiter);
- XSetDashes(xapplication.display, Fgc, 0, cDashDotDot, 6);
- end;
- else // which includes lsSolid
- XSetLineAttributes(xapplication.display, Fgc, awidth,
- LineSolid, CapNotLast, JoinMiter);
- end; { case }
- end; { awidth >= 0 }
+
+ case AStyle of
+ lsDot:
+ begin
+ XSetLineAttributes(xapplication.display, Fgc, 1,
+ LineOnOffDash, aCapStyle, JoinMiter);
+ XSetDashes(xapplication.display, Fgc, 0, cDot, 2);
+ end;
+ lsDash:
+ begin
+ XSetLineAttributes(xapplication.display, Fgc, 1,
+ LineOnOffDash, aCapStyle, JoinMiter);
+ XSetDashes(xapplication.display, Fgc, 0, cDash, 2);
+ end;
+ lsDashDot:
+ begin
+ XSetLineAttributes(xapplication.display, Fgc, 1,
+ LineOnOffDash, aCapStyle, JoinMiter);
+ XSetDashes(xapplication.display, Fgc, 0, cDashDot, 4);
+ end;
+ lsDashDotDot:
+ begin
+ XSetLineAttributes(xapplication.display, Fgc, 1,
+ LineOnOffDash, aCapStyle, JoinMiter);
+ XSetDashes(xapplication.display, Fgc, 0, cDashDotDot, 6);
+ end;
+ else // which includes lsSolid
+ XSetLineAttributes(xapplication.display, Fgc, awidth,
+ LineSolid, aCapStyle, JoinMiter);
+ end; { case }
end;
procedure TfpgCanvasImpl.DoDrawString(x, y: TfpgCoord; const txt: string);