Erste Programme mit Lazarus Einführung in die Entwicklungsumgebung (IDE) Grundelemente der Programmiersprache Objekt-Pascal Übungen Helmut Paulus Speyer, 19.04.13
Teil 1 Einführung in die Lazarus-Entwicklungsumgebung Grundelemente der Programmiersprache Objekt-Pascal
3 Was ist Lazarus Lazarus ist eine plattformunabhängige freie, Delphi-ähnliche Entwicklungsumgebung für die Programmiersprache Objekt Pascal - eine Bezeichnung für mehrere Programmiersprachen- Varianten, die Pascal um Objektorientierte Programmierung erweitern, am bekanntesten davon ist die Programmiersprache der Entwicklungsumgebung Embarcadero Delphi, die Delphi genannt wurde. baut auf dem Free Pascal Compiler (FPC) auf, seine Komponentenbibliothek (LCL) ist sehr ähnlich zu der von Delphi (VCL), ist daher höchst kompatibel zu Delphi. Lazarus-Projekt: http://www.lazarus.freepascal.org/ Beschreibungen bei Wikipedia: Lazarus: http://de.wikipedia.org/wiki/lazarus_(entwicklungsumgebung) Objekt Pascal: http://de.wikipedia.org/wiki/object_pascal
4 Entwicklungsumgebung (IDE) Komponenten-Palette Formular (GUI) Objektinspektor Quelltextfenster
5 Lazarus-Projekt Lazarus erzeugt eine ganze Reihe von Dateien zur Verwaltung eines Programmierprojektes. Diese Dateien sollte man immer in einem eigenen Ordner speichern. (Quellcodedateien werden als Units bezeichnet.) Vorbereitende Schritte: 1. Ordner für das neue Projekt anlegen 2. Neues Projekt anlegen: Datei->Neu->Anwendung 3. Projektdateien sofort speichern: (1) Datei - Alles speichern (2) die vom System vorgeschlagen Namen unit1.pas und project1.lpr umbenennen (z. B.: ugui.pas und Rechner.lpr) u für Unit (Quelltextdatei) Neben den oben genannten beiden Dateien werden automatisch im Projektordner viele weitere Dateien angelegt und laufend von Lazarus verwaltet und aktualisiert. Beim Kompilieren wird aus den Projektdateien ein lauffähiges Programm Rechner.exe erzeugt, das anschließend ausgeführt werden kann.
6 Projektaufbau Ein Projekt besteht einzelnen Units, die einer Projektdatei verwaltet werden.
7 Projekt Rechner Speichern Sie den Ordner Rechner in ein eigenes Verzeichnis. Laden und starten Sie dann das Projekt in Lazarus und testen Sie seine Funktionalität. Analysieren Sie den Quelltext. Führen Sie auf dem Formular einen Doppelklick auf ein Button-Objekt aus. Was passiert? Fügen Sie einen weiteren Button hinzu. Lassen Sie sich über Projekt und.lpr Datei anzeigen den Quelltext der Projektdatei anzeigen. Was geschieht dort? Klicken Sie mit rechten Maustaste ins Formular und öffnen Sie mit Quelltext (.lfm) anzeigen die Formulardatei. Analysieren Sie den Inhalt.
8 Entwicklung der GUI Formular im Entwurfsmodus PAnzeige : TPanel Label1 : TLabel EErgebnis: TEdit form1 : TForm1 (Formular) Bplus : TButton GUI-Objekte (Komponenten der Komponentenpalette) werden auf dem Formular platziert und mit Hilfe des Objektinspektors (Register Eigenschaften) editiert. GUI-Objekte haben einen Namen und gehören ein Klasse an.
9 Komponenten Das Formular enthält Komponenten (GUI-Objekte) vom Typ: TForm, TEdit, TButton, TLabel, TPanel Sinnvolle Namenskonvention Der Editor gibt den GUI-Objekten automatisch Namen, z. B. TForm1, Label1, Button1, Button2 Die Objekte sollten im Objektinspektor mit sinnvollen Namen (nach Konventionen) belegt werden; z. B.: je nach Typ des Objekts einen Präfix: Name Funktionalität Bplus B für Button Schaltfläche EZahl1 E für Edit Text-Eingabefeld einzeilig PHinweis P für Panel Container für Komponenten Lergebnis L für Label Beschriftungsfeld Standardattribute (Eigenschaften) der GUI-Objekte: Caption Beschriftung einer Komponente (Aufschrift eines Buttons, Labels, Panels, ) Text Inhalt eines Textfeldes (Edit) Name Name, mit dem das Objekt im Programm angesprochen wird
10 Objekthierarchie Das Formularobjekt Form1 verwaltet alle anderen Objekte als Unterobjekte. Die zur Entwurfszeit definierten Attributwerte werden in der so genannten Formulardatei ugui.lfm gespeichert. Die Formulardatei wird automatisch erzeugt und gepflegt und hat immer den gleichen Namen wie die Quelltextdatei ugui.pas. object Form1: TForm1 Left = 354 Height = 176 Top = 248 Width = 229 Caption = 'Rechner' ClientHeight = 176 ClientWidth = 229 LCLVersion = '1.0.8.0... object EZahl1: TEdit Left = 8 Height = 23 Top = 64 Width = 90 TabOrder = 0 end object Bplus: TButton Left = 32 Height = 25 Top = 136 Width = 25 Caption = '+' OnClick = BplusClick TabOrder = 2 end end
11 Quelltext-Interface unit ugui; {$mode objfpc}{$h+} interface uses Classes, SysUtils, FileUtil, Forms, Controls, Graphics, Dialogs, StdCtrls, ExtCtrls; type { TForm1 } TForm1 = class(tform) Bplus: TButton; EZahl1: TEdit; EErgebnis: TEdit; Label2: TLabel; Label4: TLabel; Panel1: TPanel; procedure BplusClick(Sender: TObject); private { private declarations } public { public declarations } var Form1: TForm1;... end. Unit-Name - beim Speichern vom System geschrieben Einbinden von Systemunits (automatisch) Formularklasse TForm1 Basisklasse: Tform (automatisch) Attribute Ereignismethoden Variablendeklaration (Formularobjekt)
12 Quelltext-Implementation unit ugui;... var Form1: TForm1; implementation {$R *.lfm} { TForm1 } procedure TForm1.BplusClick(Sender: TObject); var z1: Extended; z2: Extended; sum: Extended; begin end. // Eingabe der Daten aus GUI-Objekten z1 := StrToFloat(EZahl1.Text); z2 := StrToFloat(EZahl2.Text); //Verarbeitung sum := z1 + z2; //Ausgabe EErgebnis.Text := FloatToStr(sum); *.lfm Formulardatei einbinden (automatisch) Ereignisbearbeitung Zugriff auf Attribute der GUI-Objekte
13 Projektverwaltung Ein Lazarus-Projekt besteht im aus mehreren Dateien, die im einfachsten Fall alle im gleichen "Projekt-Ordner" liegen. Die Verbindung wird durch die Projekt-Datei *.lpr hergestellt. program Rechner; {$mode objfpc}{$h+} uses {$IFDEF UNIX}{$IFDEF UseCThreads} cthreads, {$ENDIF}{$ENDIF} Interfaces, // this includes the LCL widgetset Forms, ugui { you can add units after this }; {$R *.res} begin RequireDerivedFormResource := True; Application.Initialize; Application.CreateForm(TForm1, Form1); Application.Run; end. Hier findet sich u. a. die Einbindung von Units und Ressourcen die Erzeugung des Fensterobjektes den Start des Programms (Hauptprogramm) Diese Datei wird automatisch vom System gepflegt!
14 Überblick: Dateien des Projekts Dateien des Projektordners (zum Teil automatisch angelegt) Bedeutung: Datei *.pas *.lfm *.lpr *.exe *.lpi *.lrs *.ppu Inhalt Pascal-Quellcode Datei (Unit) Lazarus Formulardatei wird zu jeder Unit, in der ein Formularobjekt definiert ist, automatisch angelegt, enthält die Formulareinstellungen einschließlich aller Komponenten (Lazarus Projektdatei) - das Hauptmodul (Verwaltung) des Projektes Das lauffähige Programm, zur Benutzung ist nur diese EXE-Datei erforderlich Lazarus Project Information - alle wichtigen Informationen des Lazarus-Projektes im XML-Format Resourcendatei des Lazarus-Projektes Compilierter Code der einer Unit, wird mit der Uses-Anweisung im Quellprogramm eingebunden
15 Ereignisverarbeitung Ereignisse werden in Object Pascal mit Hilfe von Methodenzeigern realisiert, das sind Attribute, die Referenzen auf Methoden anderer Objekte enthalten (Callback). Durch Doppelklick auf den Button Bplus wird eine Ereignismethode erzeugt und dem Methodenzeiger OnClick des Buttonobjekts zugewiesen. Sie ist eine Methode des Formularobjekts und wird vom Buttonobjekt durch Click ausgelöst. Ereignismethode des OnClick - Ereignisses procedure TForm1.BplusClick(Sender: TObject); begin... Der vom System gebildete Name enthält die Namen der auslösenden Komponente und des Methodenzeigers als Bestandteile. Der vorangestellte Klassenname TForm1 bindet die Prozedur an das Formularobjekt. Die Ereignisse des Button-Objekts sind Methodenzeiger, die mit Ereignismethoden verknüpft werden können.
16 Ereignisverarbeitung Implementierung procedure TForm1.BplusClick(Sender: TObject); Var z1, z2, z3, sum: double; begin // Einlesen der Daten aus GUI-Objekten z1:= StrToFloat(EZahl1.Text); z2:= StrToFloat(EZahl2.Text); //Verarbeitung sum := z1 + z2; //Ausgabe EErgebnis.Text := FloatToStr(sum); Deklaration der lokalen Variablen Ein-/ Ausgabesystem mit lokalen Variablen als temporären Zwischenspeichern!
17 Hilfesystem Kontextsensitive Hilfe mit F1 LCL - Lazarus Component Library FCL - Free Component Library RTL - Runtime Library Laufzeit Debugger Haltepunkte im Quelltext setzen, an Stellen, wo das Programm halten soll, in den Rahmen neben der Quelltextzeile klicken ab dieser Stelle können die Anweisungen schrittweise ausgeführt und mit Hilfe der Maus der Wert der Variablen angezeigt werden Einzelschritt
18 Standardkomponenten Klasse Beschreibung Wichtige Eigenschaften/ Methoden TButton Schaltfläche Caption, Color, Font, Enabled FLabel Anzeige von Text Caption, Color, Font Edit Einzeiliges Eingabefeld Text, Color, Font, MaxLength, Clear TMemo Mehrzeiliges Eingabefeld Text, Lines, Append, Clear TListBox Auswahlliste mit mehreren Textzeilen ein Items, Append, Clear TGroupBox Rahmen zur Anordnung von Objekten mit Gruppenbezeichnung. Caption, Color, Font TPanel Rahmen zur Anordnung von Objekten Caption, Color, Font TImage Anzeige von Grafiken Picture, Canvas, loadfromfile TShape Grafische Form Brush, Pen, Shape
19 Teil 2 Grundelemente Objekt-Pascal
20 Einstieg Variablendeklaration Bezeichner Wertzuweisung Kommentar procedure TForm1.BplusClick(Sender: TObject); var z1,z2, z3, sum : double; Datentyp begin // Einlesen der Daten aus GUI-Objekten z1 := StrToFloat(EZahl1.Text); z2 := StrToFloat(EZahl2.Text); //Verarbeitung sum := z1 / z2; //Ausgabe EErgebnis.Text:=FloatToStrF(sum,ffFixed,0,2); Trennzeichen Anweisungen string Typumwandlung double Variablendeklaration var Bezeichner : Datentyp; Wertzuweisung a := b ; Die Variablen müssen zuweisungskompatibel sein!
21 Grundelemente Konventionen für Bezeichner Es dürfen nur folgende Zeichen verwendet werden Buchstaben (aber keine Umlaute) Zahlen, diese aber erst nach mindestens einem Buchstaben Unterstrich (auch am Anfang) ansonsten keine Sonderzeichen wie,, ; Objekt-Pascal ist nicht kontextsensitiv! Gleichheitszeichen Wertzuweisungen := Beispiel: x := x + 1; Vergleich: = Blöcke und Kommentare Anweisungsblöcke begin Kommentare //. Bis Zeilenende { } mehrzeilig
22 Variablen und Konstanten Delphi-Variablen sind Platzhalter (Container) für Daten. Diese werden im Computer durch einen Speicherbereich repräsentiert und mit Hilfe eines Namens angesprochen. Variablen haben einen Namen, einen Datentyp, einen Gültigkeitsbereich und eine Lebensdauer. Bevor eine Variable benutzt werden kann, muss sie deklariert werden. Dabei werden der Name und der Datentyp festgelegt. Gleichzeitig wird ein Speicherbereich für den speziellen Datentyp reserviert. Bei Wertzuweisungen muss die Zuweisungs-Kompatibiliät gewährleistet sein. Variablendeklaration Programmabschnitt: var Syntax: var Bezeichner : Datentyp; Beispiel: var anzahl : integer; z1, z1 : double; Konstanten Syntax: const Bezeichner= wert; Beispiel: const pi = 3.14; Konstanten haben einen unveränderlichen Wert.
23 Elementare Datentypen Einfache Datentypen integer : Ganze Zahlen {17, -12} double : Fließkommazahlen {2.675. 1.5e-10} boolean : Wahrheitswerte {true, false} string : Zeichenkette { Hallo } Char : ASCII-Zeichen { A, #65, chr(65)} Aufzählungstypen (ordinale Typen) Statt Zahlen konstante Bezeichner verwenden: var farben : (blau, gelb, gruen, rot); Die Typen Integer und Char gehören ebenfalls zu den ordinalen Typen. Arrays / Reihungen (statisch) var Bezeichner : array[startind..endind] of Datentyp; So definierte Array ist statisch, die Anzahl der Elemente kann nicht mehr verändert werden. Start- und Endindex vom Typ Integer oder Aufzählungstyp Datentyp muss ein einfacher Typ sein!
24 Typumwandlungen Bei der Ein- und Ausgabe von Daten mit Hilfe von GUI-Objekten müssen häufig Datentypen konvertiert werden. Objekt-Pascal Funktionen: Funktion : Ergebnistyp StrToInt(Para) : integer IntToStr(Para) : string Beispiel groesse := StrToInt(EGroesse.Text); PAusgabe.Caption := FloatToStr(BMI); StrToFloat(Para) : real FloatToStr(Para) : string Formatierte Ausgabe: FloatToStrF() : string Char ASCII-Zeichen Chr(0..255) : Char Ord(ch) : integer Siehe Kontexthilfe PAusgabe.Caption := FloatToStrF(BMI, ffnumber, 8, 2); Ch := Chr(65); code := Ord( A );
25 Operatoren Arbeiten mit Zeichenketten Zeichenkettentexte werden in einfachen Anführungszeichen geschrieben. Beispiel: var Ausgabe : string; Ausgabe := Du hast ; Zeichenketten kann man mit + aneinander hängen. Ausgabe := Ausgabe + leider verloren ; Die Länge einer Zeichenkette bestimmt man mit der System-Funktion length(). Zugriff auf die einzelnen Zeichen einer Zeichenkette über den Index Ausgabe[2] u Arithmetische Operatoren integer / real +, -, *, / Division ( liefert einen Realtyp bei Anwendung auf Integer z. B. 12/4) integer div Ganzzahldivision Beispiel: 7 div 5 1 mod Modulo Beispiel: 4 mod 3 1
26 Operatoren Logische Operatoren AND true : wenn beide Operanden wahr OR true : wenn einer oder beide Operanden wahr NOT Negation des Operanden ( NOT a) Beispiel: var x : integer; teilbar : boolean; Vergleichsoperatoren = gleich <> ungleich < Kleiner <= kleiner gleich > Größer >= größer gleich teilbar := (x mod 3 = 0) AND (x mod 5 = 0); Funktionen zum Arbeiten mit Aufzählungstypen Ord() Pred() Succ() Low() High() gibt die Position des Bezeichners zurück gibt den Vorgänger zurück gibt den Nachfolger zurück gibt den niedrigsten Wert zurück gibt den höchsten Wert zurück
27 Laufzeitfehler Laufzeitfehler abfangen mit einem try-except Block Syntax try Anweisungen Except Fehlerbehandlung Beispiel: try z := StrToInt(Ezahl.Text); Except ShowMessage( Falsche Eingabe! ); Im except - Abschnitt kann die Art des Fehlers (der Exception) geprüft und individuell bearbeitet werden. except on EZeroDivide do...; on EMathError do...; on EConvertError do...; else...;
28 Fallunterscheidungen If then else Einseitig If Ausdruck then begin Anweisung; zweiseitig If Bedingung then begin Anweisung; end else begin Anweisung; Case of Mehrfachverzweigung case OrdWert of 1 :... ; 2 :... ; 3 :... ; else... ; kein Semikolon vor else
29 Schleifen Anfangsbedingung while Schleife while Bedingung do begin Anweisung; Zählschleife For Schleife for i := 1 to n do begin Anweisung; Endbedingung Repeat Schleife repeat Anweisung; until Bedingung; Schleifen über Arrays: var augen : array[1..6] of integer; for i := 1 to 6 do augen[i] := i;
30 Prozeduren und Funktionen Prozeduren procedure Bezeichner(Parameter); var lokale Variablen; begin Anweisungen; Deklarationsteil Anweisungsteil Die Parameterliste kann auch fehlen Funktionen Das Ergebnis muss einen einfachen Datentyp besitzen. function Bezeichner(Parameter): Datentyp; var lokale Variablen; begin Anweisung; result := Ergebnis; Rückgabentyp Rückgabewert Das Funktionsergebnis wird der Funkionsvariablen result zugewiesen.
31 Methoden Prozeduren und Funktionen als Methoden Bei Methoden steht vor dem Methodennamen der Name der Bezugsklasse setzt. Beispiel: Die Funktion Max als Funktion des Formular-Objekts vom Typ TForm1 TForm1 = class(tform) private { Private-Deklarationen} function Max(z1, z2 : integer): integer; public { Public-Deklarationen} Deklaration der Funktion als private Methode von TForm1 function TForm1.Max(z1,z2: integer): integer; begin if (z1 < z2) then result := z2 else result := z1; Implementierung der Funktion Als Methode von TForm1
32 Struktur einer Unit unit name; {$mode objfpc}{$h+} interface uses... Type... var... implementation uses... type... var... procedure end. Kopf Schlüsselwort unit Das System schriebt den Namen beim Speichern! Interface (Schnittstelle) Auf Alles, was hier deklariert ist, kann von außen (anderen Units) zugriffen werden. Typ Vereinbarungen gobale Variablen und Konstanten Implementation Lokale Deklarationen (nur innerhalb der Unit) Implementierung von Prozeduren, Funktionen (Methoden)
33 Projekt BMI Mit einem Programm soll der BodyMass-Index BMI berechnet werden. Eingaben: Ausgabe: Ablauf: Gewicht in Kg, Körpergröße in m BMI-Index Ereignisgesteuert Schreiben Sie ein Programm, das den Body-Mass-Index einer Person ausgibt.
34 Projekt BMI Ergänzen Sie das Programm mit einer Bewertung des BMI nach Alter. Benutzen Sie dazu die folgenden Grundlagen und die Kontexthilfe. Die Tabelle zeigt die wünschenswerte BMI-Werte für verschiedene Altersgruppen: Alter BMI 19-24 Jahre 19-24 25-34 Jahre 20-25 35-44 Jahre 21-26 45-54 Jahre 22-27 55-64 Jahre 23-28 >64 Jahre 24-29 Weitere Informationen unter: https://www.uni-hohenheim.de/wwwin140/info/interaktives/bmi.htm
35 Lösung procedure TGUI.BtberechnenClick(Sender: TObject); var gewicht, groesse, BMI : real; begin //Eingabe gewicht := StrToFloat(EdGewicht.Text); groesse := StrToFloat(EdGroesse.Text); //Verarbeitung BMI := gewicht/groesse/groesse; //Ausgabe PAusgabe.Caption := FloatToStr(BMI);
36 Projekt Zahlenraten Aufgabe: Es ist ein Programm zu entwickeln, das ein Zahlenratespiel simuliert. Anforderungen: 1. Der Computer bestimmt eine Zufallszahl (1..100), die der Spieler zu erraten hat. 2. Der Spieler hat er beliebig viele Versuche. 3. Nach jeder Zahleneingabe wird angegeben, ob die Zahl zu groß oder zu klein ist. 4. Hat der Spieler die Zahl erraten, so wird die Anzahl der Versuche und eine Bewertung ausgegeben. 5. Alle Ausgaben werden gelöscht, wenn ein neues Spiel begonnen wird. 6. Sicherheitsprüfung bei der Eingabe der Ratezahll. 7. Feldgröße über ein Edit-Feld eingelesen Datenmodell Anzahl der Versuche: Versuche : integer Zu erratende Zahl: Ratezahl : integer Zufallszahlen Funktion: random z := random(n); ganzzahlige Zufallszahl z mit 0 z < N r := random; Gleitkommazahl 0 r < 1
37 GUI und Datenmodell Problem Speicherung der Daten in den GUI-Objekten ist ineffektiv!!! Besser ist eine Trennung von GUI und Datenmodell Lösung (vorläufig) Realisierung eines "internen Datenmodell mit globalen Variablen als private Atribute des Formulars. Diese Variablen sind innerhalb des Formularobjekts global. Internes Datenmodell TGUI = class(tform) {Steuerelemente} procedure FormCreate(Sender: TObject); procedure BtEingabeClick(...); private { Private-Deklarationen} RateZahl : integer; Versuche : integer; public { Public-Deklarationen} Spieldaten als private Attribute des Formulars Lokale Variablen (temporäre Daten) procedure TGUI.BpruefenClick(...); var Zahl : integer; kommentar : string; begin //Eingabe Zahl := StrToInt(ETippZahl.text); // Verarbeitung Versuche := Versuche + 1; if Zahl = Ratezahl then...
38 Initialisierung bei Programmstart Ereignis OnCreate des Formulars Die zugehörige Ereignisprozedur FormCreate wird automatisch beim Start des Programms aufgerufen. Anwendungsbeispiel: Initialisierung des Zufallszahlengenerators des Systems durch randomize. Dadurch wird bei jedem Programmstart eine andere Zufallszahlenfolge erzeugt. procedure TGUI.FormCreate(Sender: TObject); begin randomize;
Teil 3 Übungen Helmut Paulus Speyer, 19.04.13
40 Aufgabe 1 Das Schaltjahr-Problem Die Schaltjahresregelung unseres Kalenders (Gregorianischer Kalender) lautet: Ein Schaltjahr ist ein Jahr, dessen Jahreszahl durch 4 ohne Rest teilbar ist. Ausgenommen davon sind die Jahrhundertwechsel, es sei denn, deren Jahreszahl ist durch 400 ohne Rest teilbar. Es kommt also alle 400 Jahre vor, dass ein Jahrhundertwechsel ein Schaltjahr erzeugt. Das Jahr 2000 ist ein solches Jahr. Zu entwickeln ist ein Programm, das nach Eingabe einer gültigen Jahreszahl prüft, ob dieses Jahr ein Schaltjahr ist.
41 Aufgabe 2 Die Entwicklung der Weltbevölkerung schreitet rasch voran: Im Jahr 2012 wurde die 7 Milliardengrenze überschritten. Zur Zeit wächst die Weltbevölkerung jährlich um ca. 1,2 %. Mit Hilfe eines kleinen Programms soll die jährliche Entwicklung verfolgt werden. Datenmodell: Jahr : integer; Population : double; WFaktor : double; Prototyp: Interaktionen: Aktuelle Werte eingeben und die Population des nächsten Jahres berechnen und anzeigen Aktuelle Werte eingeben und die Population des vorherigen Jahres berechnen und angezeigen Population in 10-Jahresschritten voraus- oder zurückberechnen
42 Aufgabe 3 Projekt 17 und 4: Es ist ein Programm zu entwickeln, das das bekannte Kartenspiel simuliert. Anforderungen 1. Spielkarten werden durch einen Würfel ersetzt (Wertbereich [1;...;6]). 2. Es werden Zahlen gewürfelt und aufsummiert. Der Spieler kann nach jedem Spielzug entscheiden, ob er aufhört oder weiter spielen will. 3. Ist die Summe größer als 21, so hat der Spieler verloren. Hört der Spieler bei einer Summe kleiner oder gleich 21 auf, wird noch eine Zahl gewürfelt. Ist die neue Summe immer noch kleiner oder gleich 21, so hat der Spieler verloren, andernfalls gewonnen. 4. Alle Ausgaben werden gelöscht, wenn ein neues Spiel begonnen wird.
Teil 4 Objektorientierte Programmierung mit Objekt-Pascal Übungen
44 Projekt Farbenmischer RGB-Farben bestehen aus einer Mischung von jeweils 3 Farben (rot - grün - blau). Jeder Farbkanal hat 256 Abstufungen: 0 255. Ziel: Zu entwickeln ist ein Programm, das beliebige RGB-Farben, sowie deren Komplementärfarbe nebeneinander angezeigt. Beispiele:
45 Modellklasse TFarbe Farbmodell TFarbe - rot : integer - gruen :integer - blau : integer; + constructor create + getfarbe : integer; + setfarbe(r, g, b : integer) + getrot : integer + getgruen: integer + getblau : integer private Attribute Konstruktor create öffentliche Methoden Festlegung von: Zugriffsrechten (- private; + public) Datentypen Signaturen (Parameter der Methoden) Konvention - vorangestelltes T bei Datentypen Konstruktoren - constructor (Schlüsselwort) Objekte werden mit Hilfe von Konstruktoren erzeugt. Dabei wird der Speicherbereich eines Objekts anlegt, werden die Attribute mit Standardwerten belegt, wird eine Referenz auf das Objekt zurückgeben.
46 Implementierung Eigene Unit für die Modellklasse: ufarbe.pas 1. Deklaration der Klasse im Interface unit ufarbe; Interface uses... type TFarbe = Class private rot, blau, gruen : integer; public constructor create; procedure setfarbe(r,g,b : integer); function getfarbe : integer; function getrot : integer; function getgruen: integer; function getblau : integer; TFarbe - Frot : integer - Fgruen :integer - Fblau : integer; + constructor create + getfarbe : integer; + setfarbe(r, g, b : integer) + getrot : integer + getgruen: integer + getblau : integer Implementation...
47 Implementierung 2. Implementierung der Methoden im Implementation - Bereich der Unit... implementation constructor TFarbe.create; begin rot := 255; gruen := 255; blau := 255; function TFarbe.getFarbe : Integer; begin result := blau*256*256+gruen*256+rot; procedure TFarbe.setFarbe(r,g,b : integer); begin rot := r mod 256; gruen := g mod 256; blau := b mod 256;...
48 GUI Formular-Unit: GUI-Objekte: TLabel TEdit TButton TShape TButton
49 Modellobjekt verwalten Das Formular verwaltet die GUI-Objekte und das Modellobjekt. uses Windows, Messages, SysUtils, Classes, ufarbe; Unit einbinden type Tgui = class(tform) Farbmischer: TGroupBox; Label1: TLabel;... private { Private-Deklarationen } Farbe : TFarbe; procedure aktualisiere; //Anzeigen public { Public-Deklarationen }... Referenzvariable für das Farbobjekt deklarieren (Hat- Beziehung)
50 Objekte erzeugen und freigeben Die GUI-Objekte, die zur Entwurfszeit ins Formular eingefügt wurden, werden automatisch erzeugt und zerstört. Das Farbobjekt wird zur Laufzeit erzeugt und zerstört werden. Z. B.: Erzeugung mit dem OnCreate-Ereignis procedure TGUI.FormCreate(...); begin Farbe := TFarbe.create;... Schema: obj := Klasse.create; Zeiger auf ein Farbobjekt hat-beziehung Zerstörung mit dem OnDestroy-Ereignis Procedure TGUI.FormDestroy(...); begin Farbe.Free; Speicherbereich freigeben geerbter Destruktor
51 Aktualisierung von Model und View Ereignismethode //Datenfluss: Controller Modell procedure TGUI.okBtnClick(Sender: TObject); //Modelldaten schreiben var r, g, b : integer; begin r := StrToInt(Erot.text); g := strtoint(egruen.text); b := strtoint(eblau.text); Farbe.setFarbe(r,g,b); //Werte im Modellobjekt speichern aktualisiere; //Aktualisierung der Anzeige durch Abfragen //Datenfluss: Modell View procedure TGUI.aktualisiere; //Modelldaten abfragen begin FarbBox.brush.color := Farbe.getFarbe; KFarbBox.brush.color := clwhite - Farbe.getFarbe;
52 MVC-Muster Ziel: Trennung von Datenhaltung und -verarbeitung, Darstellung und Steuerung. Modell Interne Repräsentation der Daten mit Methoden zum Ändern und Abfragen View Controller Ansicht, Darstellung: Ein Modell kann durch mehrere Views angezeigt werden, welche unterschiedliche Sichtweisen des Models darstellen. Steuerung: Verarbeitung der Benutzereingaben View und Controller bilden zusammen die Benutzeroberfläche (GUI). Controller Steuerung View Ansicht GUI schreibt liest informiert Model Fachkonzept
53 Aufgabe 1 1. Testen Sie das Programm Farben0 und verfolgen Sie den Ablauf mit Hilfe des Einzelschritt- Modus. 2. Erweitern Sie das Farbemodell um folgende Methoden a) TFarbe.getKomplement (Komplementärfarbe) b) TFarbe.toHTML (HTML- Code) Bsp.: #AFB055, verwenden Sie die Funktion InttoHex() c) Binden Sie beide Methoden in die Anwendung ein. 3. Entwickeln Sie eine zweite Benutzungsoberfläche, die die RGB-Farben einzeln anzeigt. (z. B.: in drei Shape-Komponenten) Binden Sie das Farbmodell an die entwickelte Benutzeroberfläche an.
54 Links Lazarus Tools, Tutorials http://wiki.lazarus.freepascal.org/lazarus_documentation/de http://wiki.lazarus.freepascal.org/lazarus_ide_tools/de#find_declaration http://wiki.lazarus.freepascal.org/lazarus_tutorial/de Grundlagen ObjektPascal http://www.delphi-treff.de/ Unterrichtsmaterialien Bildungsserver Informatik RP http://informatik.bildung-rp.de K. Merkert: http://www.hsg-kl.de/faecher/inf/delphi/index.php Siegfried Spolwig / Johann Penon http://oszhdl.be.schule.de/gymnasium/faecher/informatik/lazarus/index.html Martin Jakobs http://www.martinjakobs.de/pages/objektorientierte-programmierung.php Joachim Mohr http://www.kilchb.de/lektionen.html UML-Werkzeug: UML-Editor : UMLed.exe http://www.kubitz-online.de