10864

Рисование графиков в Delphi

Лабораторная работа

Информатика, кибернетика и программирование

Лабораторная работа № 2 Рисование графиков в Delphi Точка Поверхности на которую программа может осуществлять вывод графики соответствует объект Canvas. Свойство pixels представляющее собой двумерный массив типа TColor содержит информацию о цвете каждой точки графической...

Русский

2013-04-02

107.5 KB

62 чел.

Лабораторная работа № 2

«Рисование графиков в Delphi»

Точка

Поверхности, на которую программа может осуществлять вывод графики, соответствует объект Canvas. Свойство pixels, представляющее собой двумерный массив типа TColor, содержит информацию о цвете каждой точки графической поверхности. Используя свойство Pixels, можно задать тре-

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

Form1.Canvas.Pixels[10,10]:=clRed

окрашивает точку поверхности формы в красный цвет.

Размерность массива pixels определяется размером графической поверхности. Размер графической поверхности формы (рабочей области, которую также называют клиентской) задается значениями свойств ciientwidth и ClientHeight, а размер графической поверхности компонента image — значениями свойств width и Height. Левой верхней точке рабочей области формы соответствует элемент pixels [0,0], а правой нижней -Pixels[Ciientwidth - 1,ClientHeight - 1].

Свойство Pixels можно использовать для построения графиков. График строится, как правило, на основе вычислений по формуле. Границы диапазона изменения аргумента функции являются исходными данными. Диапазон изменения значения функции может быть вычислен. На основании этих данных можно вычислить масштаб, позволяющий построить график таким образом, чтобы он занимал всю область формы, предназначенную для вывода графика.

Например, если некоторая функция f(x) может принимать значения от нуля до 1000, и для вывода ее графика используется область формы высотой в 250 пикселов, то масштаб оси Y вычисляется по формуле: т = 250/1000. Таким образом, значению f(x) = 70 будет соответствовать точка с координатой Y =233. Значение координаты Y вычислено по формуле

Y= h -f(x) х т = 250 - 70х(250/1000),

где h - высота области построения графика.

Обратите внимание на то, что точное значение выражения 250 - 70х(250/1000) равно 232,5. Но т. к. индексом свойства pixels, которое используется для вывода точки на поверхность Canvas, может быть только целое значение, то число 232,5 округляется к ближайшему целому, которым является число 233.

Следующая программа, текст которой приведен в листинге 10.5, используя свойство pixels, выводит график функции у = 2 sin(jc) e*/5. Для построения графика используется вся доступная область формы, причем если во время работы программы пользователь изменит размер окна, то график будет выведен заново с учетом реальных размеров окна.

Листинг 10.5. График функции

unit grfunc_;

interface

Windows, Messages, SysUtils, Classes,

Graphics, Controls, Forms, Dialogs;

type

TForm1 = class(TForm)

procedure FormPaint(Sender: TObject);

procedure FormResize(Sender: TObject);

private

{ Private declarations }

public

{Public declarations }

end;

var

Forml: TForml;

implementation

{$R *.DFM}

// Функция, график которой надо построить

Function f(x:real):real;

begin

f:=2*Sin(x)*exp(x/5) ;

end;

// строит график функции

procedure GrOfFunc;

var

x1,x2:real; // границы изменения аргумента функции

y1,y2:real; // границы изменения значения функции

х:real; // аргумент функции

у:real; // значение функции в точке х

dx:real; // приращение аргумента

l,b:integer; // левый нижний угол области вывода графика

w,h:integer; // ширина и высота области вывода графика

mx,my:real; // масштаб по осям X и Y

х0,у0:integer; // точка — начало координат

begin

// область вывода графика

l:=10; // X — координата левого верхнего угла

b:=Forml.ClientHeight-20;

//У — координата левого верхнего угла

h:=Forml.ClientHeight-40; // высота

w:=Forml.Width-40; // ширина

x1:=0; // нижняя граница диапазона аргумента

х2:=25; // верхняя граница диапазона аргумента

dx:=0.01; // шаг аргумента

// найдем максимальное и минимальное значения

// функции на отрезке [x1,x2]

