Створення програм із графічним відображенням даних

Про матеріал

Конспект уроку та презентація до теми "Створення програм із графічним відображенням даних". Підійде для 8 класу при вивченні Lazarus

Перегляд файлу

Тема. Створення програм із графічним відображенням даних.

Мета: навчальна: сформувати уявлення про необхідність відновлення та масштабування зображення при зміні розмірів форми, розуміння алгоритму масштабування зображення, вміння створювати обробник події OnPaint для форми, створювати зображення в циклі;

розвивальна: розвивати логічне мислення та креативність;

виховна: виховувати інформаційну культуру, дбайливе ставлення до комп’ютерної техніки;

компетентнісна:

Тип уроку: Комбінований.

Обладнання та наочність: дошка, комп’ютери, мережа Інтернет, підручник, навчальна презентація.

Програмне забезпечення: Середовище програмування Lazarus, браузер.

Хід уроку

І. Організаційний етап

Привітання, перевірка присутніх, перевірка готовності учнів до уроку

ІІ. Актуалізація опорних знань

Тестування у програмі MyTestX

ІІІ. Мотивацій навчальної діяльності

Під час зміни розмірів форми в процесі виконання програми поверхня малювання стає недійсною і частина малюнка може бути втрачена.

На цьому уроці ви дізнаєтесь, як відновлювати малюнок при активації форми і як підлаштовувати розміри малюнка під поточні розміри форми. Ви дізнаєтесь, як за допомогою генератора випадкових чисел створювати в циклі цікаві абстрактні малюнки.

IV. Вивчення нового матеріалу

Пояснення вчителя з елементами демонстрування презентації (використовуються можливості локальної мережі кабінету або проектор)

У попередньому параграфі ви малювали графічні примітиви на формі в результаті виконання процедури обробника події OnClick для кнопки. При перекритті вікна форми іншими вікнами або зміні розмірів форми частина зображення може бути втрачена. Існують способи для відновлення зображення під час активізації форми та налаштування розмірів зображення під поточні розміри форми.

 Перемальовування форми

Подія OnPaint відбувається за необхід ності перемалювати форму, наприклад, у разі її активізації, якщо до цього ча стина форми була закрита іншими вікнами.

Для створення процедури обробки події  OnPaint потрібно:

1) клацнути мишею на формі;

2) у  вікні Інспектор об’єктів перейти на вкладку Події;

3) д вічі клацнути в полі події OnPaint (рис. 45.1).

Створена процедура TForm1.FormPaint виконуватиметься під час завантаження форми і при кожному її перемальовуванні під час зміни розмірів або відображення форми на екрані.

procedure TForm1.FormPaint (Sender: TObject);

begin   

Form1.Canvas. Rectangle (200,0,300,100);   

{ далі слідують команди для побудови малюнка }

end;

Для візуалізації процесу зміни розміру форми потрібно очистити полотно перед перемальовуванням форми нового розміру. Для цього в процедурі обробки події OnResize слід викликати метод Refresh (). Він очищує полотно і генерує подію OnPaint:

procedure TForm1.FormResize (Sender: TObject);

begin   

Refresh ();

end;

Намалювати різнокольорові лінії (відрізки) випадковим чином (рис. 45.2).

procedure TForm1.FormPaint (Sender: TObject);

const Num_Lines = 100; // кількість ліній

var i: Integer;

begin

{ ініціалізація генератора випадкових чисел }   

Randomize;   

For i := 0 to Num_Lines do   

begin        

Canvas.Pen.Color := RGBToColor(Random (256), Random (256), Random (256)); // випадковий вибір кольору       

Canvas.LineTo (Random (ClientWidth), Random (ClientHeight));

{ малювання відрізка з випадковими координатами кінців }   

end;

end;

procedure TForm1.FormResize (Sender: TObject);

begin       

Refresh ();

end;

 Масштабування зображення

