| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768 |
- using QuestPDF.Drawing;
- using QuestPDF.Helpers;
- using QuestPDF.Infrastructure;
- namespace QuestPDF.LayoutTests.TestEngine;
- internal class MockDrawingCommand
- {
- public string ElementId { get; set; }
- public int PageNumber { get; set; }
- public Position Position { get; set; }
- public Size Size { get; set; }
- }
- internal class ElementMock : Element
- {
- public string Id { get; set; }
- public string Color { get; set; } = Placeholders.Color();
-
- public float TotalWidth { get; set; }
- public float TotalHeight { get; set; }
-
- private float HeightOffset { get; set; }
- internal List<MockDrawingCommand> DrawingCommands { get; } = new();
-
- internal override SpacePlan Measure(Size availableSpace)
- {
- if (TotalWidth > availableSpace.Width)
- return SpacePlan.Wrap();
-
- if (availableSpace.Height < Size.Epsilon)
- return SpacePlan.Wrap();
- var remainingHeight = TotalHeight - HeightOffset;
- if (remainingHeight == 0)
- return SpacePlan.FullRender(Size.Zero);
-
- if (remainingHeight > availableSpace.Height)
- return SpacePlan.PartialRender(TotalWidth, availableSpace.Height);
-
- return SpacePlan.FullRender(TotalWidth, remainingHeight);
- }
- internal override void Draw(Size availableSpace)
- {
- var height = Math.Min(TotalHeight - HeightOffset, availableSpace.Height);
- var size = new Size(TotalWidth, height);
-
- Canvas.DrawRectangle(Position.Zero, size, Color);
- HeightOffset += height;
-
- if (Canvas is not SkiaCanvasBase canvasBase)
- return;
- var matrix = canvasBase.Canvas.TotalMatrix;
-
- DrawingCommands.Add(new MockDrawingCommand
- {
- ElementId = Id,
- PageNumber = PageContext.CurrentPage,
- Position = new Position(matrix.TransX / matrix.ScaleX, matrix.TransY / matrix.ScaleY),
- Size = size
- });
- }
- }
|