y1:=f(xl); // минимум

y2:=f(xl); //максимум

x:=x1;

repeat

У := f (х);

if у < yl then yl:=y;

if у > у2 then y2:=y;

х:=x+dx; until (x >= х2);

// вычислим масштаб

my:=h/abs(y2-yl); // масштаб по оси Y

mx:=w/abs(x2-xl); // масштаб по оси X

х0:=1;

у0:=b-Abs(Round(y1*my)) ;

with form1.Canvas do

begin

// оси

MoveTo(l,b);LineTo(l,b-h);

MoveTo(x0,y0);LineTo(x0+w,y0);

TextOut(l+5,b-h,FloatToStrF(y2,ffGeneral,6,3));

TextOut(l+5,b,FloatToStrF(yl,ffGeneral,6,3));

// построение графика

x:=xl; repeat

y:=f(x);

Pixels[x0+Round(x*mx),y0-Round(y*my)]:=clRed;

x:=x+dx;

until (x >= x2);

end;

end;

procedure TForm1.FormPaint(Sender: TObject);

begin

GrOfFunc; end;

// изменился размер окна программы

procedure TForm1.FormResize(Sender: TObject);

begin

// очистить форму

forml.Canvas.FillRect(Rect(0,0,ClientWidth,

ClientHeight));

// построить график

GrOfFunc;

end;

end.

Основную работу выполняет процедура GrOfFunc, которая сначала вычисляет максимальное (у2) и минимальное (yl) значения функции на отрезке [x1l,x2]. Затем, используя информацию о ширине (Forml.Clientwidth -40) и высоте (Form1.ClientHeight - 40) области вывода графика, вычисляет масштаб по осям X (mх) иY(mу).

Высота и ширина области вывода графика определяется размерами рабочей (клиентской) области формы, т. е. без учета области заголовка и границ. После вычисления масштаба процедура вычисляет координату у горизонтальной оси (уо) и вычерчивает координатные оси графика. Затем выполняется непосредственное построение графика (рис. 10.10).

Вызов процедуры GrOfFunc выполняют процедуры обработки событий onPaint и onFormResize. Процедура TForm1. FormPaint обеспечивает вычерчивание графика после появления формы на экране в результате запуска программы, а также после появления формы во время работы программы, например, в результате удаления или перемещения других окон, полностью или частично перекрывающих окно программы. Процедура TForm1.FormResize обеспечивает вычерчивание графика после изменения размера формы.

Рис. 10.10. График, построенный процедурой GrOfFunc

Приведенная программа довольно универсальна. Заменив инструкции в теле функции f (х), можно получить график другой функции. Причем независимо от вида функции ее график будет занимать всю область, предназначенную для вывода.

Примечание

Рассмотренная программа работает корректно, если функция, график которой надо построить, принимает как положительные, так и отрицательные значения. Если функция во всем диапазоне только положительная или только отрицательная, то в программу следует внести изменения. Какие — пусть это будет упражнением для читателя.

Задания по вариантам:

Примечание. Созданные программы необходимо сохранить. Они Вам понадобятся в дальнейшем.

Задание 1. Составьте программу построения кусочно-заданной функции:

   

  

  

  

  

   

  

  

  

  

Задание 2.Составьте программу построение функции с учетом области определения y=F(x):

1. y=ln((1+x)/(1-sinx)).     6. y=lg((1-x)/(1+sinx)).

2. y=(x+2lnx)/(x*x-4).     7. y=(x-2ln(x-5))/(x*x-4).

3. y=(1+sinx)/cosx.      8. y=(1-cosx)/sinx.

4. y=arcsin(1/(2-x)).      9. y=arccos(1/(2+x)).

5. y=(x-lg(1-x))/(sinx-cosx).     10. y=(x-lg(1+x))/(sinx+cosx).

11. y=ln((1+x)/(1+sin2x)).     16. y=lg((1+x)/(1-sinx)).

12. y=(x+2lnx)/(x*x-4lnx).     17. y=(x+2ln(x+5))/(-x*x+4).

13. y=lnx-(1+sinx)/cosx.     18. y=(1-lncosx)/sinx.

