Часто, при отображении отчета вы можете наблюдать как не поместившиеся на первой странице данные переносятся на вторую. Это характерно для бэнда «Данные» и «Заголовок группы», и связанных с ними.
В бэнде «Данные» могут быть поля данных, или другие объекты, такие как таблица или матрица.
Чтобы первая страница полностью заполнилась данными, без пробелов, нужно установить свойство CanBreak для бэнда «Данные». Но что, если вы хотите «остаток» таблицы на второй странице разместить ниже верхнего края? Скажем на уровне начала таблицы. При этом, если просматривать одновременно два листа отчета, это будет выглядеть гармонично. Штатных настроек для этого нет. Но, мы всегда можем воспользоваться скриптом отчета, и сделать что угодно.
Поэтому существует два способа осуществить задуманное, и оба они очень похожи.
Первый способ:
Подобрав высоту бэнда «Заголовок страницы», мы можем добиться печати таблицы на второй странице на том же уровне, что и на первой.
Второй способ практически идентичен первому:
Оба способа абсолютно равнозначные, просто выберите понравившийся.
Теперь рассмотрим код обработчика события 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; } |
Как видите, в первом случае мы изменяем высоту бэнда в коде, а во втором отображаем бэнд с заранее заданной высотой.
В результате получим отступ сверху для таблицы на второй странице отчета:
Таким образом вы можете настраивать отступы для каждой последующей страницы отчета.