Skip to content

Commit

Permalink
Added changes from Lazarus 3.0
Browse files Browse the repository at this point in the history
  • Loading branch information
salvadorbs committed Jan 10, 2025
1 parent 6dc90cf commit b3eae92
Show file tree
Hide file tree
Showing 33 changed files with 301 additions and 1,219 deletions.
13 changes: 9 additions & 4 deletions Demos/Minimal/Main.lfm
Original file line number Diff line number Diff line change
Expand Up @@ -28,23 +28,28 @@ object MainForm: TMainForm
Colors.HotColor = clBlack
DefaultText = 'Node'
Header.AutoSizeIndex = -1
Header.Columns = <>
Header.DefaultHeight = 17
Header.Font.Height = -11
Header.Font.Name = 'MS Sans Serif'
Header.MainColumn = -1
Header.Options = [hoColumnResize, hoDrag]
Header.Options = [hoColumnResize, hoDrag, hoShowSortGlyphs, hoVisible]
HintAnimation = hatNone
IncrementalSearch = isAll
RootNodeCount = 100
TabOrder = 0
TreeOptions.AnimationOptions = [toAnimatedToggle]
TreeOptions.AutoOptions = [toAutoDropExpand, toAutoTristateTracking]
TreeOptions.MiscOptions = [toEditable, toInitOnSave, toToggleOnDblClick, toWheelPanning]
TreeOptions.PaintOptions = [toShowButtons, toShowRoot, toShowTreeLines, toThemeAware, toUseBlendedImages]
TreeOptions.SelectionOptions = [toMultiSelect, toCenterScrollIntoView]
TreeOptions.SelectionOptions = [toMultiSelect]
OnFreeNode = VSTFreeNode
OnGetText = VSTGetText
OnInitNode = VSTInitNode
Columns = <
item
Position = 0
Width = 300
WideText = 'Name'
end>
end
object ClearButton: TButton
Left = 97
Expand Down
15 changes: 13 additions & 2 deletions Demos/dragdrop/fmain.lfm
Original file line number Diff line number Diff line change
Expand Up @@ -17,9 +17,7 @@ object MainForm: TMainForm
DragMode = dmAutomatic
DragType = dtVCL
Header.AutoSizeIndex = 0
Header.Columns = <>
Header.DefaultHeight = 17
Header.MainColumn = -1
RootNodeCount = 30
TabOrder = 0
TreeOptions.AutoOptions = [toAutoDropExpand, toAutoScroll, toAutoScrollOnExpand, toAutoTristateTracking, toAutoDeleteMovedNodes]
Expand All @@ -29,6 +27,19 @@ object MainForm: TMainForm
OnGetText = VirtualStringTree1GetText
OnGetNodeDataSize = VirtualStringTree1GetNodeDataSize
OnInitNode = VirtualStringTree1InitNode
Columns = <
item
Position = 0
Spacing = 4
Text = 'te1'
Width = 63
end
item
Position = 1
Spacing = 4
Text = 'te2'
Width = 63
end>
end
object ListBox1: TListBox
Left = 248
Expand Down
3 changes: 2 additions & 1 deletion Source/VTConfig.inc
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,8 @@
{$ifdef Windows}
{$define EnableThreadSupport}
{$endif}
{$if defined(CPU64) or defined(LCLCarbon)}

{$if not (defined(CPU386) or Defined(CPUX64))}
{$define PACKARRAYPASCAL}
{$endif}

Expand Down
162 changes: 119 additions & 43 deletions Source/VirtualTrees.BaseTree.pas

Large diffs are not rendered by default.

6 changes: 3 additions & 3 deletions Source/VirtualTrees.DataObject.pas
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ interface
{$I VTConfig.inc}

