Как управлять отступом сверху на второй странице отчета

06.09.2018

Часто, при отображении отчета вы можете наблюдать как не поместившиеся на первой странице данные переносятся на вторую. Это характерно для бэнда «Данные» и «Заголовок группы», и связанных с ними.

В бэнде «Данные» могут быть поля данных, или другие объекты, такие как таблица или матрица.

Чтобы первая страница полностью заполнилась данными, без пробелов, нужно установить свойство CanBreak для бэнда «Данные». Но что, если вы хотите «остаток» таблицы на второй странице разместить ниже верхнего края? Скажем на уровне начала таблицы. При этом, если просматривать одновременно два листа отчета, это будет выглядеть гармонично. Штатных настроек для этого нет. Но, мы всегда можем воспользоваться скриптом отчета, и сделать что угодно.

Поэтому существует два способа осуществить задуманное, и оба они очень похожи.

Первый способ:

  1. Добавить бэнд «Заголовок страницы»;
  2. Добавить обработчик события BeforePrint для этого бэнда;
  3. В коде обработчика события проверить номер текущей страницы, и, если это вторая страница, но изменить высоту бэнда на подходящую величину.

Подобрав высоту бэнда «Заголовок страницы», мы можем добиться печати таблицы на второй странице на том же уровне, что и на первой.

Второй способ практически идентичен первому:

  1. Добавить бэнд «Заголовок страницы»;
  2. Задать ему нужную высоту в свойствах;
  3. Добавить обработчик события BeforePrint для бэнда «Заголовок страницы»;
  4. В коде обработчика события проверить номер текущей страницы, и, если это вторая страница, но отобразить бэнд.

Оба способа абсолютно равнозначные, просто выберите понравившийся.

Теперь рассмотрим код обработчика события BeforePrint для бэнда «Заголовок страницы».

Первый способ:

1
2
3
4
5
6
7
private void PageHeader1_BeforePrint(object sender, EventArgs e)
{
 if (Engine.CurPage > 0)
 PageHeader1.Height = 50; // Set top margin
 else
 PageHeader1.Height = 0;
}

 Второй способ:

1
2
3
4
5
6
7
private void PageHeader1_BeforePrint(object sender, EventArgs e) 
{ 
 if (Engine.CurPage > 0) 
 PageHeader1.Visible = true; 
 else 
 PageHeader1.Visible = false; 
} 

 Как видите, в первом случае мы изменяем высоту бэнда в коде, а во втором отображаем бэнд с заранее заданной высотой.

В результате получим отступ сверху для таблицы на второй странице отчета:

Таким образом вы можете настраивать отступы для каждой последующей страницы отчета.

.NET .NET FastReport FastReport
21 апреля 2025

Как работают RFID-метки в FastReport VCL

В этой статье мы рассмотрим принцип работы RFID-меток с новым объектом TfrxDeviceCommand в FastReport VCL с релизом 2025.2.
21 апреля 2025

Работа с компонентом TfrShellTreeView в FastReport VCL

В данной статье мы рассмотрим компонент TfrShellTreeView. Он предназначен для отображения элементов файловой системы и частично является аналогом компонентов TDirectoryListBox, TDirectoryOutline и TShellTreeView.
8 апреля 2025

Как настроить подключение к Apache Ignite в FastReport .NET

В этой статье мы рассмотрим, как настроить подключение к Apache Ignite в FastReport .NET. Вы узнаете, какие шаги необходимо выполнить для подключения плагина через код и дизайнер отчетов.