Архитектура Аудит Военная наука Иностранные языки Медицина Металлургия Метрология
Образование Политология Производство Психология Стандартизация Технологии


Визуальный компонент класса TChart.



Для того чтобы создать график необходимо разместить компонент TChart на форме или воспользоваться мастером.

Рисунок 1.Заготовка графика в форме.

После двойного щелчка мыши по этой заготовке, будет произведен переход в редактор графика. В среде этого редактора можно установить свойства графика и его серий. Содержимое редактора графика представляет собой табулированный блокнот. Для нового графика первой всегда показывается закладка Chart и для страницы Chart - закладка Series (рисунок 2).

Рисунок 2. Редактор графика.

Каждая из закладок на странице Chart предназначена для установки параметров того или иного компонента графика:

Series - содержит серии графика. Серией называется набор точек графика. На графике серии соответствует отдельная линия или ряд столбцов. Если в графике несколько серий, то будет визуализировано несколько линий или рядов столбцов.

General - устанавливает общие параметры графика, такие как объемность графика, отступы от краев, возможность увеличения ( Zoom ) и др.

Axis - устанавливает свойства осей (рисунок 3.).

В области ShowAxis определяется, для какой оси устанавливаются параметры - левой, правой, верхней или нижней. На странице, определяемой закладкой Scales, устанавливаются свойства масштаба значений по оси. Automatic устанавливает автоматическое масштабирование данных по оси - минимум и максимум вычисляются динамически, исходя из текущих значений серии. При отмене автоматического масштабирования можно установить автоматическое масштабирование минимального ( Minimum ) или максимального ( Maximum ) значения (отметка Auto ). Для установки значения максимума и (или) минимума вручную следует нажать соответствующую кнопку Change. Шаг масштаба по оси выбирается автоматически, если в Desired Increment установлено значение 0. Установить фиксированное значение шага можно, нажав кнопку Change. Закладка Title позволяет установить текст заголовка по оси, угол расположения заготовки и шрифт, которым заголовок выводится. Закладка Labels задает параметры меток для оси. Закладка Tiks устанавливает параметры самой линии оси.

 

Рисунок 3. Редактор графика - окно установки свойств осей.

Titles - определяет заголовок графика, шрифт, выравнивание и др.

Legend - задает параметры легенды. Легенда - это область графика, где приводится информация о графике. Легенда служит для пояснения графика.

Panel - определяет параметры панели, на которой располагается график.

Paging - устанавливает параметры многостраничного графика.

Walls - задает " стенку" графика.

3D - дает возможность изменить внешний вид диаграммы: наклон, сдвиг, толщину и т.д.

Добавление серии в график

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

Чтобы добавить в график серию, следует на странице Chart, (закладка Series ) нажать кнопку Add. После этого появится окно выбора типа серии (рисунок 4.).

Рисунок 4.Редактор графика - окно выбора типа серии

После выбора типа серии в график добавляется компонент, дочерний от базового типа TChartSeries - TLineSeries, TBarSeries, TPieSeries и т.д. Для примера выберем серию типа Line и нажмем Ok. В окне страницы Chart (закладка Series ) будет показана серия (рисунок 5.).

Рисунок 5.Редактор графика - список серии графика

Кнопка Add может использоваться для добавления других серий, кнопка Delete - для удаления текущей серии. После нажатия кнопки Title можно определить заголовок серии, кнопки Clone -создать новый экземпляр такой же серии в этом же графике, кнопки Change - изменить тип текущей серии.

Перейдем с закладки Chart на закладку Series. На этой странице представлен блокнот с закладками Format, General, Marks, Data Source. Рассмотрим свойства серии, которые можно установить на страницах, соответствующих этим закладкам.

Главные свойства серии можно определить на странице Data Source. На ней определяется источник данных для серии. Выпадающий список ниже закладки позволяет определить тип источника данных для серии:

No Data - серии не назначается источник данных. Заготовленный шаблон серии может в разное время использоваться для показа данных из разных источников.

Random Values - набор случайных чисел, может быть полезен при формировании заготовки серии.

Function - функция ( Copy, Average, Low, High, Divide, Multiply, Subtract, Add ) - служит для построения графиков на основании данных в двух или более сериях.

Свойства компонента TChart:

Таблица 1. Свойства компонента TChart