uses
Classes, Controls, Graphics, LCLType, SysUtils, Types,
Classes, Controls, Graphics, LCLType, SysUtils, Types, WSReferences,
{$ifdef Windows}
ActiveX,
JwaWinBase,
Expand Down Expand Up @@ -39,7 +39,7 @@ TVTDataObject = class(TInterfacedObject, IDataObject)
function EqualFormatEtc(FormatEtc1, FormatEtc2 : TFormatEtc) : Boolean;
function FindFormatEtc(TestFormatEtc : TFormatEtc; const FormatEtcArray : TFormatEtcArray) : Integer;
function FindInternalStgMedium(Format : TClipFormat) : PStgMedium;
function HGlobalClone(HGlobal : THandle) : THandle;
function HGlobalClone(HGlobal : TLCLHandle) : TLCLHandle;
function RenderInternalOLEData(const FormatEtcIn : TFormatEtc; var Medium : TStgMedium; var OLEResult : HResult) : Boolean;
function StgMediumIncRef(const InStgMedium : TStgMedium; var OutStgMedium : TStgMedium; CopyInMedium : Boolean; const DataObject : IDataObject) : HResult;

Expand Down Expand Up @@ -195,7 +195,7 @@ function TVTDataObject.FindInternalStgMedium(Format : TClipFormat) : PStgMedium;

//----------------------------------------------------------------------------------------------------------------------

function TVTDataObject.HGlobalClone(HGlobal : THandle) : THandle;
function TVTDataObject.HGlobalClone(HGlobal : TLCLHandle) : TLCLHandle;
// Returns a global memory block that is a copy of the passed memory block.
{$IFDEF EnableWinDataObject}
var
Expand Down
4 changes: 2 additions & 2 deletions Source/VirtualTrees.EditLink.pas
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ interface
{$I VTConfig.inc}

uses
Classes, Controls, StdCtrls, LMessages, VirtualTrees.Types, VirtualTrees.BaseTree, VirtualTrees,
Classes, Controls, StdCtrls, LMessages, VirtualTrees.Types, VirtualTrees.BaseTree, VirtualTrees, WSReferences,
LCLType, LCLIntf, Types;

type
Expand Down Expand Up @@ -503,7 +503,7 @@ procedure TVTEdit.CreateParams(var Params : TCreateParams);
function TVTEdit.GetTextSize : TSize;
var
DC : HDC;
LastFont : THandle;
LastFont : TLCLHandle;
begin
DC := GetDC(Handle);
LastFont := SelectObject(DC, Font.Handle);
Expand Down
59 changes: 44 additions & 15 deletions Source/VirtualTrees.Header.pas
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,10 @@ interface
{$I VTConfig.inc}

uses
{$ifdef LCLCocoa}
MacOSAll, // hack: low-level access to Cocoa drawins is going to be used
// in order to support Cocoa HighDPI implementation
{$endif}
LMessages, LCLIntf, LCLType, Controls, Classes, StdCtrls, Themes, Graphics,
{$ifdef Windows}
Windows,
Expand All @@ -25,7 +29,13 @@ interface
, ImgList
, Menus
, LCLVersion
, Types;
, Types
{$ifdef LCLCocoa}
,CocoaGDIObjects // hack: while using buffered drawing, multiply the context
// by the retina scale to achieve the needed scale for Retina
// Ideally - not to use Buffered. but Unbuffered drawing
// seems to need a fix
{$endif};

