Форум программистов, компьютерный форум, киберфорум
Microsoft Access
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.89/9: Рейтинг темы: голосов - 9, средняя оценка - 4.89
 Аватар для minibuilder
97 / 6 / 1
Регистрация: 15.04.2013
Сообщений: 40

Отчет фиксированной высоты

20.12.2013, 11:14. Показов 1978. Ответов 11
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Подскажите, пожалуйста, как можно сделать отчет фиксированной высоты, чтобы он помещался либо на половину листа А4, либо на целый.
Отчеты выводятся по группам. Заголовок и примечание группы фиксированы, высота изменяется только в области данных.
Так вот вопрос: как сделать, чтобы одна эта группа занимала строго либо пол страницы А4, или если не умещается, то занимала целый лист.
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.12.2013, 11:14
Ответы с готовыми решениями:

Таблица фиксированной высоты со скролом
Здравствуйте, не получается сделать таблицу фиксированной высоты со скролом, т.е. Таблица со справочной информации, вытягивает страницу, а...

Выровнять блоки без фиксированной высоты
есть 4 блока в которых имеется картинки разных размеров. Нужно что бы текст всегда был на одном уровне от высоты самой высокой картинки. У...

Задание фиксированной высоты блока в две строки
Здравствуйте! Есть страница с блоками такого плана. Эти блоки размещаются один за одним в ряд. <div class="item"...

11
 Аватар для VinniPuh
9127 / 6129 / 593
Регистрация: 27.03.2013
Сообщений: 19,972
20.12.2013, 13:36
Точно не скажу, мало с отчетами балуюсь, но наверное можно поробовать поиграться в режиме конструктора отчета с параметрами типа - ГРУППИРОВКА
Там были такие параметры -
Интервал
или
не разрывать
+ еще
можно попробовать в панели элементов
Разрыв страницы
1
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,934
Записей в блоге: 4
20.12.2013, 14:47
Так вот вопрос: как сделать, чтобы одна эта группа занимала строго либо пол страницы А4, или если не умещается, то занимала целый лист.
сочетание групп может быть ММ-ММ-М-Б-Б-Б-Б-Б-М-Б

если будет ММ пройдет
если же МБ -нет
0
 Аватар для VinniPuh
9127 / 6129 / 593
Регистрация: 27.03.2013
Сообщений: 19,972
20.12.2013, 15:04
shanemac51 - Ну Вы и ответили.
Цитата Сообщение от shanemac51 Посмотреть сообщение
...ММ-ММ-М-Б-Б-Б-Б-Б-М-Б...
А поразвернутее и поподробнее можно?
1
 Аватар для Андрэич
2842 / 774 / 41
Регистрация: 20.05.2012
Сообщений: 2,055
20.12.2013, 15:20
У Гетца есть похожий пример: www.cyberforum.ru/post1960917.html
1
 Аватар для minibuilder
97 / 6 / 1
Регистрация: 15.04.2013
Сообщений: 40
20.12.2013, 15:38  [ТС]
shanemac51, что ты имеешь ввиду?)
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,934
Записей в блоге: 4
20.12.2013, 16:01
а то что размер предполагаемых бланков случаен
--то маленький --пол-листа
--то большой(1 лист)

хотя на этом можно сработать
--все элементы в области данных
--введите вертикальную линию высотой с пол-листа--чтобы элементы не разрывались

хотя не понятно
--в отчете одна строка данных(например карта приема на работу)
--или это накладная с головной и табличной частями
0
 Аватар для minibuilder
97 / 6 / 1
Регистрация: 15.04.2013
Сообщений: 40
20.12.2013, 17:09  [ТС]
Лучший ответ Сообщение было отмечено как решение

Решение

Цитата Сообщение от shanemac51 Посмотреть сообщение
введите вертикальную линию высотой с пол-листа--чтобы элементы не разрывались
так делать необязательно и даже неправильно. чтобы элементы группы не разрывались достаточно указать в "Сортировке и группировке" в свойстве "Не разрывать" - "Вся группа". Вопрос про неразрывность не стоял.
Цитата Сообщение от shanemac51 Посмотреть сообщение
хотя не понятно
--в отчете одна строка данных(например карта приема на работу)
--или это накладная с головной и табличной частями
да, это подобие накладной, в которой есть заголовок (так называемая тобой головная часть), область данных (табличная часть) и примечание (назовем ее нижняя часть)

