lazarus/lcl/include/winapi.inc

1350 lines
40 KiB
PHP

{%MainUnit ../lclintf.pp}
(******************************************************************************
All Winapi related stuff goes here.
This file is used by LCLIntf.pas
If a procedure is platform dependent then it should call:
WidgetSet.MyDependentProc
If a procedure insn't platform dependent, it is no part of InterfaseBase has
to be implementerd here
!! Keep this alphabetical !!
*****************************************************************************
* *
* This file is part of the Lazarus Component Library (LCL) *
* *
* See the file COPYING.LCL, included in this distribution, *
* for details about the copyright. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. *
* *
*****************************************************************************
******************************************************************************)
{******************************************************************************
These functions redirect to the platform specific interface object.
Note:
the section for not referring WidgetSet is at the end
******************************************************************************}
//##apiwiz##sps## // Do not remove
function Arc(DC: HDC; Left,Top,width,height,angle1,angle2 : Integer): Boolean;
begin
Result := WidgetSet.Arc(DC,Left,Top,width,height,angle1,angle2);
end;
function AngleChord(DC: HDC; x,y,width,height,angle1,angle2 : Integer): Boolean;
begin
Result := WidgetSet.AngleChord(DC,x,y,width,height,angle1,angle2);
end;
function BeginPaint(Handle: hWnd; Var PS : TPaintStruct) : hdc;
begin
Result := WidgetSet.BeginPaint(Handle,PS);
end;
function BitBlt(DestDC: HDC; X, Y, Width, Height: Integer; SrcDC: HDC; XSrc, YSrc: Integer; Rop: DWORD): Boolean;
begin
Result := WidgetSet.BitBlt(DestDC, X, Y, Width, Height, SrcDC, XSrc, YSrc, Rop);
end;
function CallNextHookEx(hhk : HHOOK; ncode : Integer; WParam: WParam; LParam: LParam) : Integer;
begin
Result := WidgetSet.CallNextHookEx(hhk, ncode, WParam, LParam);
end;
Function CallWindowProc(lpPrevWndFunc :TFarProc; Handle : HWND; Msg : UINT; WParam: WParam; LParam: LParam): Integer;
begin
Result := WidgetSet.CallWindowProc(lpPrevWndFunc, Handle, Msg, WParam, LParam);
end;
Function ClienttoScreen(Handle : HWND; var P : TPoint) : Boolean;
Begin
Result := WidgetSet.ClientToScreen(Handle, P);
end;
Function CombineRgn(Dest, Src1, Src2 : HRGN; fnCombineMode : Longint) : Longint;
begin
Result := WidgetSet.CombineRgn(Dest, Src1, Src2, fnCombineMode);
end;
function CreateBitmap(Width, Height: Integer; Planes, BitCount: Longint;
BitmapBits: Pointer): HBITMAP;
begin
Result := WidgetSet.CreateBitmap(Width, Height, Planes, BitCount,
BitmapBits);
end;
function CreateDIBitmap(DC: HDC; var InfoHeader: TBitmapInfoHeader;
dwUsage: DWORD; InitBits: PChar; var InitInfo: TBitmapInfo;
wUsage: UINT): HBITMAP;
begin
Result := WidgetSet.CreateDIBitmap(DC,InfoHeader,dwUsage,InitBits,
InitInfo,wUsage);
end;
function CreateDIBSection(DC: HDC; const BitmapInfo: tagBitmapInfo; Usage: UINT;
var Bits: Pointer; SectionHandle: THandle; Offset: DWORD): HBITMAP;
begin
Result := WidgetSet.CreateDIBSection(DC,BitmapInfo,Usage,
Bits,SectionHandle,Offset);
end;
function CreateBrushIndirect(const LogBrush: TLogBrush): HBRUSH;
begin
Result := WidgetSet.CreateBrushIndirect(LogBrush);
end;
Function CreateCaret(Handle : HWND; Bitmap : hBitmap; width, Height : Integer) : Boolean;
Begin
Result := WidgetSet.CreateCaret(Handle, Bitmap, width, Height);
end;
function CreateCompatibleBitmap(DC: HDC; Width, Height: Integer): HBITMAP;
begin
Result := WidgetSet.CreateCompatibleBitmap(DC, Width, Height);
end;
function CreateCompatibleDC(DC: HDC): HDC;
begin
Result := WidgetSet.CreateCompatibleDC(DC);
end;
function CreateFontIndirect(const LogFont: TLogFont): HFONT;
begin
Result := WidgetSet.CreateFontIndirect(LogFont);
end;
function CreateFontIndirectEx(const LogFont: TLogFont;
const LongFontName: string): HFONT;
begin
Result := WidgetSet.CreateFontIndirectEx(LogFont,LongFontName);
end;
function CreatePalette(const LogPalette: TLogPalette): HPalette;
begin
Result := WidgetSet.CreatePalette(LogPalette);
end;
function CreatePenIndirect(const LogPen: TLogPen): HPEN;
begin
Result := WidgetSet.CreatePenIndirect(LogPen);
end;
function CreatePolygonRgn(Points: PPoint; NumPts: Integer; FillMode: integer): HRGN;
Begin
Result := WidgetSet.CreatePolygonRgn(Points, NumPts, FillMode);
end;
function CreateRectRgn(X1,Y1,X2,Y2 : Integer): HRGN;
Begin
Result := WidgetSet.CreateRectRgn(X1,Y1,X2,Y2);
end;
Procedure DeleteCriticalSection(var CritSection: TCriticalSection);
begin
WidgetSet.DeleteCriticalSection(CritSection);
end;
function DeleteDC(hDC: HDC): Boolean;
begin
Result := WidgetSet.DeleteDC(hDC);
end;
function DeleteObject(GDIObject: HGDIOBJ): Boolean;
begin
Result := WidgetSet.DeleteObject(GDIObject);
end;
function DestroyCaret(Handle : HWND): Boolean;
Begin
Result := WidgetSet.DestroyCaret(Handle);
end;
Function DrawFrameControl(DC: HDC; var Rect : TRect; uType, uState : Cardinal) : Boolean;
Begin
Result := WidgetSet.DrawFrameControl(DC, Rect, uType, uState);
end;
function DrawEdge(DC: HDC; var Rect: TRect; edge: Cardinal; grfFlags: Cardinal): Boolean;
Begin
Result := WidgetSet.DrawEdge(DC, Rect, edge, grfFlags);
end;
function DrawText(DC: HDC; Str: PChar; Count: Integer; var Rect: TRect; Flags: Cardinal): Integer;
begin
Result := WidgetSet.DrawText(DC, Str, Count, Rect, Flags);
end;
function DPtoLP(DC: HDC; var Points; Count: Integer): BOOL;
begin
Result := WidgetSet.DPtoLP(DC,Points,Count);
end;
function EnableScrollBar(Wnd: HWND; wSBflags, wArrows: Cardinal): Boolean;
begin
Result := WidgetSet.EnableScrollBar(Wnd, wSBflags, wArrows);
end;
function EnableWindow(hWnd: HWND; bEnable: Boolean): Boolean;
begin
Result := WidgetSet.EnableWindow(hWnd, bEnable);
end;
Function EndPaint(Handle : hwnd; var PS : TPaintStruct): Integer;
Begin
Result:=WidgetSet.EndPaint(Handle,PS);
end;
procedure EnterCriticalSection(var CritSection: TCriticalSection);
begin
WidgetSet.EnterCriticalSection(CritSection);
end;
function EnumFontFamilies(DC: HDC; Family: Pchar;
EnumFontFamProc: FontEnumProc; LParam:Lparam):longint;
begin
Result := WidgetSet.EnumFontFamilies(DC, Family, EnumFontFamProc, LParam);
end;
function EnumFontFamiliesEx(DC: HDC; lpLogFont: PLogFont;
Callback: FontEnumExProc; LParam: Lparam; flags: dword): longint;
begin
Result := WidgetSet.EnumFontFamiliesEx(DC, lpLogFont, Callback, LParam, flags);
end;
function Ellipse(DC: HDC; x1,y1,x2,y2: Integer): Boolean;
begin
Result := WidgetSet.Ellipse(DC,x1,y1,x2,y2);
end;
function ExcludeClipRect(dc: hdc; Left, Top, Right, Bottom : Integer) : Integer;
begin
Result := WidgetSet.ExcludeClipRect(DC,Left,Top,Right,Bottom);
end;
function ExtTextOut(DC: HDC; X, Y: Integer; Options: Longint; Rect: PRect; Str: PChar; Count: Longint; Dx: PInteger): Boolean;
begin
Result := WidgetSet.ExtTextOut(DC, X, Y, Options, Rect, Str, Count, Dx);
end;
function ExtSelectClipRGN(dc: hdc; rgn : hrgn; Mode : Longint) : Integer;
begin
Result := WidgetSet.ExtSelectClipRGN(DC, RGN, Mode);
end;
function FillRect(DC: HDC; const Rect: TRect; Brush: HBRUSH): Boolean;
begin
Result := WidgetSet.FillRect(DC, Rect, Brush);
end;
function FillRgn(DC: HDC; RegionHnd: HRGN; hbr: HBRUSH): BOOL;
begin
Result := WidgetSet.FillRgn(DC,RegionHnd,hbr);
end;
function FloodFill(DC: HDC; X, Y: Integer;
Color: TGraphicsColor; FillStyle: TGraphicsFillStyle;
Brush: HBRUSH): Boolean;
begin
Result := WidgetSet.FloodFill(DC,X,Y,Color,FillStyle,Brush);
end;
function FrameRect(DC: HDC; const ARect: TRect; hBr: HBRUSH): Integer;
begin
Result:= WidgetSet.FrameRect(DC, ARect, hBr);
end;
Function GetActiveWindow : HWND;
begin
Result := WidgetSet.GetActiveWindow;
end;
function GetBitmapBits(Bitmap: HBITMAP; Count: Longint; Bits: Pointer): Longint;
begin
Result := WidgetSet.GetBitmapBits(Bitmap, Count, Bits);
end;
function GetCapture: HWND;
Begin
Result := WidgetSet.GetCapture;
end;
function GetCaretPos(var lpPoint: TPoint): Boolean;
begin
Result := WidgetSet.GetCaretPos(lpPoint);
end;
{------------------------------------------------------------------------------
Function: GetClientRect
Params: handle:
Result:
Returns: true on success
Returns the client rectangle of a control. Left and Top are always 0.
The client rectangle is the size of the inner area of a control, where the
child controls are visible.
A child control with Align=alClient will completely fill the clientrect.
------------------------------------------------------------------------------}
function GetClientRect(handle : HWND; var Rect : TRect) : Boolean;
begin
Result := WidgetSet.GetClientRect(handle, Rect);
end;
Function GetClipBox(DC : hDC; lpRect : PRect) : Longint;
begin
Result := WidgetSet.GetClipBox(DC, lpRect);
end;
Function GetClipRGN(DC : hDC; RGN : hRGN) : Longint;
begin
Result := WidgetSet.GetClipRGN(DC, RGN);
end;
Function GetCursorPos(var lpPoint:TPoint): Boolean;
Begin
Result := WidgetSet.GetCursorPos(lpPoint);
end;
function GetCharABCWidths(DC: HDC; p2, p3: UINT; const ABCStructs): Boolean;
begin
Result := WidgetSet.GetCharABCWidths(DC, p2, p3, ABCStructs);
end;
function GetDC(hWnd: HWND): HDC;
begin
Result := WidgetSet.GetDC(hWnd);
end;
function GetDIBits(DC: HDC; Bitmap: HBitmap; StartScan, NumScans: UINT;
Bits: Pointer; var BitInfo: BitmapInfo; Usage: UINT): Integer;
begin
Result := WidgetSet.GetDIBits(DC, Bitmap, StartScan, NumScans, Bits,
BitInfo, Usage);
end;
function GetDeviceCaps(DC: HDC; Index: Integer): Integer;
begin
Result := WidgetSet.GetDeviceCaps(DC, Index);
end;
function GetFocus: HWND;
begin
Result := WidgetSet.GetFocus;
end;
function GetFontLanguageInfo(DC: HDC): DWord;
begin
Result := WidgetSet.GetFontLanguageInfo(DC);
end;
function GetForegroundWindow: HWND;
begin
Result := WidgetSet.GetForegroundWindow;
end;
function GetKeyState(nVirtKey: Integer): Smallint;
begin
Result := WidgetSet.GetKeyState(nVirtKey);
end;
function GetMapMode(DC: HDC): Integer;
begin
Result := WidgetSet.GetMapMode(DC);
end;
function GetObject(GDIObject: HGDIOBJ; BufSize: Integer; Buf: Pointer): Integer;
begin
Result := WidgetSet.GetObject(GDIObject, BufSize, Buf);
end;
function GetPaletteEntries(Palette: HPALETTE; StartIndex, NumEntries: UINT;
var PaletteEntries): UINT;
begin
Result := WidgetSet.GetPaletteEntries(Palette,StartIndex,NumEntries,
PaletteEntries);
end;
Function GetParent(Handle : HWND): HWND;
begin
Result := WidgetSet.GetParent(Handle);
end;
Function GetProp(Handle : hwnd; Str : PChar): Pointer;
Begin
Result := WidgetSet.GetProp(Handle,Str);
end;
Function GetRGNBox(RGN : HRGN; lpRect : PRect) : Longint;
begin
Result := WidgetSet.GetRGNBox(RGN, lpRect);
end;
function GetROP2(DC: HDC): integer;
begin
result := WidgetSet.GetROP2(DC);
end;
function GetScrollInfo(Handle: HWND; SBStyle: Integer; var ScrollInfo: TScrollInfo): Boolean;
begin
Result := WidgetSet.GetScrollInfo(Handle, SBStyle, ScrollInfo);
end;
function GetStockObject(Value : Integer): Longint;
begin
Result := WidgetSet.GetStockObject(Value);
end;
function GetSysColor(nIndex: Integer): DWORD;
begin
Result := WidgetSet.GetSysColor(nIndex);
end;
function GetSystemMetrics(nIndex: Integer): Integer;
begin
Result := WidgetSet.GetSystemMetrics(nIndex);
end;
function GetSystemPaletteEntries(DC: HDC; StartIndex, NumEntries: UINT;
var PaletteEntries): UINT;
begin
Result := WidgetSet.GetSystemPaletteEntries(DC,StartIndex,NumEntries,
PaletteEntries);
end;
function GetTextColor(DC: HDC) : TColorRef;
begin
Result := WidgetSet.GetTextColor(DC);
end;
function GetTextExtentExPoint(DC: HDC; Str: PChar; Count, MaxWidth: Integer;
MaxCount, PartialWidths: PInteger; var Size: LCLType.TSize): Boolean;
begin
Result := WidgetSet.GetTextExtentExPoint(DC,Str,Count,MaxWidth,MaxCount,
PartialWidths,Size);
end;
function GetTextExtentPoint(DC: HDC; Str: PChar; Count: Integer;
var Size: LCLType.TSize): Boolean;
begin
Result := WidgetSet.GetTextExtentPoint(DC, Str, Count, Size);
end;
function GetTextExtentPoint32(DC: HDC; Str: PChar; Count: Integer;
var Size: LCLType.TSize): Boolean;
begin
Result := WidgetSet.GetTextExtentPoint32(DC, Str, Count, Size);
end;
function GetTextMetrics(DC: HDC; var TM: TTextMetric): Boolean;
begin
Result := WidgetSet.GetTextMetrics(DC, TM);
end;
function GetWindowLong(Handle : hwnd; int : Integer): PtrInt;
begin
Result := WidgetSet.GetWindowLong(Handle, int);
end;
{------------------------------------------------------------------------------
Function GetWindowRect(Handle : hwnd; var Rect : TRect): Integer;
After the call, ARect will be the control area in screen coordinates.
That means, Left and Top will be the screen coordinate of the TopLeft pixel
of the Handle object and Right and Bottom will be the screen coordinate of
the BottomRight pixel.
------------------------------------------------------------------------------}
Function GetWindowRect(Handle : hwnd; var Rect : TRect): Integer;
begin
Result := WidgetSet.GetWindowRect(Handle, Rect);
end;
{------------------------------------------------------------------------------
Function GetWindowSize(Handle: hwnd; var Width, Height: integer): boolean;
Returns the Width and Height
------------------------------------------------------------------------------}
Function GetWindowSize(Handle : hwnd; var Width, Height: integer): boolean;
begin
Result := WidgetSet.GetWindowSize(Handle, Width, Height);
end;
Function GetWindowOrgEx(dc : hdc; P : PPoint): Integer;
begin
Result := WidgetSet.GetWindowOrgEx(dc,P);
end;
function GradientFill(DC: HDC; Vertices: PTriVertex; NumVertices : Longint;
Meshes: Pointer; NumMeshes : Longint; Mode : Longint): Boolean;
begin
Result := WidgetSet.GradientFill(DC, Vertices, NumVertices, Meshes, NumMeshes, Mode);
end;
function HideCaret(hWnd: HWND): Boolean;
begin
Result := WidgetSet.HideCaret(hWnd);
end;
{------------------------------------------------------------------------------
Function: IntersectClipRect
Params: dc: hdc; Left, Top, Right, Bottom: Integer
Returns: Integer
Shrinks the current clipping region in the device context dc to the boundary
defined by Left, Top, Right, Bottom.
The result can be one of the following constants
Error
NullRegion
SimpleRegion
ComplexRegion
Region_Error
------------------------------------------------------------------------------}
function IntersectClipRect(dc: hdc; Left, Top, Right, Bottom: Integer): Integer;
Begin
Result := WidgetSet.IntersectClipRect(dc,Left,Top,Right,Bottom);
end;
Function InvalidateRect(aHandle : HWND; ARect : pRect; bErase : Boolean) : Boolean;
begin
Result := WidgetSet.InvalidateRect(aHandle, ARect, bErase);
end;
function IsDBCSLeadByte(TestChar: Byte): boolean;
begin
Result := WidgetSet.IsDBCSLeadByte(TestChar);
end;
function IsWindowEnabled(handle: HWND): boolean;
begin
Result := WidgetSet.IsWindowEnabled(Handle);
end;
function IsWindowVisible(handle: HWND): boolean;
begin
Result := WidgetSet.IsWindowVisible(Handle);
end;
procedure InitializeCriticalSection(var CritSection: TCriticalSection);
begin
WidgetSet.InitializeCriticalSection(CritSection);
end;
procedure LeaveCriticalSection(var CritSection: TCriticalSection);
begin
WidgetSet.LeaveCriticalSection(CritSection);
end;
function LineTo(DC: HDC; X, Y: Integer): Boolean;
begin
Result := WidgetSet.LineTo(DC, X, Y);
end;
function MaskBlt(DestDC: HDC; X, Y, Width, Height: Integer; SrcDC: HDC; XSrc, YSrc: Integer; Mask: HBITMAP; XMask, YMask: Integer): Boolean;
begin
Result := WidgetSet.MaskBlt(DestDC, X, Y, Width, Height, SrcDC, XSrc, YSrc, Mask, XMask, YMask);
end;
function MaskBlt(DestDC: HDC; X, Y, Width, Height: Integer; SrcDC: HDC; XSrc, YSrc: Integer; Mask: HBITMAP; XMask, YMask: Integer; Rop: DWORD): Boolean;
begin
Result := WidgetSet.MaskBlt(DestDC, X, Y, Width, Height, SrcDC, XSrc, YSrc, Mask, XMask, YMask, Rop);
end;
function MessageBox(hWnd: HWND; lpText, lpCaption: PChar; uType : Cardinal): integer;
begin
Result:= WidgetSet.MessageBox(hWnd, lpText, lpCaption, uType);
end;
function MoveToEx(DC: HDC; X, Y: Integer; OldPoint: PPoint): Boolean;
begin
Result := WidgetSet.MoveToEx(DC, X, Y, OldPoint);
end;
function PeekMessage(var lpMsg : TMsg; Handle : HWND;
wMsgFilterMin, wMsgFilterMax,wRemoveMsg : UINT): Boolean;
begin
Result := WidgetSet.PeekMessage(lpMsg,Handle,
wMsgFilterMin,wMsgFilterMax,wRemoveMsg);
end;
function Pie(DC: HDC; EllipseX1,EllipseY1,EllipseX2,EllipseY2,
StartX,StartY,EndX,EndY: Integer): Boolean;
begin
Result := WidgetSet.Pie(DC,EllipseX1,EllipseY1,EllipseX2,EllipseY2,
StartX,StartY,EndX,EndY);
end;
function PolyBezier(DC: HDC; Points: PPoint; NumPts: Integer;
Filled, Continuous: boolean): boolean;
begin
Result := WidgetSet.PolyBezier(DC,Points,NumPts,Filled,Continuous);
end;
function Polygon(DC: HDC; Points: PPoint; NumPts: Integer;
Winding: boolean): boolean;
begin
Result := WidgetSet.Polygon(DC,Points,NumPts,Winding);
end;
function Polyline(DC: HDC; Points: PPoint; NumPts: Integer): boolean;
begin
Result := WidgetSet.Polyline(DC,Points,NumPts);
end;
function PostMessage(Handle: HWND; Msg: Cardinal; WParam: WParam; LParam: LParam): Boolean;
begin
Result := WidgetSet.PostMessage(Handle, Msg, WParam, LParam);
end;
function PtInRegion(RGN: HRGN; X, Y: Integer) : Boolean;
begin
Result := WidgetSet.PtInRegion(RGN,X,Y);
end;
function RealizePalette(DC: HDC): Cardinal;
begin
Result := WidgetSet.RealizePalette(DC);
end;
function Rectangle(DC: HDC; X1, Y1, X2, Y2: Integer): Boolean;
begin
Result := WidgetSet.Rectangle(DC, X1, Y1, X2, Y2);
end;
function RectVisible(dc : hdc; const ARect: TRect) : Boolean;
begin
Result := WidgetSet.RectVisible(dc,ARect);
end;
function ReleaseCapture: Boolean;
begin
Result := WidgetSet.ReleaseCapture;
end;
function ReleaseDC(hWnd: HWND; DC: HDC): Integer;
begin
Result := WidgetSet.ReleaseDC(hWnd, DC);
end;
function RemoveProp(Handle: hwnd; Str: PChar): THandle;
begin
Result := WidgetSet.RemoveProp(Handle, Str);
end;
function RoundRect(DC : hDC; X1, Y1, X2, Y2: Integer; RX,RY : Integer): Boolean;
begin
Result := WidgetSet.RoundRect(DC, X1, Y1, X2, Y2, RX, RY);
end;
function RestoreDC(DC: HDC; SavedDC: Integer): Boolean;
begin
Result := WidgetSet.RestoreDC(DC, SavedDC)
end;
function SaveDC(DC: HDC) : Integer;
begin
Result := WidgetSet.SaveDC(DC)
end;
Function ScreenToClient(Handle : HWND; var P : TPoint) : Integer;
begin
Result := WidgetSet.ScreenToClient(Handle, P);
end;
function ScrollWindowEx(hWnd: HWND; dx, dy: Integer; prcScroll, prcClip: PRect; hrgnUpdate: HRGN; prcUpdate: PRect; flags: UINT): Boolean;
begin
Result := WidgetSet.ScrollWindowEx(hWnd, dx, dy, prcScroll, prcClip, hrgnUpdate, prcUpdate, flags);
end;
function SendMessage(HandleWnd: HWND; Msg: Cardinal; WParam: WParam; LParam: LParam): LResult;
begin
Result := WidgetSet.SendMessage(HandleWnd, Msg, WParam, LParam);
end;
function SetActiveWindow(Handle: HWND): HWND;
begin
Result := WidgetSet.SetActiveWindow(Handle);
end;
function SetBkColor(DC: HDC; Color: TColorRef): TColorRef; //pbd
begin
Result := WidgetSet.SetBkColor(DC, Color);
end;
Function SetBkMode(DC: HDC; bkMode : Integer) : Integer;
begin
Result := WidgetSet.SetBkMode(DC, bkMode);
end;
function SetCapture(AHandle: HWND): HWND;
begin
Result := WidgetSet.SetCapture(AHandle);
end;
function SetCaretPos(X, Y: Integer): Boolean;
begin
Result := WidgetSet.SetCaretPos(X, Y);
end;
function SetCaretPosEx(Handle: HWnd; X, Y: Integer): Boolean;
begin
Result := WidgetSet.SetCaretPosEx(Handle, X, Y);
end;
function SetCursor(hCursor: HICON): HCURSOR;
begin
Result := WidgetSet.SetCursor(hCursor);
end;
function SetCursorPos(X, Y: Integer): Boolean;
begin
Result := WidgetSet.SetCursorPos(X, Y);
end;
Function SetProp(Handle: hwnd; Str : PChar; Data : Pointer) : Boolean;
Begin
Result := WidgetSet.SetProp(Handle,Str,Data);
end;
function SetROP2(DC: HDC; Mode: Integer): Integer;
begin
Result := WidgetSet.SetRop2(Dc, Mode);
end;
Function SelectClipRGN(DC : hDC; RGN : HRGN) : Longint;
begin
Result := WidgetSet.SelectClipRGN(DC, RGN);
end;
function SelectObject(DC: HDC; GDIObj: HGDIOBJ): HGDIOBJ;
begin
Result := WidgetSet.SelectObject(DC, GDIObj);
end;
function SelectPalette(DC: HDC; Palette: HPALETTE; ForceBackground: Boolean): HPALETTE;
begin
Result := WidgetSet.SelectPalette(DC, Palette, ForceBackground);
end;
function SetFocus(hWnd: HWND): HWND;
begin
//DebugLn('[winapi.inc SetFocus] A');
Result := WidgetSet.SetFocus(hWnd);
//DebugLn('[winapi.inc SetFocus] END');
end;
function SetForegroundWindow(hWnd: HWND): boolean;
begin
Result := WidgetSet.SetForegroundWindow(hWnd);
end;
function SetMapMode(DC: HDC; MapMode: Integer): Integer;
begin
Result := WidgetSet.SetMapMode(DC,MapMode);
end;
function SetScrollInfo(Handle : HWND; SBStyle : Integer;
ScrollInfo: TScrollInfo; Redraw : Boolean): Integer;
begin
Result := WidgetSet.SetSCrollInfo(Handle, SBStyle, ScrollInfo, Redraw)
end;
function SetStretchBltMode(DC: HDC; StretchMode: Integer): Integer;
begin
Result := WidgetSet.SetStretchBltMode(DC,StretchMode);
end;
function SetSysColors(cElements: Integer; const lpaElements; const lpaRgbValues): Boolean;
begin
Result := WidgetSet.SetSysColors(cElements, lpaElements, lpaRgbValues);
end;
function SetTextAlign(DC: HDC; Flags: UINT): UINT;
begin
Result := WidgetSet.SetTextAlign(DC,Flags);
end;
Function SetTextCharacterExtra(_hdc : hdc; nCharExtra : Integer):Integer;
begin
Result := WidgetSet.SetTextCharacterExtra(_hdc, nCharExtra);
end;
function SetTextColor(DC: HDC; Color: TColorRef): TColorRef;
begin
Result := WidgetSet.SetTextColor(DC, Color);
end;
function SetWindowLong(Handle: HWND; Idx: Integer; NewLong : PtrInt): PtrInt;
begin
Result := WidgetSet.SetWindowLong(handle, Idx, NewLong);
end;
function SetWindowOrgEx(dc : hdc; NewX, NewY : Integer;
OldPoint: PPoint) : Boolean;
begin
Result := WidgetSet.SetWindowOrgEx(dc, NewX, NewY, OldPoint);
end;
function SetWindowPos(hWnd: HWND; hWndInsertAfter: HWND; X, Y, cx, cy: Integer; uFlags: UINT): Boolean;
begin
Result := WidgetSet.SetWindowPos(hWnd, hWndInsertAfter, X, Y, cx, cy, uFlags);
end;
function ShowCaret(hWnd: HWND): Boolean;
begin
Result := WidgetSet.ShowCaret(hWnd)
end;
function ShowScrollBar(Handle: HWND; wBar: Integer; bShow: Boolean): Boolean;
begin
Result := WidgetSet.ShowScrollBar(Handle, wBar, bShow);
end;
function ShowWindow(hWnd: HWND; nCmdShow: Integer): Boolean;
begin
Result := WidgetSet.ShowWindow(hWnd,nCmdShow);
end;
function StretchBlt(DestDC: HDC; X, Y, Width, Height: Integer;
SrcDC: HDC; XSrc, YSrc, SrcWidth, SrcHeight: Integer; Rop: Cardinal): Boolean;
begin
Result := WidgetSet.StretchBlt(DestDC, X, Y, Width, Height,
SrcDC, XSrc, YSrc, SrcWidth, SrcHeight, Rop);
end;
function StretchDIBits(DC: HDC; DestX, DestY, DestWidth, DestHeight, SrcX,
SrcY, SrcWidth, SrcHeight: Integer; Bits: Pointer; var BitsInfo: TBitmapInfo;
Usage: UINT; Rop: DWORD): Integer;
begin
Result := WidgetSet.StretchDIBits(DC,DestX,DestY,DestWidth,DestHeight,
SrcX,SrcY,SrcWidth,SrcHeight,Bits,BitsInfo,Usage,Rop);
end;
function TextOut(DC: HDC; X,Y : Integer; Str : Pchar; Count: Integer) : Boolean;
begin
Result := WidgetSet.TextOut(DC, X, Y, Str, Count);
end;
function UpdateWindow(Handle: HWND): Boolean;
begin
Result := WidgetSet.UpdateWindow(Handle);
end;
function VkKeyScan(AChar: Char): Short;
begin
Result := WidgetSet.VkKeyScan(AChar);
end;
function WindowFromPoint(Point : TPoint) : HWND;
begin
Result := WidgetSet.WindowFromPoint(Point);
end;
//##apiwiz##eps## // Do not remove
{******************************************************************************
Platform independent stuff
******************************************************************************}
//##apiwiz##spi## // Do not remove
{------------------------------------------------------------------------------
Function: AdjustWindowRectEx
Params:
Returns:
------------------------------------------------------------------------------}
function AdjustWindowRectEx( Var Rect: TRect; Style1: Word; MenuExist : Boolean;
Style2 : Word) : Boolean;
begin
// ToDo:
Result := true;
if MenuExist
then Rect.Top := Rect.Top + 25;
end;
{------------------------------------------------------------------------------
Function: CharLowerBuff
Params: pStr:
Len:
Returns:
------------------------------------------------------------------------------}
function CharLowerBuff(pStr : PChar; Len : Integer): Integer;
begin
// your code here
//TODO:WINAPI call CHARLOWERBUFF
DebugLn('TODO: WINAPI call CHARLOWERBUFF');
Result := -1;
end;
{------------------------------------------------------------------------------
Function: CopyRect pbd
Params:
Returns:
------------------------------------------------------------------------------}
function CopyRect(var DestRect: TRect; const SrcRect: TRect): Boolean;
begin
Move(SrcRect, DestRect, SizeOf(TRect));
Result := True;
end;
{------------------------------------------------------------------------------
function CreateEllipticRgnIndirect(const ARect: TRect): HRGN;
------------------------------------------------------------------------------}
function CreateEllipticRgn(p1, p2, p3, p4: Integer): HRGN;
begin
Result := WidgetSet.CreateEllipticRgn(p1,p2,p3,p4);
end;
{------------------------------------------------------------------------------
function CreateEllipticRgnIndirect(const ARect: TRect): HRGN;
------------------------------------------------------------------------------}
function CreateEllipticRgnIndirect(const ARect: TRect): HRGN;
begin
with ARect do
Result:=CreateEllipticRgn(Left,Top,Right,Bottom);
end;
{------------------------------------------------------------------------------
Function: CreateFont
Params:
Returns:
------------------------------------------------------------------------------}
function CreateFont(Height, Width, Escapement, Orientation, Weight: Integer;
Italic, Underline, StrikeOut, CharSet, OutputPrecision, ClipPrecision,
Quality, PitchAndFamily: Byte; FaceName: PChar): HFONT;
var
LogFont: TLogFont;
begin
DebugLn('CreateFont Name="',FaceName,'"');
FillChar(LogFont,SizeOf(LogFont),0);
with LogFont do
begin
lfHeight := Height;
lfWidth := Width;
lfEscapement := Escapement;
lfOrientation := Orientation;
lfWeight := Weight;
lfItalic := Italic;
lfUnderline := Underline;
lfStrikeOut := StrikeOut;
lfCharSet := CharSet;
lfOutPrecision := OutputPrecision;
lfClipPrecision := ClipPrecision;
lfQuality := Quality;
lfPitchAndFamily := PitchAndFamily;
StrLCopy(@lfFaceName, FaceName, SizeOf(lfFaceName)-1);
end;
Result := CreateFontIndirect(LogFont);
end;
{------------------------------------------------------------------------------
Function: CreatePen
Params:
Returns:
------------------------------------------------------------------------------}
function CreatePen(Style, Width: Integer; Color: TColorRef): HPEN;
var
LogPen: TLogPen;
begin
with LogPen do
begin
lopnStyle := Style;
lopnWidth.X := Width;
lopnColor := Color;
end;
Result := CreatePenIndirect(LogPen);
end;
{------------------------------------------------------------------------------
function CreateRectRgnIndirect(const ARect: TRect): HRGN;
-------------------------------------------------------------------------------}
function CreateRectRgnIndirect(const ARect: TRect): HRGN;
begin
with ARect do
Result:=CreateRectRgn(Left,Top,Right,Bottom);
end;
{------------------------------------------------------------------------------
Function: EqualRect
Params: Rect to Compare
Returns:
Quicker with a comparemem? whats the fpc equiv?
------------------------------------------------------------------------------}
function EqualRect(const lprc1, lprc2: TRect): Boolean;
begin
//Result := CompareMem(@lprc1, @lprc2, SizeOf(TRect);
Result := (lprc1.Left = lprc2.Left) And (lprc1.Right = lprc2.Right) And
(lprc1.Top = lprc2.Top) And (lprc1.Bottom = lprc2.Bottom);
end;
{------------------------------------------------------------------------------
Function: GetScrollPos
Params: Handle, nBar
Returns:
------------------------------------------------------------------------------}
function GetScrollPos(Handle: HWND; nBar: Integer): Integer;
var
Info: TScrollInfo;
begin
Info.fMask:=SIF_POS;
GetScrollInfo(Handle, nBar, Info);
Result := Info.nPos;
end;
function GetRValue(RGB : DWORD) : BYTE; inline;
begin
Result := RGB and $ff;
end;
function GetGValue(RGB : DWORD) : BYTE; inline;
begin
Result := (RGB shr 8) and $ff;
end;
function GetBValue(RGB : DWORD) : BYTE; inline;
begin
Result := (RGB shr 16) and $ff;
end;
procedure GetRGBValues(RGB : DWORD; var R, G, B: Byte); inline;
begin
R := RGB and $ff;
G := (RGB shr 8) and $ff;
B := (RGB shr 16) and $ff;
end;
procedure GetRGBIntValues(RGB : DWORD; var R, G, B: integer); inline;
begin
R := RGB and $ff;
G := (RGB shr 8) and $ff;
B := (RGB shr 16) and $ff;
end;
{------------------------------------------------------------------------------
Function: GetScrollRange
Params: Handle, nBar, lpMinPos, lpMaxPos
Returns:
------------------------------------------------------------------------------}
function GetScrollRange(Handle: HWND; nBar: Integer; var lpMinPos, lpMaxPos: Integer): Boolean;
var
Info: TScrollInfo;
begin
Info.fMask:=SIF_RANGE;
Result := GetScrollInfo(Handle, nBar, Info);
lpMinPos := Info.nMin;
lpMaxPos := Info.nMax;
end;
{------------------------------------------------------------------------------
Function: InflateRect
Params: ARect: points to structure that increases or decreases in size.
dx : amount to increase the rectangle width.
dy : amount to increase the rectangle height.
Returns: True if succesful
Increases or decreases the width and height of the specified rectangle.
------------------------------------------------------------------------------}
function InflateRect(var ARect: TRect; dx, dy: Integer): Boolean;
begin
// make sure, that after deflating holds: Left<=Right
if (dx<0) and (ARect.Right-ARect.Left+2*dx<0) then begin
ARect.Left:=(ARect.Left+ARect.Right) shr 1;
ARect.Right:=ARect.Left;
end else begin
dec(ARect.Left,dx);
inc(ARect.Right,dx);
end;
// make sure, that after deflating holds: Top<=Bottom
if (dy<0) and (ARect.Bottom-ARect.Top+2*dy<0) then begin
ARect.Top:=(ARect.Top+ARect.Bottom) shr 1;
ARect.Bottom:=ARect.Top;
end else begin
dec(ARect.Top,dy);
inc(ARect.Bottom,dy);
end;
Result := True;
end;
{------------------------------------------------------------------------------
Function: IntersectRect
Params: var DestRect: TRect; const SrcRect1, SrcRect2: TRect
Returns: Boolean
Intersects SrcRect1 and SrcRect2 into DestRect.
Intersecting means that DestRect will be the overlapping area of SrcRect1 and
SrcRect2. If SrcRect1 and SrcRect2 do not overlapp the Result is false, else
true.
------------------------------------------------------------------------------}
function IntersectRect(var DestRect: TRect;
const SrcRect1, SrcRect2: TRect): Boolean;
begin
Result := False;
// test if rectangles intersects
Result:=(SrcRect2.Left < SrcRect1.Right)
and (SrcRect2.Right > SrcRect1.Left)
and (SrcRect2.Top < SrcRect1.Bottom)
and (SrcRect2.Bottom > SrcRect1.Top);
if Result then begin
DestRect.Left:=Max(SrcRect1.Left,SrcRect2.Left);
DestRect.Top:=Max(SrcRect1.Top,SrcRect2.Top);
DestRect.Right:=Min(SrcRect1.Right,SrcRect2.Right);
DestRect.Bottom:=Min(SrcRect1.Bottom,SrcRect2.Bottom);
end else begin
SetRectEmpty(DestRect);
end;
end;
{------------------------------------------------------------------------------
Function: IsCharAlphaNumeric
Params: c:
Returns:
------------------------------------------------------------------------------}
Function IsCharAlphaNumeric(c : Char) : Boolean;
begin
// your code here
Result := c in ['a'..'z','A'..'Z','0'..'9'];
end;
{------------------------------------------------------------------------------
Function: IsRectEmpty
Params: const lprc: TRect
Returns: Boolean
Returns true if ARect is (0,0,0,0)
------------------------------------------------------------------------------}
function IsRectEmpty(const ARect: TRect): Boolean;
begin
with ARect do
Result := (Left = 0) and (Top = 0) and (Right = 0) and (Bottom = 0);
end;
{------------------------------------------------------------------------------
Function: MakeLParam
Params:
Returns:
------------------------------------------------------------------------------}
function MakeLParam(l, h: Word): LPARAM; inline;
begin
Result := MakeLong(l, h);
end;
{------------------------------------------------------------------------------
Function: MakeLResult
Params:
Returns:
------------------------------------------------------------------------------}
function MakeLResult(l, h: Word): LRESULT; inline;
begin
Result := MakeLong(l, h);
end;
{------------------------------------------------------------------------------
Function: MakeWParam
Params:
Returns:
------------------------------------------------------------------------------}
function MakeWParam(l, h: Word): WPARAM; inline;
begin
Result := MakeLong(l, h);
end;
{------------------------------------------------------------------------------
Function: OffSetRect
Params: Rect: points to structure that moves.
dx : amount to move the rect to left or right. Must be negative to move to left.
dy : amount to move the rect up or down. Mmust be negative to move up.
Returns: True if succesful
Moves the rectangle up or down, left or right.
------------------------------------------------------------------------------}
function OffSetRect(var Rect: TRect; dx,dy: Integer): Boolean; inline;
Begin
Result:=LCLProc.OffsetRect(Rect,dx,dy);
end;
{------------------------------------------------------------------------------
Function: PointtoSmallPoint
Params:
Returns:
------------------------------------------------------------------------------}
Function PointtoSmallPoint(const P : TPoint) : TSmallPoint; inline;
Begin
Result.X := P.X;
Result.Y := P.Y;
end;
{------------------------------------------------------------------------------
Function: PtInRect
Params: Rect
Point
Returns: True if point is in rect
Determines if the POINT is within the rect
It is considered inside if it lies on the left top, or within the rectangle.
It is outside ther rect if it's on the bottom or right.
------------------------------------------------------------------------------}
Function PtInRect(Rect : TRect; Point : TPoint) : Boolean; inline;
Begin
Result := ((Point.X >= Rect.Left) and
(Point.X < Rect.Right) and
(Point.Y >= Rect.Top) and
(Point.Y < Rect.Bottom)
);
end;
{------------------------------------------------------------------------------
Function: RGB
Params: R: Red color
G: Green Color
B: Blue Color
Returns: The return value is the resultant RGB color
The RGB macro selects a red, green, blue (RGB) color based on the arguments
supplied and the color capabilities of the output device.
------------------------------------------------------------------------------}
function RGB(R, G, B : Byte) : TColorRef; inline;
begin
Result := R or (G shl 8) or (B Shl 16);
end;
{------------------------------------------------------------------------------
Function: ScrollWindow In progress pbd
Params: Handle
XAmount +scroll down -scroll up
Rect: Rect to move
ClipRect: Boundaries at which the pixels go to /dev/nul
Returns: More than a simple boolean but for compatibilty bool will do
scrolls a window or portion of a window
------------------------------------------------------------------------------}
function ScrollWindow(hWnd: HWND; XAmount, YAmount: Integer;
Rect, ClipRect: PRect): Boolean; inline;
begin
Result := ScrollWindowEx(hWnd, XAmount, YAmount, Rect, ClipRect, 0, nil, 0);
end;
{------------------------------------------------------------------------------
Function: SetRect
Params:
Returns:
------------------------------------------------------------------------------}
Function SetRect(var ARect : TRect; xLeft,yTop,xRight,yBottom : Integer) : Boolean;
Begin
Result := True;
with ARect do begin
Left := xLeft;
Top := yTop;
Right := xRight;
Bottom := yBottom;
end;
End;
{------------------------------------------------------------------------------
Function: SetRectEmpty
Params: Rect to clear
Returns: essentially nothing
------------------------------------------------------------------------------}
function SetRectEmpty(var ARect: TRect): Boolean;
begin
FillChar(ARect, SizeOf(TRect), 0);
Result := True;
end;
{------------------------------------------------------------------------------
Function: SetScrollPos
Params: Handle, nBar, nPos, bRedraw
Returns: The old position
The SetScrollPos function sets the position of the scroll box (thumb) in the
specified scroll bar and, if requested, redraws the scroll bar to reflect
the new position of the scroll box.
------------------------------------------------------------------------------}
function SetScrollPos(Handle: HWND; nBar, nPos: Integer; bRedraw: Boolean): Integer;
var
Info: TScrollInfo;
begin
Info.fMask := SIF_POS;
Info.nPos := nPos;
Result := SetScrollInfo(Handle, nBar, Info, bRedraw);
end;
{------------------------------------------------------------------------------
Function: SetScrollRange
Params: Handle, nBar, nMinPos, nMaxPos, bRedraw
Returns: True is succesful
The SetScrollRange function sets the minimum and maximum position values
for the specified scroll bar.
------------------------------------------------------------------------------}
function SetScrollRange(Handle: HWND; nBar, nMinPos, nMaxPos: Integer; bRedraw: Boolean): Boolean;
var
Info: TScrollInfo;
begin
Info.fMask := SIF_RANGE;
Info.nMin := nMinPos;
Info.nMAx := nMaxPos;
SetScrollInfo(Handle, nBar, Info, bRedraw);
Result := True;
end;
{------------------------------------------------------------------------------
Function:
Params:
Returns:
------------------------------------------------------------------------------}
function SmallPointtoPoint(const P : TSmallPoint) : Tpoint;
Begin
Result.X := P.X;
Result.Y := P.Y;
end;
{------------------------------------------------------------------------------
Function: UnionRect pbd
Params: var DestRect: TRect; const SrcRect1, SrcRect2: TRect
Returns: Boolean 0 on failure
Creates the union rectangle of SrcRect1 and SrcRect2 into DestRect.
The union rectangle encloses SrcRect1 and SrcRect2.
------------------------------------------------------------------------------}
function UnionRect(var DestRect: TRect;
const SrcRect1, SrcRect2: TRect): Boolean;
begin
Result := True;
DestRect.Left := Min(SrcRect1.Left, SrcRect2.Left);
DestRect.Top := Min(SrcRect1.Top, SrcRect2.Top);
DestRect.Right := Max(SrcRect1.Right, SrcRect2.Right);
DestRect.Bottom := Max(SrcRect1.Bottom, SrcRect2.Bottom);
end;
//##apiwiz##epi## // Do not remove