Під час зміни розмірів форми в режимі виконання бажано, щоб розміри нашого малюнка підлаштовувалися під ці зміни. Властивості форми ClientWidth, ClientHeight визначають ширину і висоту області, на якій можна малювати.

Щоб малюнок масштабувався разом із формою, необхідно при виклику графічних методів указувати не абсолютні значення координат, а залежності їх координат від властивостей ClientWidth, ClientHeight.

Масштабувати малюнок за зразком (рис. 45.3, 45.4):

procedure TForm1.FormPaint (Sender: TObject);

const x = 10; y = 10; var dx, dy: Integer;

begin   

dx := Form1.ClientWidth div x;   

dy := Form1.ClientHeight div y;   

with Form1.Canvas do begin       

Font.Size := 20;

TextOut (0, dy, ‘ Hello!’);       

Pen.Color := clYellow;       

Pen.Width := 3;       

Brush.Color := clYellow;       

Ellipse (dx, 2*dy, 3*dx, 5*dy);       

MoveTo (dx, 2*dy);       

LineTo (3*dx, 5*dy);       

MoveTo (3*dx, dy);       

LineTo (dx, 5*dy);       

MoveTo (0, 4*dy);       

LineTo (4*dx, 3*dy);       

Brush.Style := bsClear;   

end;

end;

procedure TForm1.FormResize (Sender: TObject);

begin   

Refresh ();

end;

V. Фізкультхвилинка

VI. Засвоєння нових знань, формування вмінь

Практичне завдання. Робота за комп’ютером

  1.    Повторення правил безпечної поведінки за комп’ютером.
  2.    Інструктаж учителя.
  3.    Практична робота за комп’ютерами.

Вправа 45

Скласти програму для малювання в центрі форми чотирьох концентричних еліпсів, що зафарбовано різними кольорами (рис. 1).

1) Створіть новий проект. Змініть заголовок форми на «Еліпси».

2) Створіть процедуру обробки події OnPaint для форми.

3) У програмному коді процедури запишіть оператори для малювання чотирьох еліпсів (рис. 2).

procedure TForm1.FormPaint (Sender: TObject);

const x =  10; y = 10; // умовне розбиття форми на комірки 

var dx, dy, i: Integer;

begin    

dx := Form1.ClientWidth div x;    

dy := Form1.ClientHeight div y;    

For i := 1 to 4 do begin        

Canvas. Brush.Color := RGBToColor (255, 255 div i, 255 div i);        

Canvas. Ellipse (i*dx, i*dy, (10-i) *dx, (10-i) *dy);    

end;

end;

procedure TForm1.FormResize (Sender: TObject);

begin    

Refresh (); 

end;

4) Змініть кольори заливки еліпсів на відтінки зеленого.

5) Запустіть проект на виконання. Перевірте роботу програми. Збережіть проект у папці Вправа 45.

6) Змініть програмний код таким чином, щоб виконувалось малювання п’яти вкладених прямокутників.

  1.    Вправи для очей.

VIІ. Підсумки уроку

Питання для самоперевірки

1. Як створити процедуру обробки події OnPaint для форми?

2. Яку дію виконує метод Refresh ()?

3. Якими властивостями визначаються розміри форми?

4. Як запрограмувати масштабування зображення?

5. Як запрограмувати задавання кольору малювання випадковим чином?

6. Напишіть фрагмент програми для заповнення форми різнокольоровими точками з випадковими координатами.

 

VІІI. Домашнє завдання

Підручник § 45 ст. 220-223

 

ІХ Оцінювання роботи учнів

 

 

Зміст слайдів
Номер слайду 1

Створення програм із графічним відображенням даних

Номер слайду 2

Створення програм із графічним відображенням даних. У попередньому параграфі ми викликали методи малювання графічних примітивів із процедури обробника події Button1. Click, тобто малювання виконувалось при клацанні кнопки. Але при перекритті вікна форми іншими вікнами або зміні розмірів форми частина малюнку може бути втрачена. Щоб цьому запобігти, краще створювати обробник події On. Paint для форми.

Номер слайду 3