14. y=arccos(2-1/x).      19. y=arcsin(cos(1/(2+x))).

15. y=(x+lg(-x))/(sinx+cosx).    20. y=lg(1+x)/(sin2x+cosx).


 

А также другие работы, которые могут Вас заинтересовать

25677. СОЕДИНИТЕЛЬНЫЕ ТКАНИ 30.5 KB
  Соединительные ткани выполняют различные функции: трофическую защитную опорную биомеханическую пластическую морфогенетическую. Пластическая функция соединительной ткани выражается в адаптации к меняющимся условиям существования регенерации участии в замещении дефектов органов при их повреждении. Разновидности соединительной ткани различаются между собой составом и соотношением клеток волокон а также физикохимическими свойствами аморфного межклеточного вещества.
25678. Спинной мозг 40 KB
  На периферии спинного мозга располагается более светлое белое вещество. В процессе развития спинного мозга из нервной трубки образуются нейроны группирующиеся в 10 слоях или в пластинах пластины Рекседа. Такое деление на пластины дополняет организацию структуры серого вещества спинного мозга основывающейся на локализации ядер. Серое вещество спинного мозга состоит из тел нейронов безмиелиновых и тонких миелиновых волокон и нейроглии.
25679. центральный орган лимфо. 45.5 KB
  Из костномозговых предшественников Тлимфоцитов в нем происходит антигеннезависимая дифференцировка их в Тлимфоциты разновидности которых осуществляют реакции клеточного иммунитета и регулируют реакции гуморального иммунитета. Удаление тимуса тимэктомия у новорожденных животных вызывает резкое угнетение пролиферации лимфоцитов во всех лимфатических узелках кроветворных органов исчезновение малых лимфоцитов из крови резкое уменьшение количества лейкоцитов и другие характерные признаки атрофия органов кровоизлияния и пр. На 1112...
25680. Ткань 34 KB
  Эпителиальная ткань образует кожные покровы и выстилает изнутри полые внутренние органы выполняя защитную функцию функцию обмена веществ между организмом и внешней средой. Соединительная ткань состоит из клеток и неклеточного вещества с преобладанием последнего. В эту группу входят: собственно соединительная ткань костная жировая а также хрящ сухожилия связки кровь и лимфа. Хрящ состоит из разнообразных плотных волокон и клеток вместе с костной тканью придает прочность позвоночнику и другим частям скелета.
25681. Толстая кишка 38.5 KB
  Одной из функций толстой кишки является выделительная. Через слизистую оболочку этой кишки выделяется ряд веществ например кальций магний фосфаты соли тяжелых металлов и т. Эпителий ободочной кишки и тазовой части прямой кишки развивается из энтодермы. В кожной и промежуточной зонах анальной части прямой кишки эпителий имеет эктодермальное происхождение.
25682. Тонкая кишка 57.5 KB
  Клетки кишечного эпителия у 4недельного эмбриона не дифференцированы и характеризуются высокой пролиферативной активностью. В это время среди эндокриноцитов преобладают переходные клетки с недифференцированными гранулами выявляются ЕСклетки Gклетки и Sклетки. В плодном периоде преобладают ЕСклетки большинство из которых не сообщается с просветом крипт закрытый тип; в более позднем плодном периоде появляется открытый тип клеток. Крипты содержат камбиальные элементы эпителия и дифференцирующиеся из них клетки.
25683. солевом обмене веществ. 44.5 KB
  Кроме того эти ткани принимают участие в водносолевом обмене веществ. Хрящевые ткани входят в состав органов дыхательной системы суставов межпозвоночных дисков и др. В свежей хрящевой ткани содержится около 7080 воды 1015 органических веществ и 47 солей.
25684. Эмбриогенез 239.5 KB
  Вместе с тем появляются особенности отличающие развитие человека от развития других представителей позвоночных. Процесс внутриутробного развития зародыша человека продолжается в среднем 280сут 10 лунных месяцев. Эмбриональное развитие человека принято делить на 3 периода: начальный 1я неделя зародышевый 2 8я неделя плодный с 9й недели развития до рождения ребенка.