Свойство Описание
Property AllowPanning: TPanningMode; Определяет возможность пользователя прокручивать наблюдаемую часть графика во время выполнения, нажимая правую кнопку мыши. Возможны значения: · pmNone - прокрутка запрещена; · pmHorizontal - прокрутка разрешена в горизонтальном направлении; · pmVertical - прокрутка разрешена в вертикальном направлении; · pmBoth - прокрутка разрешена в обоих направлениях.
Property AllowZoom: Boolean; Позволяет пользователю изменять во время выполнения масштаб изображения, вырезая фрагменты диаграммы или графика курсором мыши.
Property BackWall: TChartWall; PropertyBottomWall: TChartWall; Property LeftWall: TChartWall; Определяют характеристики соответственно задней, нижней и левой граней области трехмерного отображения графика.
PropertyBottomAxis: TChartAxis; Property LeftAxis: TChartAxis; Property RightAxis: TChartAxis; Определяют характеристики соответственно нижней, левой и правой осей.
Property Chart3dPercent: Integer; Масштаб трехмерного отображения диаграммы.
Property Foot: TChartTitle; Определяет подпись под диаграммой. По умолчанию отсутствует. Текст подписи определяется под свойством Text.
Property Frame: TChartPen; Определяет рамку вокруг диаграммы.
Property Legend: TChartLegend; Легенда диаграммы - список обозначений.
Property MarginLeft: Integer; Property MarginRight: Integer; Property MarginTop: Integer; Property MarginBottom: Integer; Значения левого, правого, верхнего и нижнего полей.
Property SeriesList: TChartSeriesList; Список серий данных, отображаемых в компоненте.
Property Title: TChartTitle; Определяет заголовок диаграммы.
Property View3d: Boolean; Разрешает или запрещает трехмерное отображение диаграммы.

Для задания отображаемых значений используются методы серии Series. Основные:

Метод Clear очищает серию от занесенных ранее данных.

Метод Add:

Add(const AValue: Double; const ALabel: String;

AColor: TColor)

позволяет добавить в диаграмму новую точку. Параметр AValue соответствует добавляемому значению, параметр ALabel - название, которое будет отображаться на диаграмме и в легенде, AColor - цвет. Заметим, что параметр ALabel - не обязательный, его можно задать пустым: ' '.

Метод AddXY:

AddXY(const AXValue, AYValue: Double;

const ALabel: String; AColor: TColor)

позволяет добавить в график функции новую точку. Параметр AXValue и AYValue соответствуют аргументу и функции. Параметр ALabel и AColor те же, что и в методе Add.

Так же компонент TChart имеет метод Print, обеспечивающий печать. Предварительно может быть выполнен метод PrintPortrait, задающий книжную (вертикальную) ориентацию бумаги, или метод PrintLandscape, задающий альбомную (горизонтальную) ориентацию. Масштабировать размер печатаемого графика можно, вызвав предварительно метод PrintRect:

procedure PrintRect(const R: TRect);

в котором параметр R определяет размер области принтера, в которой осуществляется печать.

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

 

Порядок выполнения работы:

 

1.Программно исследовать область определения заданной функции( см. вариант ).

2.C учетом проведенных исследований(точек разрыва) протабулировать функцию на заданном отрезке изменения аргумента от Хначального до Х конечного (Хн и Хк вводить в процессе работы программы).

3. Cохранить полученную таблицу значений функции в текстовом файле(выбор имени файла осуществлять динамически с помощью компонент страницы VCL DIALOGS.

4. Построить график заданной функции:

а) с использованием визуального компонента класса TChart;

б) на канве (свойство Canvas) компонента класса TPaintbox или класса TImage.

Замечание.

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

5.Продемонстрировать все результаты работы преподавателю.

6.Оформить отчет и защитить лабораторную работу преподавателю.

 

Варианты заданий для выполнения работы:

1. y= (x+3)/(x-2);

2.y=3+2/x+3/(x*x);

3.y=1/(3*x*x+2*x+1);

4. y=1/(x*x+2*x+1);

5. y=1/(x*x+3*x+1);

6. y=x/(3*x*x+2*x+1);

7. y=x/(x*x+2*x+1);

8. y=x/(x*x+3*x+1);

9. y=x/(x*x-2*x+1);

10. y=x/(x*x-3*x+1);

 

 