Перемальовування форми. Подія On. Paint генерується за необхідності перемалювати форми, наприклад у разі активізації форми, якщо до цього частина її була закрита іншими вікнами. Для створення процедури TForm1. Form. Paint потрібно виділити форму, у вікні Інспектор об'єктів перейти на сторінку Події і двічі клацнути в полі навпроти події On. Paint.

Номер слайду 4

Перемальовування форми. Отримана процедура TForm1. Form. Paint виконуватиметься під час завантаження форми і при кожній зміні розмірів або видимості форми.procedure TForm1. Form. Paint (Sender: TObject);begin form1. Canvas. Rectangle (200,0,300,100); {тут — решта команд для побудови малюнка}end;

Номер слайду 5

Перемальовування форми. Під час зміни розмірів форми в процесі виконання програми поверхня малювання стає недійсною, і малюнок зникає. Щоб уникнути цього, в обробнику події On Resize, яка при цьому виникає, слід викликати метод Refresh (). Він очищує полотно і генерує подію On. Paint:procedure TForm1. Form. Resize (Sender: TObject);begin Refresh ();end;

Номер слайду 6

Масштабування зображення. Під час зміни розмірів форми в режимі виконання бажано, щоб розміри нашого малюнка підлаштовувалися під ці зміни. Властивості форми: Client. Width. Client. Height. Визначає ширину області, на якій можна малювати. Визначає висоту області, на якій можна малювати. Щоб малюнок масштабувався разом із формою, необхідно при виклику графічних методів указувати не абсолютні значення координат, а їх залежності від властивостей Client. Width, Client. Height.

Номер слайду 7

Масштабування зображення. Масштабувати малюнок за зразком:procedure TForm1. Form. Paint (Sender: TObject);const x = 10; у = 10;var dx, dy: Integer;begin dx := Form1. Client. Width div x; dy := Form1. Client. Height div y; with Form1. Canvas do begin Font. Size := 20; Text. Out (0, dy, ' Hello!'); Pen. Color := cl. Yellow; Pen. Width := 3;

Номер слайду 8

Продовження Brush. Color := cl. Yellow; Ellipse (dx, 2*dy, 3*dx, 5*dy); Move. To (dx, 2*dy); Line. To (3*dx, 5*dy); Move. To (3*dx, dy); Line. To (dx, 5*dy); Move. To (0, 4*dy); Line. To (4*dx, 3*dy); Brush. Style := bs. Clear; end;end;procedure TForm1. Form. Resize (Sender: TObject);begin Refresh ();end;

Номер слайду 9

Масштабування зображення. Намалювати різнокольорові лінії випадковим чином. procedure TForm1. Form. Paint (Sender: TObject);const NUM_LINES = 100;var i: Integer;begin// ініціалізація генератора випадкових чисел. Randomize;for і := 0 to NUM_LINES — 1 dobegin Canvas. Pen. Color:=RGB (Random (256), Random (256), Random (256));

Номер слайду 10

Масштабування зображення. Продовження Canvas. Line. To (Random (Client. Width), Random (Client. Height)); end;end;procedure TForm1. Form. Resize (Sender: TObject);begin Refresh ();end;

Номер слайду 11

Питання для самоперевірки. Як створити обробник події On. Paint для форми?Яку дію виконує метод Refresh ()?Якими властивостями визначаються розміри форми?Як запрограмувати масштабування зображення?Як запрограмувати задавання кольору малювання випадковим чином?Напишіть фрагмент програми для заповнення форми різнокольоровими точками з випадковими координатами.

Номер слайду 12

Домашнє завдання. Проаналізувати§ 45, ст. 220-223

Номер слайду 13

Працюємо за комп’ютером. Сторінка222-223

Номер слайду 14

Дякую за увагу!

zip
Додано
3 січня
Переглядів
252
Оцінка розробки
Відгуки відсутні
Безкоштовний сертифікат
про публікацію авторської розробки
Щоб отримати, додайте розробку

Додати розробку