The base unit and starting point of fpGUI

This unit contains all the abstract classes for the CoreLib code of fpGUI. It also defines many types and constants used throughout the toolkit.

When implementing support for a completely new windowing system (eg: Carbon used in Mac OS-X) you would implement all the abstract methods defined in this unit.

A custom type used to represent X and Y coordinates. Internally TfpgCoord is actually a Integer type. We created a custom alias type for use in fpGUI in the event that we might want to change the underlying type in the future. Example to floating points. Represents a color in integer format.

TfpgColor is always in RRGGBB (Red, Green, Blue) format, no matter the operating system.

The gfxbase unit also contains definitions of many useful color constants. It defines the standard predefined Delphi colors (like clRed, clMagenta etc.), the 140 websafe colors using the defacto standard names as used by Netscape and Internet Explorer web browsers. As well as some internal color constants used by many GUI components (like clText, clWindowBackground etc.).

A record structure holding the RGBA values of a color. Alpha support has not really been implemented in fpGUI yet. Enum type defining what types of windows can be created. The window being created is a child on another window. This normally means no titlebar or window borders are going to be created. This would specify a standard window with titlebar and window borders. This windows is the same as wtWindow, but grabs the input focus until it has closed. This window will normally not have a titlebar or window borders and will appear above other windows. It is used for example in the dropdown window of a ComboBox or a tooltip window. An enum types defining extra attributes of a window. If this attribute is set, the window will be resizeable by the user. If this attribute is set, the underlying window manager will decide where the window will be placed on the screen it it becomes visible for the first time. If this attribute is set, the window will be centred on the screen when it is shown for the first time. A set of TWindowAttribute types. Enum types of the available mouse cursor shapes. Normally the default arrow cursor. Normally a hourglass or watch representing a busy state. Enum types defining how a gradient must be painted Defines that the gradient must be painted vertically. Defines that the gradient must be painted horizontally. Represents the clipboard function being triggered by some keyboard key combination. Constant representing the left mouse button. Constant representing the right mouse button. Constant representing the middle mouse button. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. Platform independent messages used by fpGUI. A rectangle structure used throughout fpGUI. Note that this structure is not a class, so static allocations are allowed. This makes it much easier to use in Widgets and in fpGUI internal messages. A convenience function to quickly set a rectangle structure. Calculates and returns the bottom position of the rectangle. Calculates and returns the Right most position of the rectangle. Sets the bottom value and recalculates the Height value. Sets the Right value and recalculates the Width value. Abstract class use for representing a Window or Widget fpGUI is a Windowed toolkit. By that we mean that every component or widget has a window handle. Widgets are essentially embedded windows without titlebars or borders inside a main parent window. Abstract class used to represent a Canvas for painting Abstract class used to represent a Image Encapsulates the resources of a font A abstract class representing a base Interpolation filter. This is used as the base class to implement Interpolation filters like Gaussian, Sinc etc... These decendant filters are used in the Canvas.StretchDraw function. Canvas.StretchDraw Draws a rectangle. You can specify the size of the rectangle via X, Y, Width and Height parameters or via a TfpgRect parameter. Draws a line . This method draws a line from (x1,y1) to (x2,y2), but does not draw the last pixel. All supported backends follow the Microsoft API and doesn't draw the last pixel. This optimises consecutive lines being drawn without overlapping pixels. Returns the text representation of a keycode. This is mainly used for debugging, but could also be used for Menu Item keyboard shortcuts etc. Detects if the pressed keys represent a Clipboard key shortcut Detects if the pressed keys represent a Clipboard key shortcut. If it does, it returns the correct enum type detected. Converts the TfpgColor to TRGBTriple type This function converts the given TfpgColor into a TRGBTriple type. Converts the TRGBTriple to TfpgColor type This function converts the given TRGBTriple into a TfpgColor type. Returns the Red portion of a color value. Returns the Green portion of a color value. Returns the Blue portion of a color value. Returns the Alpha portion of a color value. Calculates the average color using the two supplied This function calculates and returns the average color by using AColor1 and AColor2. The Alpha value also gets taken into account. Returns true if APoint is inside ARect rectangle This function is used to detect if the point APoint is inside the given rectangle ARect. If it is, the function returns True, otherwise False. Fixes the Top, Bottom and Left, Right to always represent a valid rectangle This function fixes a rectangle so that the Left point is always smaller than the Right. And the Top is always smaller than the Bottom. Draws a line inside a clip rectangle

. This procedure clips a line to the AClipRect boundaries and then calls the DrawLine procedure with the clipped coordinates. If the line lies completely outside of the clip boundary, then the Line routine is not called. This procedure uses the well known Cohen-Sutherland line clipping algorithm to clip each coordinate.

Use this if you did not what to change the Canvas.ClipRegion for some reason. For a detailed explanation see: http://www.nondot.org/~sabre/graphpro/line6.html

Clips the line based on AClipRect boundaries. This does not do any drawing, in only clips the line coordinates. This method is used internally by .