Контрольные вопросы:

1.Расскажите о возможностях компонента класса TImage.

2.Визуальный компонент класса TPaintBox-- его назначение, свойства и методы.

3.Опишите возможности компонента класса TChart.

 


 

Приложение 1
Справка по работе с основным набором визуальных компонентов Delphi, требуемых при выполнении лабораторных работ

 

 

TLabel

 

Компоненты класса TLabel (метки) предназначены для размещения на форме различного рода текстовых надписей. С компонентом может быть связан оконный управляющий элемент, который выбирается при нажатии Alt+Буква, где Буква – выделенная подчеркиванием буква в тексте метки. Такие символы в терминологии Windows называются акселераторами.

 

Свойства компонента:

 

propertyAutoSize: Boolean; Указывает, будет ли метка изменять свои размеры в зависимости от помещенного в ее свойство Caption
propertyFocusControl: TWinControl; Содержит имя оконного компонента, который связан с меткой акселератором.
TTextLayout = (tlTop, tlCenter, tlBottom); propertyLayout: TTextLayout; Определяет выравнивание текста по вертикали относи­тельно границ метки: tlTop –текст располагается вверху; tlCenter – текст центрируется по вертикали; tlBottom – текст располагается внизу.
propertyShowAccelChar: Boolean; Если содержит True, символ & в тексте метки предшест­вует символу-акселератору.
propertyTransparent: Boolean; Определяет прозрачность фона метки. Если False, фон закрашивается собственным цветом Color, в противном случае используется фон родительского компонента.
propertyWordwrap: Boolean; Разрешает/запрещает разрыв строки на границе слова. Для вывода многострочных надписей задайте AuroSize = False, Wordwrap = True и установите подходя­щие размеры метки.

 


 

TEdit

 

Компонент класса TEdit представляет собой однострочный редактор текста. С его помощью можно вводить и/или отображать достаточно длинные текстовые строки.

 

Свойства компонента:

 

propertyAutoSelect: Boolean; Указывает, будет ли выделяться весь текст в момент получения компонентом фокуса ввода.
propertyAutoSize: Boolean; Если True и BorderStyle = bsSingle, высота компо­нента автоматически меняется при изменении свойства Font.Size.
TBorderStyle = bsNone..bsSingle; propertyBorderStyle: TBorderStyle; Определяет стиль обрамления компонента: bsNone - нет обрамления; bsSingle - компонент обрамляется одной линией.
TEditCharCase = (ecNormal, ecUpperCase, ecLowerCase); propertyCharCase: TEditCharCase; Определяет автоматическое преобразование высоты букв: ecNormal –нет преобразования; ecUpperCase - все буквы заглавные; ecLowerCase -все буквы строчные. Правильно работает с кириллицей.
propertyHideSelection: Boolean; Если False, выделение текста сохраняется при потере фокуса ввода.
propertyMaxLength: Integer; Определяет максимальную длину текстовой строки. Если имеет значение 0, длина строки не ограничена.
propertyModified: Boolean; Содержит True, если текст был изменен.
propertyOnChange: TNotifyEvent; Определяет обработчик события OnChange, которое возникает после любого изменения текста.
propertyOEMConvert: Boolean; Содержит True, если необходимо перекодировать текст из кодировки MS-DOS в кодировку Windows и обратно.
propertyPasswordChar: Char; Если символ PasswordChar определен, он заменяет собой любой символ текста при отображении в окне. Используется для ввода паролей.
propertyReadonly: Boolean; Если содержит True, текст не может изменяться.
propertySelLength: Integer; Содержит длину выделенной части текста.
propertySelStart: Integer; Содержит номер первого символа выделенной части текста.
property Text: String; Содержит текст.

 

Методы компонента:

 

procedureClear; Удаляет весь текст.
procedureClearSelection; Удаляет выделенный текст.
procedureCopyToClipboard; Копирует выделенный текст в Clipboard.
procedureCutToClipboard; Копирует выделенный текст в Clipboard, после чего удаляет выделенный текст из компонента.
functionGetSelTextBuf(Buffer: PChar; BufSize: Integer): Integer; Копирует не более BufSize символов выделенно­го текст в буфер Buffer.
procedurePasteFromClipboard; Заменяет выделенный текст содержимым Clipboard, а если нет выделенного текста, копи­рует содержимое Clipboard впозицию текстово­го курсора.
procedureSelectAll; Выделяет весь текст.
procedure SetSelTextBuf(Buffer: PChar); Заменяет выделенный текст содержимым Buffer, а если нет выделенного текста, копирует содер­жимое Buffer в позицию текстового курсора.

 

 

