Jump to content

Attila Kovacs

Members
  • Content Count

    2016
  • Joined

  • Last visited

  • Days Won

    26

Everything posted by Attila Kovacs

  1. Attila Kovacs

    Scaling (DPI Change) + Anchors

    Could you help me identify from which Delphi version this works correctly? If it does at all..... Anchors are akTop + akRight original: pressing "+", (scale up with 24dpi) the same thing happens if the anchors are akTop + akLeft + akRigt I'm on Berlin U2. A hint or a patch or workaround would also be appreciated if available. Scale-Test.7z
  2. Attila Kovacs

    Scaling (DPI Change) + Anchors

    It seems I can't postpone an upgrade much longer, perhaps I can bridge it until then with this. Very basic, only tested with the form from above, (also inserting/removing components may break it)... unit AnchorPanel; interface uses Winapi.Windows, Winapi.Messages, System.Classes, Vcl.Controls, Vcl.ExtCtrls; type TControl = class(Vcl.Controls.TControl); TControlData = record Anchors: TAnchors; Bounds: TRect; Align: TAlign; IsScaling: boolean; end; TAnchorPanel = class(TPanel) private FOriginalSize: TRect; FControlData: TArray<TControlData>; FCalcWidth: integer; FCalcHeight: integer; FScale: single; procedure SaveControls; procedure ResizeControls; procedure WMSize(var Message: TWMSize); message WM_SIZE; protected procedure ChangeScale(M, D: integer; isDpiChange: boolean); override; procedure Loaded; override; public published end; procedure Register; implementation procedure Register; begin RegisterComponents('Samples', [TAnchorPanel]); end; { TAnchorPanel } procedure TAnchorPanel.ChangeScale(M, D: integer; isDpiChange: boolean); var i: integer; begin if (csDesigning in ComponentState) then begin inherited ChangeScale(M, D, isDpiChange); end else begin SaveControls; inherited ChangeScale(M, D, True); if csLoading in ComponentState then begin FCalcWidth := Width; FCalcHeight := Height; FScale := 1; end else begin FCalcWidth := MulDiv(Width, M, D); FCalcHeight := MulDiv(Height, M, D); FScale := FScale * M / D; end; if not isDpiChange then begin for i := 0 to ControlCount - 1 do begin FControlData[i].IsScaling := True; TControl(Controls[i]).ChangeScale(M, D, isDpiChange); end; end; end; end; procedure TAnchorPanel.Loaded; begin inherited; if not(csDesigning in ComponentState) then begin FOriginalSize := Self.BoundsRect; FCalcWidth := Self.Width; end; end; procedure TAnchorPanel.ResizeControls; var i: integer; begin if FOriginalSize.Width <> 0 then for i := 0 to High(FControlData) do begin if FControlData[i].Align = alNone then if akRight in FControlData[i].Anchors then begin if akLeft in FControlData[i].Anchors then begin Controls[i].Width := Trunc(FControlData[i].Bounds.Width * FScale) + Trunc(Self.Width - (FOriginalSize.Width * FScale)); end else begin if not FControlData[i].IsScaling then Controls[i].Left := Trunc(FControlData[i].Bounds.Left * FScale) + (Self.Width - FCalcWidth) + Trunc(FCalcWidth - (FOriginalSize.Width * FScale)); end; end; FControlData[i].IsScaling := False; end; end; procedure TAnchorPanel.SaveControls; var i: integer; begin if not(csDesigning in ComponentState) then begin if Length(FControlData) <> Self.ControlCount then begin SetLength(FControlData, Self.ControlCount); for i := 0 to Self.ControlCount - 1 do begin FControlData[i].Anchors := Self.Controls[i].Anchors; FControlData[i].Bounds := Self.Controls[i].BoundsRect; FControlData[i].Align := Self.Controls[i].Align; FControlData[i].IsScaling := False; Self.Controls[i].Anchors := [akLeft, akTop]; end; end; end; end; procedure TAnchorPanel.WMSize(var Message: TWMSize); begin if not(csDesigning in ComponentState) then SaveControls; inherited; if not(csDesigning in ComponentState) then ResizeControls end; end. Scale-Test5.7z
  3. Attila Kovacs

    Scaling (DPI Change) + Anchors

    didn't work, the bottom pane is now on 3 panels in groups
  4. Attila Kovacs

    Scaling (DPI Change) + Anchors

    They are on a TPanel. o.O
  5. since I switched to x64, I've been encountering a problem that I can only describe if it's not.
  6. Attila Kovacs

    Returning a string from a bpl

    what was your first google hit?
  7. Attila Kovacs

    Collecting data

    here
  8. Attila Kovacs

    Are local TGUIDS preinitialized?

    as both paramerters for Equal() are const it could yell before calling it
  9. Attila Kovacs

    Are local TGUIDS preinitialized?

    @Brandon Staggs The compiler makes educated guesses even with integers. Consider my example. The same could be mimicked for records. I know it won't cover everything, but neither does it for other types.
  10. Attila Kovacs

    Are local TGUIDS preinitialized?

    var i: integer; begin i.ToSingle; if i > 0 then Exit; I understand but I think those excuses are made up. ToSingle supresses the hint.
  11. Attila Kovacs

    Are local TGUIDS preinitialized?

    Does this 'more complex' mean that we don't care, or that we sweated hard and got it done? 🙂
  12. Attila Kovacs

    Are local TGUIDS preinitialized?

    Ahm, isn't there a compiler hint missing then?
  13. Attila Kovacs

    Are local TGUIDS preinitialized?

    @Dalija Prasnikar Thanks! So, I was just lucky all the time <o>, checking it against TGUID.Empty and it bit me under x64. Did a code check and found one more occurence in my code...
  14. Attila Kovacs

    Project Options -> Version Info aka. dproj madness

    I also have a build server where I generate the resource from a template, but I still need it in the IDE. Just saying. 😉
  15. Attila Kovacs

    Project Options -> Version Info aka. dproj madness

    I also need it in the IDE because I store essential information in it. Perhaps it's not the best practice, but that's how it currently is. Uwe's solution to remove child entries seems to be the best option, as it usually is when he comes up with something. However, this issue should also be addressed in the IDE itself. At the very least, they should consider hiring that expert and incorporating their solution into the IDE.
  16. Attila Kovacs

    JSON and UInt64 problem

    That means those numbers are implicitly converted to anything by every interpreter. If necessary, you may consider using strings instead.
  17. Attila Kovacs

    Project Options -> Version Info aka. dproj madness

    oh. now that's interesting 😄
  18. One of my VCL apps is hanging in 64-bit mode at termination for 30+ seconds. Any ideas what could be causing this? I don't have to do much; just starting the app and ending it, or pressing Ctrl+F2. Other apps are terminating instantly. I would prefer to try some tips before resorting to cloning the project and systematically removing components. IDE: Berlin U2
  19. Attila Kovacs

    JSON and UInt64 problem

    Be careful with those numbers, they can bite. https://lwn.net/Articles/730671/
  20. Attila Kovacs

    Project Options -> Version Info aka. dproj madness

    Great, but this should be working in the IDE. Before I report this misimplementation, I wanted to know if it's still the same in the current IDE.
  21. Attila Kovacs

    Project Options -> Version Info aka. dproj madness

    Of course. The state as if it were never checked, without explicit "false" in the dproj, inherinting the settings from above.
  22. Attila Kovacs

    ANN HTML Library 4.7 released

    It became really fast with about 30.000 shapes. Like you were zooming/scrolling etc.. an image without any lag.
  23. Attila Kovacs

    Type within a class

    it's a type declaration in the class it's type TDataContainer = class public type TIterateAction = reference to procedure (value: integer); strict private FData: TArray<integer>; FIndex: integer; public constructor Create(const data: TArray<integer>); procedure Iterate(action: TIterateAction); function GetFirst(var value: integer): boolean; function GetNext(var value: integer): boolean; end; TDataContainer.TIterateAction type It's just ebarcadero who does not give a fuck to implement its own syntax to the formatter.
  24. It's the Vcl.FlexCel.Core and FlexCel.XlsAdapter units. I'll ask the Author.
×