Недавно добавленные исходники

•  DeLiKaTeS Tetris (Тетрис)  4 667

•  TDictionary Custom Sort  6 673

•  Fast Watermark Sources  6 455

•  3D Designer  9 388

•  Sik Screen Capture  6 790

•  Patch Maker  7 199

•  Айболит (remote control)  7 186

•  ListBox Drag & Drop  6 034

•  Доска для игры Реверси  97 657

•  Графические эффекты  7 358

•  Рисование по маске  6 660

•  Перетаскивание изображений  5 516

•  Canvas Drawing  5 902

•  Рисование Луны  5 645

•  Поворот изображения  5 131

•  Рисование стержней  3 722

•  Paint on Shape  2 928

•  Генератор кроссвордов  3 839

•  Головоломка Paletto  3 072

•  Теорема Монжа об окружностях  3 885

•  Пазл Numbrix  2 554

•  Заборы и коммивояжеры  3 301

•  Игра HIP  2 263

•  Игра Go (Го)  2 183

•  Симулятор лифта  2 578

•  Программа укладки плитки  2 190

•  Генератор лабиринта  2 693

•  Проверка числового ввода  2 342

•  HEX View  2 675

•  Физический маятник  2 329

 
скрыть

  Форум  

Delphi FAQ - Часто задаваемые вопросы

| Базы данных | Графика и Игры | Интернет и Сети | Компоненты и Классы | Мультимедиа |
| ОС и Железо | Программа и Интерфейс | Рабочий стол | Синтаксис | Технологии | Файловая система |



Delphi Sources

Как узнать минимальные поля для принтера



uses
  Printers;

type
  TMargins = record
    Left,
      Top,
      Right,
      Bottom: Double
  end;

procedure GetPrinterMargins(var Margins: TMargins);
var
  PixelsPerInch: TPoint;
  PhysPageSize: TPoint;
  OffsetStart: TPoint;
  PageRes: TPoint;
begin
  PixelsPerInch.y := GetDeviceCaps(Printer.Handle, LOGPIXELSY);
  PixelsPerInch.x := GetDeviceCaps(Printer.Handle, LOGPIXELSX);
  Escape(Printer.Handle, GETPHYSPAGESIZE, 0, nil, @PhysPageSize);
  Escape(Printer.Handle, GETPRINTINGOFFSET, 0, nil, @OffsetStart);
  PageRes.y := GetDeviceCaps(Printer.Handle, VERTRES);
  PageRes.x := GetDeviceCaps(Printer.Handle, HORZRES);
  // Top Margin
  Margins.Top := OffsetStart.y / PixelsPerInch.y;
  // Left Margin
  Margins.Left := OffsetStart.x / PixelsPerInch.x;
  // Bottom Margin
  Margins.Bottom := ((PhysPageSize.y - PageRes.y) / PixelsPerInch.y) -
    (OffsetStart.y / PixelsPerInch.y);
  // Right Margin
  Margins.Right := ((PhysPageSize.x - PageRes.x) / PixelsPerInch.x) -
    (OffsetStart.x / PixelsPerInch.x);
end;

function InchToCm(Pixel: Single): Single;
// Convert inch to Centimeter
begin
  Result := Pixel * 2.54
end;

procedure TForm1.Button1Click(Sender: TObject);
var
  Margins: TMargins;
begin
  GetPrinterMargins(Margins);
  ShowMessage(Format('Margins: (Left: %1.3f, Top: %1.3f, Right: %1.3f, Bottom: %1.3f)',
    [InchToCm(Margins.Left),
    InchToCm(Margins.Top),
      InchToCm(Margins.Right),
      InchToCm(Margins.Bottom)]));
end;




Похожие по теме исходники

Линейная интерполяция функции

Интерполяция сплайнами

Нейросеть для распознавания образов

Механизм станка качалки для нефти

 

Весы для взвешивания

Кувшины для воды

Доска для игры Реверси




Copyright © 2004-2025 "Delphi Sources" by BrokenByte Software. Delphi World FAQ

Группа ВКонтакте