TButton

 

Кнопки TButton широко используются для управ­ления программами.

 

Свойства компонента:

 

propertyCancel: Boolean; Если имеет значение True, событие OnClick кнопки возникает при нажатии клавиши Esc.
propertyDefault: Boolean; Если имеет значение True, событие ОпСliсk кнопки возникает при нажатии клавиши Enter.
TModalResult = Low(Integer)..High(Integer); propertyModalResult: TModalResult; Определяет результат, с которым было закрыто модальное окно (см. ниже поясне­ние).

 

В терминологии Windows модальными окнами называются такие специальные окна, которые, раз появившись на экране, блокируют работу пользователя с другими окнами вплоть до своего закрытия. Обычно с их помощью реализуется диалог, требующий от пользова­теля принятия некоторого решения. Для этого в состав модального окна включается несколько кнопок. Если у кнопки определено свой­ство ModalResult, нажатие на нее приводит к закрытию модального окна и возвращает в программу значение ModalResult как результат диалога с пользователем. В Delphi определены следующие стандарт­ные значения ModalResult:

 

mrNone   mrOk mrCancel mrAbort mrRetry Модальное окно не закрывается. Была нажата кнопка ОК. Была нажата кнопка Cancel. Была нажата кнопка Abort. Была нажата кнопка Retry. mrIgnore mrYes mrNo mrAll Была нажата кнопка Ignore. Была нажата кнопка Yes. Была нажата кнопка No. Была нажата кнопка Аll.

 

 

TCheckBox

 

Независимый переключатель TCheckBox использу­ется для того, чтобы пользователь мог указать свое решение типа Да/Нет или Да/Нет/Не знаю. Это решение отражается в свойстве State компонента, доступном как для чтения, так и для записи. В составе диалогового окна может быть несколько компонентов TCheckBox. Состояние любого из них не зависит от состояния остальных, поэтому такие переключатели называются независимыми.

Свойства компонента:

 

TLeftRight = (taLeftJustify, taRightJustify); propertyAlignment: TLeftRight; Определяет положение текста: taLeftJustify – с левой стороны компонента; taRightJustify – с правой стороны.
propertyAllowGrayed: Boolean; Разрешает/запрещает использование состоя­ния cbGrayed (He знаю).
propertyChecked: Boolean; Содержит выбор пользователя типа Да/Нет. Состояния cbUnchecked и cbGrayed отража­ются как False.
TCheckBoxState = (cbUnchecked, cbChecked, cbGrayed); propertyState: TCheckBoxState; Содержит состояние компонента: cbUnchecked – нет; cbChecked – да; cbGrayed – не знаю.

 

TRadioButton

 

В отличие от TCheckBox, компоненты TRadioButton представляют собой зависимые переключатели, предназначенные для выбора одного из нескольких взаимоисключающих решений. На форму (точнее, в компонент-контейнер) помещается по меньшей мере два таких компонента. Они могут находиться в одном из двух состояний, определяемом свойством Checked. Если в одном компо­ненте это свойство принимает значение True, во всех других компо­нентах, расположенных в том же контейнере, свойства Checked при­нимают значения False.

Помимо свойства Checked компонент TRadioButton имеет еще одно специфичное свойство – Alignment, аналогичное такому же свойству TCheckBox.

 

 

TMemo

 

Обойтись простым текстовым полем удается не всегда. Если пользователь должен ввести большой объем информации (например полный почтовый адрес или произвольный комментарий), ему может понадобиться несколько строк текста. В таком случае следует использовать компонент ТМеmо.

При вводе текста для перехода на новую строку (к новому абзацу) обычно исполь­зуется клавиша ENTER. Однако в диалоговых окнах Windows эта клавиша часто применяется для завершения ввода. Способ использования клавиши ENTERопреде­ляется значением свойства WantReturns. Если оно имеет значение true, то клавиша ENTERпозволяет переходить к новой строке внутри текстовой области, в противном случае она служит для завершения ввода и перехода к следующему элементу управле­ния, а для перехода к новой строке применяется комбинация клавиш CTRL+ENTER.

