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

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
13 октября 2025

Как использовать Excel формулы в отчете при экспорте в MS Excel

Начиная с версии FastReport .NET 2026.1 появилась возможность экспортировать формулы в Microsoft Excel. Важно правильно настроить экспорт формул и соблюдать синтаксис.
13 октября 2025

Новые возможности экспорта изображений в Microsoft Word в FastReport .NET

В последней версии FastReport .NET мы добавили новые функции экспорта изображений. Теперь можно самостоятельно настроить баланс между качеством и размером итогового документа.
30 сентября 2025

Как установить дизайнер отчетов FastReport .NET с предустановленными плагинами

Читайте в статье как с версии 2025.2.5 для FastReport .NET WinForms и FastReport .NET WEB можно установить дизайнер отчётов со всеми плагинами без сборки dll-файлов.

Не является публичной офертой
© 1998-2025 ООО «Быстрые отчеты»