const
DefaultColumnOptions = [coAllowClick, coDraggable, coEnabled, coParentColor, coParentBidiMode, coResizable,
Expand Down Expand Up @@ -411,9 +421,7 @@ TVTHeader = class(TPersistent)
procedure RescaleHeader;
procedure UpdateMainColumn;
procedure UpdateSpringColumns;
{$IFDEF DelphiSupport}
procedure WriteColumns(Writer : TWriter);
{$ENDIF}
procedure InternalSetMainColumn(const Index : TColumnIndex);
procedure InternalSetAutoSizeIndex(const Index : TColumnIndex);
procedure InternalSetSortColumn(const Index : TColumnIndex);
Expand Down Expand Up @@ -1545,7 +1553,7 @@ function TVTHeader.HandleMessage(var Message: TLMessage): Boolean;
P : TPoint;
I : TColumnIndex;
HitIndex : TColumnIndex;
NewCursor : TVTCursor;
NewCursor : TCursor;
Button : TMouseButton;
IsInHeader, IsHSplitterHit, IsVSplitterHit : Boolean;

Expand Down Expand Up @@ -1913,13 +1921,14 @@ function TVTHeader.HandleMessage(var Message: TLMessage): Boolean;
else
IsVSplitterHit := InHeaderSplitterArea(P) and Self.CanSplitterResize(P);

//lcl: in lazarus we must use TCursor
if IsVSplitterHit or IsHSplitterHit then
begin
NewCursor := Screen.Cursors[Tree.Cursor];
NewCursor := Tree.Cursor;
if IsVSplitterHit and ((hoHeightResize in FOptions) or (csDesigning in Tree.ComponentState)) then
NewCursor := Screen.Cursors[crVSplit]
NewCursor := crVSplit
else if IsHSplitterHit then
NewCursor := Screen.Cursors[crHSplit];
NewCursor := crHSplit;

if not (csDesigning in Tree.ComponentState) then
Tree.DoGetHeaderCursor(NewCursor);
Expand Down Expand Up @@ -2269,7 +2278,6 @@ procedure TVTHeader.UpdateSpringColumns;

//----------------------------------------------------------------------------------------------------------------------

{$IFDEF DelphiSupport}
type
//--- HACK WARNING!
//This type cast is a partial rewrite of the private section of TWriter. The purpose is to have access to
Expand Down Expand Up @@ -2308,7 +2316,6 @@ procedure TVTHeader.WriteColumns(Writer : TWriter);
TWriterHack(Writer).FPropPath := LastPropPath;
end;
end;
{$ENDIF}

//----------------------------------------------------------------------------------------------------------------------

Expand Down Expand Up @@ -2580,7 +2587,7 @@ procedure TVTHeader.LoadFromStream(const Stream : TStream);

var
Dummy, Version : Integer;
S : AnsiString;
S : AnsiString = '';
OldOptions : TVTHeaderOptions;

begin
Expand Down Expand Up @@ -2685,7 +2692,8 @@ function TVTHeader.ResizeColumns(ChangeBy : TDimension; RangeStartCol : TColumnI
ColCount,
Sign: Integer;
ToGo, MaxDelta, Difference, Rest: TDimension;
Constraints, Widths : array of TDimension;
Constraints : array of TDimension = nil;
Widths : array of TDimension = nil;
BonusPixel : Boolean;

//--------------- local functions -------------------------------------------
Expand Down Expand Up @@ -4155,7 +4163,7 @@ function TVirtualTreeColumn.GetText : string;
procedure TVirtualTreeColumn.LoadFromStream(const Stream : TStream; Version : Integer);
var
Dummy : Integer;
S : string;
S : string = '';

begin
with Stream do
Expand Down Expand Up @@ -5527,6 +5535,7 @@ function TVirtualTreeColumns.GetVisibleColumns : TColumnsArray;
I, Counter : Integer;

begin
Result := nil;
SetLength(Result, Count);
Counter := 0;

Expand Down Expand Up @@ -5608,6 +5617,9 @@ procedure TVirtualTreeColumns.PaintHeader(DC : HDC; R : TRect; HOffset : TDimens
var
VisibleFixedWidth : TDimension;
RTLOffset : TDimension;
{$ifdef LCLCocoa}
sc : Double;
{$endif}

procedure PaintFixedArea;

Expand All @@ -5621,6 +5633,15 @@ procedure TVirtualTreeColumns.PaintHeader(DC : HDC; R : TRect; HOffset : TDimens
begin
// Adjust size of the header bitmap
FHeaderBitmap.SetSize(Max(TreeViewControl.HeaderRect.Right, R.Right - R.Left), TreeViewControl.HeaderRect.Bottom);
{$ifdef LCLCocoa}
if Assigned(Header) and Assigned(Header.TreeView) then
sc := Header.Treeview.GetCanvasScaleFactor
else
sc := 1.0;
FHeaderBitmap.Width := Round(FHeaderBitmap.Width * sc);
FHeaderBitmap.Height := Round(FHeaderBitmap.Height * sc);
CGContextScaleCTM(TCocoaBitmapContext(FHeaderBitmap.Canvas.Handle).CGContext, sc, sc);
{$endif}

VisibleFixedWidth := GetVisibleFixedWidth;

Expand All @@ -5643,7 +5664,15 @@ procedure TVirtualTreeColumns.PaintHeader(DC : HDC; R : TRect; HOffset : TDimens
PaintFixedArea;

// Blit the result to target.
{$ifdef LCLCocoa}
StretchBlt(DC, R.Left, R.Top, R.Right - R.Left, R.Bottom - R.Top,
FHeaderBitmap.Canvas.Handle,
R.Left, R.Top,
FHeaderBitmap.Width, FHeaderBitmap.Height,
SRCCOPY);
{$else}
BitBlt(DC, R.Left, R.Top, R.Right - R.Left, R.Bottom - R.Top, FHeaderBitmap.Canvas.Handle, R.Left, R.Top, SRCCOPY);
{$endif}
end;

//----------------------------------------------------------------------------------------------------------------------
Expand Down Expand Up @@ -5969,15 +5998,15 @@ procedure TVirtualTreeColumns.PaintHeader(TargetCanvas : TCanvas; R : TRect; con

// caption
if WrapCaption then
ColCaptionText := FCaptionText
ColCaptionText := UnicodeString(FCaptionText)
else
ColCaptionText := Text;
ColCaptionText := UnicodeString(Text);
if IsHoverIndex and TreeViewControl.VclStyleEnabled then
DrawHot := True
else
DrawHot := (IsHoverIndex and (hoHotTrack in Header.Options) and not (tsUseThemes in TreeViewControl.TreeStates));
if not (hpeText in ActualElements) and (Length(Text) > 0) then
DrawButtonText(TargetCanvas.Handle, ColCaptionText, TextRectangle, IsEnabled, DrawHot, DrawFormat, WrapCaption);
DrawButtonText(TargetCanvas.Handle, String(ColCaptionText), TextRectangle, IsEnabled, DrawHot, DrawFormat, WrapCaption);

// sort glyph
if not (hpeSortGlyph in ActualElements) and ShowSortGlyph then
Expand Down
4 changes: 2 additions & 2 deletions Source/VirtualTrees.Utils.pas
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ interface
bmConstantAlphaAndColor // blend the destination color with the given constant color und the constant alpha value
);

procedure AlphaBlend(Source, Destination: HDC; R: TRect; Target: TPoint; Mode: TBlendMode; ConstantAlpha, Bias: Integer);
procedure AlphaBlend(Source, Destination: HDC; const R: TRect; const Target: TPoint; Mode: TBlendMode; ConstantAlpha, Bias: Integer);
function GetRGBColor(Value: TColor): DWORD;
{$ifdef EnablePrint}
procedure PrtStretchDrawDIB(Canvas: TCanvas; DestRect: TRect; ABitmap: TBitmap);
Expand Down Expand Up @@ -460,7 +460,7 @@ function WrapString(DC: HDC; const S: string; const Bounds: TRect; RTL: Boolean;
I, W: Integer;
Buffer,
Line: string;
Words: array of string;
Words: array of string = nil;
R: TRect;

begin
Expand Down
2 changes: 0 additions & 2 deletions Source/include/intf/carbon/olemethods.inc

This file was deleted.

4 changes: 2 additions & 2 deletions Source/include/intf/carbon/vtgraphicsi.inc
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
//todo: properly implement
procedure AlphaBlend(Source, Destination: HDC; R: TRect; Target: TPoint; Mode: TBlendMode; ConstantAlpha, Bias: Integer);
procedure AlphaBlend(Source, Destination: HDC; const R: TRect; const Target: TPoint; Mode: TBlendMode; ConstantAlpha, Bias: Integer);
begin
case Mode of
bmConstantAlpha,
Expand All @@ -20,4 +20,4 @@ end;
function GetBitmapBitsFromBitmap(Bitmap: HBITMAP): Pointer;
begin
Result := nil;
end;
end;
2 changes: 0 additions & 2 deletions Source/include/intf/cocoa/olemethods.inc

This file was deleted.

4 changes: 2 additions & 2 deletions Source/include/intf/cocoa/vtgraphicsi.inc
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
//todo: properly implement
procedure AlphaBlend(Source, Destination: HDC; R: TRect; Target: TPoint; Mode: TBlendMode; ConstantAlpha, Bias: Integer);
procedure AlphaBlend(Source, Destination: HDC; const R: TRect; const Target: TPoint; Mode: TBlendMode; ConstantAlpha, Bias: Integer);
begin
case Mode of
bmConstantAlpha,
Expand All @@ -20,4 +20,4 @@ end;
function GetBitmapBitsFromBitmap(Bitmap: HBITMAP): Pointer;
begin
Result := nil;
end;
end;
Loading

0 comments on commit b3eae92

Please sign in to comment.