Главное свойство данного компонента – Lines (Строки), имеющее тип TStrings. В нем хранится список строк, введенных пользователем. Эти строки можно обрабатывать всеми методами, доступными в классе TStrings, например сохранять в файле:

Memo1.Lines.SaveToFile('С: \Memo.TXT');

 

Наличие у текстовой области полос прокрутки задается в свойстве ScrollBars.

 

Значение Вид текстовой области
ssNone Полосы прокрутки отсутствуют
ssHorizontal Имеется горизонтальная полоса прокрутки
ssVertical Имеется вертикальная полоса прокрутки
ssBoth Имеются две полосы прокрутки

 

Если включена горизонтальная полоса прокрутки, значение свойства WordWrap игно­рируется. Это свойство определяет, будет ли выполняться автоматический перенос слов на новую строку при достижении правой границы области (при этом никаких символов новой строки в текст не добавляется – перенос отображается только на экране).

При выделении фрагмента текста в текстовой области в свойство SelStart записывается позиция первого выделенного символа, а в свойство SelLength – число выделяемых символов. Выделенный текст доступен через свойство SelText (тип string).

Для выделения всего текста применяется метод SelectAll, для удаления выделенного текста – метод ClearSelection.

Чтобы очистить содержимое текстовой области, используется метод Clear, чтобы отменить последние изменения – метод Undo, а чтобы очистить буфер, хранящий историю изменений, и сделать такую отмену невозможной – метод ClearUndo.

Группа методов предназначена для работы с буфером обмена Windows. Для копирования выделенного текста в буфер обмена применяется метод CopyToClipboard, для вырезания текста – метод CutToClipboard, для вставки текста из буфера – метод PasteFromClipboard.

Когда в текстовой области происходит изменение текста, генерируется событие OnChange.

TListBox

 

С помощью компонента список (TListBox) пользователь может выбрать один или несколько его элементов. Если элементов много и они не умещаются в отведенной для них области, то автоматически добавляется вертикальная полоса прокрутки. Элементы списка можно добавлять или удалять динамически.

Свойство Items имеет тип TStrings и содержит список строк, выводимых на экран. Во время разработки программист может редактировать свойство Items с помощью редакто­ра списка строк (String List editor). Во время выполнения элементы списка можно добав­лять с помощью метода Add ( ) класса TStrings, а удалять – с помощью метода De­lete ( ) этого же класса. Свойство ItemIndex содержит порядковый номер выделенного элемента, для первого элемента значение ItemIndex равно 0. Если ни один элемент не вы­делен, то значение ItemIndex равно – 1. Свойство MultiSelect определяет, может ли пользо­ватель выделить более одного элемента списка. Если значение MultiSelect равно True, то свойство ItemIndex является индексом выделенного элемента, имеющего фокус. По умолчанию ItemIndex имеет значение 0. Свойство SelCount содержит количество выде­ленных элементов, а свойство Selected определяет, выделен ли конкретный элемент. Свойство Sorted определяет, будут ли элементы выведены в алфавитном порядке. Свой­ство Style задает внешний вид элементов. По умолчанию элементы выводятся в виде строк, однако, изменив свойство Style, их можно вывести в графическом виде или с раз­ной высотой. Ниже приведен код, иллюстрирующий использование списка.

 

TComboBox

 

Компонент поле со списком (TComboBox) объединяет возможности поля ввода и про­кручиваемого раскрывающегося списка. Пользователь может или выбрать элемент списка или ввести его непосредственно в поле ввода. Поэтому поле со списком обладает многими свойствами и методами, входящими в рассмотренные раньше компоненты TEdit и TListBox. В поле со списком свойство Style определяет внешний вид списка и наличие поля ввода

Заменим в предыдущем примере список полем со списком. В этом случае для добавления нового элемента пользователь должен ввести его название в поле ввода и нажать клавишу Enter. Приведенный ниже код иллюстрирует применение поля со списком.

 

 


Поделиться:



Популярное:

Последнее изменение этой страницы: 2017-03-11; Просмотров: 1268; Нарушение авторского права страницы


lektsia.com 2007 - 2024 год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! (0.149 с.)
Главная | Случайная страница | Обратная связь