Для вычисления агрегатного значения одного или нескольких полей одного источника данных используются два элемента оформления.
Элемент CalcText позволяет отобразить результат вычисления на полосе отчета. Так же, как и обычный элемент
DataText, его необходимо связать с
просмотром и полем. Для этого
используются свойстваDataView
и DataField соответственно.
Кроме этого, элемент CalcText должен быть связан со специализированным элементом
CaicController (см. ниже), который будет управлять процессом вычисления. Связывание осуществляется при помощи свойства
Controller.
В свойстве CalcType задается одна из пяти перечисленных выше агрегатных
функций.
Дополнительно, для функции COUNT можно настроить еще три свойства. При необходимости включить или отключить подсчет нулевых значений или пробелов используются булевские свойства
countNulls и countBianks соответственно. А свойство
Countvalue позволяет задать значение поля, которое будет учитываться при расчете функции, все остальные значения будут игнорироваться.
Вычисленное значение при сохранении может быть отформатировано в соответствии с шаблоном, заданным свойством
DisplayFormat.
Для всех агрегатных функций можно задать момент начала вычислений. Для этого в свойстве
initializer необходимо указать элемент оформления отчета, и при его печати начнется вычисление. Это может быть любой элемент, расположенный с элементом
CalcText на одной полосе. Но желательно использовать для этого специализированный элемент
calccontroller (см. ниже).
Примечание
Пример использования элемента оформления CalcText
имеется в отчетах, рассмотренных нами выше.
Элемент CalcTotal является невизуальным аналогом элемента
CalcText. Поэтому он обладает всеми свойствами, о которых рассказывается выше для элемента
CalcText. Вычисленное при его печати значение разработчик может использовать по своему усмотрению после того, как оно сохранено. Приемником вычисленного значения может быть один из параметров объекта отчета.
Свойство DestParam позволяет выбрать один из предопределенных или созданных разработчиком параметров отчета (свойство
Parameters объекта отчета).
Свойство DestPiVar задает переменную отчета, в которую будет передано вычисленное значение (свойство
pivars объекта отчета).
Рис. 26.8. Редактор свойства
DataField
Затем параметр или переменная может быть использована
для дальнейших вычислений или напечатана при помощи элемента DataText.
В редакторе свойства DataField этого элемента
(рис. 26.8) параметры и переменные отчета можно выбрать из списков Project
Parameters и Post Initialize Variables.
Знаете ли Вы, что такое "Большой Взрыв"? Согласно рупору релятивистской идеологии Википедии "Большой взрыв (англ. Big Bang) - это космологическая модель, описывающая раннее развитие Вселенной, а именно - начало расширения Вселенной, перед которым Вселенная находилась в сингулярном состоянии. Обычно сейчас автоматически сочетают теорию Большого взрыва и модель горячей Вселенной, но эти концепции независимы и исторически существовало также представление о холодной начальной Вселенной вблизи Большого взрыва. Именно сочетание теории Большого взрыва с теорией горячей Вселенной, подкрепляемое существованием реликтового излучения..." В этой тираде количество нонсенсов (бессмыслиц) больше, чем количество предложений, иначе просто трудно запутать сознание обывателя до такой степени, чтобы он поверил в эту ахинею. На самом деле взорваться что-либо может только в уже имеющемся пространстве. Без этого никакого взрыва в принципе быть не может, так как "взрыв" - понятие, применимое только внутри уже имеющегося пространства. А раз так, то есть, если пространство вселенной уже было до БВ, то БВ не может быть началом Вселенной в принципе. Это во-первых. Во-вторых, Вселенная - это не обычный конечный объект с границами, это сама бесконечность во времени и пространстве. У нее нет начала и конца, а также пространственных границ уже по ее определению: она есть всё (потому и называется Вселенной). В третьих, фраза "представление о холодной начальной Вселенной вблизи Большого взрыва" тоже есть сплошной нонсенс. Что могло быть "вблизи Большого взрыва", если самой Вселенной там еще не было? Подробнее читайте в FAQ по эфирной физике.