Область данных строиться из запроса и содержит в каждой группе различное количество строк.
Как я уже писал выше, высота заголовка и примечания в принципе фиксированы. Конечная высота в каждой из групп будет зависить исключительно от высоты области данных.

Мммббб - это конечно хорошо, но это алгоритм, а мне нужно конкретное средство реализации.

К примеру, если отталкиваться от алгоритма, то как из возможных вариантов, я вижу в изменении высоты примечания, чтобы следующая группа начиналась строго с середины листа, либо чтобы группа помещалась на А4 единолично

хотелось бы как то так:
if [Область данных конкретной группы].[Высота] < xxx then
[Примечание той же самой конкретной группы].[Высота] = [Примечание той же самой конкретной группы].[Высота]+ууу
else
[Примечание той же самой конкретной группы].[Высота] = [Примечание той же самой конкретной группы].[Высота]+zzz
другими словами, если высота всей группы менее половинки листа, то растянуть ее до высоты этой половинки, если больше - то до размера листа

Андрэич, какой именно пример. просто у меня сейчас нет возможности скачать книгу с файлообменника...
1
 Аватар для Андрэич
2842 / 774 / 41
Регистрация: 20.05.2012
Сообщений: 2,055
20.12.2013, 18:53
Я немного перепутал с другой фичей отчёта (давно не обращался к классикам )
...

Попробуйте в конструкторе свойство Неразрывная группа.

Или, по Гетцу, программно (только в процедуре события Открытие):
Visual Basic
1
Reports("MyReport").GroupLevel(Номер группировки начиная с нуля).KeepTogether = 1
где
1, WholeGroup - Аксесс попытается напечатать на одной стр заголовок, обл данных и примечание группы,
2, WithFirstDetail - заголовок и первую сроку обл данных.
Если на одной стр уместится, будет напечатано как получится
1
 Аватар для minibuilder
97 / 6 / 1
Регистрация: 15.04.2013
Сообщений: 40
23.12.2013, 12:01  [ТС]
Андрэич, пока оно и так у меня печатает как получается)
Суть задачи:
1. Вся группа - заголовок, обл данных, примечание - должны быть неразрывны (это несложно реализуется свойством Неразрывная группа)
2. Одна группа должна занимать четко половинку А4, если не помещается - то целый лист (за пределы А4 выходить точно не будет), т.е. на листе в итоге будет не более 2-х таких групп, причем нижняя группа на листе должна начинаться СТРОГО от середины.

Есть ли какая-то программная возможность узнать высоту каждой из групп уже в ходе постоения самого отчета? Или высоту уже построенной (со всеми полями) области данных. Либо на худой конец программно подчитать количево полей в каждой области данных для каждой группы...
0
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,934
Записей в блоге: 4
23.12.2013, 15:02
примерно так
Вложения
Тип файла: zip Авторемонтные23.zip (32.5 Кб, 13 просмотров)
1
Модератор
Эксперт MS Access
 Аватар для shanemac51
12231 / 5078 / 814
Регистрация: 07.08.2010
Сообщений: 14,934
Записей в блоге: 4
23.12.2013, 15:05
рисунок
Миниатюры
Отчет фиксированной высоты  
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.12.2013, 15:05
Помогаю со студенческими работами здесь

Какое количество топлива необходимо для спуска с высоты A до высоты B
Имя входного файла | input.txt ...

Найти координаты основания высоты, уравнения стороны, высоты, медианы
A(2,-3), B(17,-3), C(11,15) Найти a) координаты основания высоты BD треугольника ABC б) найти уравнения стороны BC, высоты BD,...

Вычислить, какое количество единиц топлива необходимо для спуска шара с высоты B до высоты A
Полетав немного на модифицированном воздушном шаре, Шурик отметил неприятную вещь: шар всегда спускается, но делает это очень медленно....

Автоматическое изменение высоты сразу нескольких элементов управления при изменении высоты формы
Здравствуйте! Подскажите пожалуйста, возможно ли настроить автоматическре изменение высоты сразу трёх элементов управления при изменении...

Найти координаты точки пересечения высоты AH и высоты BG треугольника
Треугольник задан координатами своих вершин A(x1;y1), B(x2;y2), C(x3;y3). Найти координаты точки пересечения высоты AH и высоты BG....


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
12
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru