Eseményvezérelt alkalmazások fejlesztése II 3. előadás. Windows Forms alapismeretek, eseményvezérlés. Giachetta Roberto

Hasonló dokumentumok
Eseményvezérelt alkalmazások fejlesztése II 2. előadás. Windows Forms alapismeretek, eseményvezérlés

Eseményvezérelt alkalmazások fejlesztése II 2. előadás. Windows Forms alapismeretek, eseményvezérlés. Giachetta Roberto

Eseményvezérelt alkalmazások fejlesztése II 2. előadás. Windows Forms alapismeretek, eseményvezérlés

Eseményvezérelt alkalmazások fejlesztése II 5. előadás. Windows Forms alkalmazások párhuzamosítása. Giachetta Roberto

Eseményvezérelt alkalmazások fejlesztése II 5. előadás. Windows Forms alkalmazások párhuzamosítása. Cserép Máté

Vizuális, eseményvezérelt programozás I.

Access adatbázis elérése OLE DB-n keresztül

Programozás 2., II. kötet Windows form alkalmazások

Programozás BMEKOKAA146. Dr. Bécsi Tamás 8. előadás

Ablakok használata. 1. ábra Programablak

Windows Application. Miklós Árpád Dr. Kotsis Domokos

Adatbázis alapú rendszerek gyakorlat Adatbázis alapú alkalmazásfejlesztés Java, C# környezetben

A programkód és az Unified Modeling Language (UML) osztálydiagramjának kapcsolata

Eseményvezérelt alkalmazások fejlesztése II 3. előadás. Windows Forms dinamikus felhasználói felület, elemi grafika

Programozás BMEKOKAA146. Dr. Bécsi Tamás 10. Előadás

A táblázatkezelő felépítése

Johanyák Zsolt Csaba: Grafikus felület programozása. Copyright 2008 Johanyák Zsolt Csaba

Adabáziselérés ODBC-n keresztül utasításokkal C#-ban

Grafikus felületek készítése 1.

Számítástechnika II. BMEKOKAA Előadás. Dr. Bécsi Tamás

A Microsoft Visual Studio 2005 fejlesztőkörnyezet

components : IContainer dx : int dy : int tmidőzítő : Timer toolstripseparator1 : ToolStripSeparator tsmikilépés : ToolStripMenuItem

AWP TELEPÍTÉSE- WINDOWS7 64 OPERÁCIÓS RENDSZEREN

7. Előadás. Makrók alkalmazása. Salamon Júlia. Előadás I. éves mérnök hallgatók számára

Programozás I gyakorlat

Johanyák Zsolt Csaba: Ugráló gomb oktatási segédlet Copyright 2008 Johanyák Zsolt Csaba

Mérési adatgyűjtés és adatfeldolgozás 2. előadás

2. Beadandó feladat dokumentáció

Hozzunk létre két rekordot a táblában, majd véglegesítsünk (commit):

Osztály szint tagok. Krizsán Zoltán 1 [2012. március 12.] Objektumorientált programozás C# alapokon tananyag

Összefoglaló. // megjegyzés /* megjegyzés */ ; // üres utasítás { } // blokk kezdet és vég

Vektoros elemzés végrehajtása QGIS GRASS moduljával 1.7 dr. Siki Zoltán

Beállítások CLASSBOOK-óratervező. Első belépés

Az első lépések. A Start menüből válasszuk ki a Minden program parancsot. A megjelenő listában kattintsunk rá az indítandó program nevére.

Laborgyakorlat Windows 7 upgrade-je, felhasználói adatok költöztetése

Eseményvezérelt alkalmazások fejlesztése II 12. előadás. Objektumrelációs adatkezelés (ADO.NET) Giachetta Roberto

Vodafone ReadyPay. Használati útmutató

Vegyes tételek könyvelése felhasználói dokumentum Lezárva:

Objektumorientált fogalmak, felügyelt környezetek

Felhasználói útmutató Dahua gyártmányú digitális képrögzítő eszközökhöz

Digitális technika (VIMIAA01) Laboratórium 1

Vizuális programozás gyakorlat

Számítástechnika II. BMEKOKAA Előadás. Dr. Bécsi Tamás

ESEMÉNY VEZÉRELT ALKALMAZÁSOK FEJLESZTÉSE I. Bevezetés. Készítette: Gregorics Tibor

Árverés kezelés ECP WEBSHOP BEÉPÜLŐ MODUL ÁRVERÉS KEZELŐ KIEGÉSZÍTÉS. v ECP WEBSHOP V1.8 WEBÁRUHÁZ MODULHOZ

Kép részlet kivágás útvonalak létrehozása és szerkesztése útvonalak kijelöléssé alakítása Kijelölés > Lágy szél

Prop-Tech. Vázmérő. Telepítési és eltávolítási útmutató

Számítógépes vírusok

SÜTIK TÖRLÉSE. Készült: Módosítva:

SAP JAM. Felhasználói segédlet

TANMENET. Tantárgy: Informatika Osztály: 9B. Heti óraszám: 2

Számítástechnika II. BMEKOKAA Előadás. Dr. Bécsi Tamás

Vodafone GPRS Kapcsolat létrehozása Win2000 alatt a Connect Me használata nélkül

Bár a digitális technológia nagyon sokat fejlődött, van még olyan dolog, amit a digitális fényképezőgépek nem tudnak: minden körülmények között

Sorosítás (szerializáció) és helyreállítás. 1. Bináris sorosítás és helyreállítás Szükséges névterek Attribútumok. 1.3.

Kivétel kezelés. Krizsán Zoltán 1. Objektumorientált programozás C# alapokon tananyag. Általános Informatikai Tanszék Miskolci Egyetem

Dial-UP Kapcsolat létrehozása angol nyelvű Windows 2000 alatt

FTP-kapcsolat létrehozása FlashFXP alatt

Java programozási nyelv 8. rész Grafikus felhasználói felület

Eseménykezelés. Aszinkron kommunikáció

FORTE MAP 5.0 Felhasználói tájékoztató

Johanyák Zsolt Csaba: Képnézegető program oktatási segédlet

Készítsen négy oldalas prezentációt egy vállalat bemutatására!

Form1 Form Size 400;400 Text Mozgó kör timer1 Timer Enabled True Interval 100

Ugráló gomb oktatási segédlet Ugráló gomb

EPER E-KATA integráció

Vasúti információs rendszerek gyakorlat

eseményvezérelt megoldások Vizuális programozás 5. előadás

HENYIR felhasználói dokumentáció

Vodafone Connect Now

Vizuális és eseményvezérelt programozás , II. félév BMF NIK

BME MOGI Gépészeti informatika 14.

Bevezetés a Programozásba II 11. előadás. Adatszerkezetek megvalósítása. Adatszerkezetek megvalósítása Adatszerkezetek

Vállalkozásfinanszírozás

C# nyelv alapjai. Krizsán Zoltán 1. Objektumorientált programozás C# alapokon tananyag. Általános Informatikai Tanszék Miskolci Egyetem

Üresként jelölt CRF visszaállítása

Erste MobilBank Felhasználói kézikönyv

Project Management

Csoportosított adatok megjelenítése sorhalmaz függvények használatával

A Felhasználónév és Jelszó mezőkbe írjuk be az adatainkat, majd kattintsunk a Bejelentkezés gombra, vagy üssük le az Enter billentyűt.

WCF, Entity Framework, ASP.NET, WPF 1. WCF service-t (adatbázissal Entity Framework) 2. ASP.NET kliens 3. WPF kliens

Objektumorientált programozás C# nyelven III.

BME MOGI Gépészeti informatika 4.

C# feladatgy jtemény

Segítség a megoldáshoz: 1. Készítse el a Window-t az ábrának és az osztálydiagramnak megfelelően.

Segítünk online ügyféllé válni Kisokos

Fábián Zoltán Hálózatok elmélet

II. év. Adatbázisok és számítógépek programozása

Objektumorientált programozás Pál László. Sapientia EMTE, Csíkszereda, 2014/2015

Bánsághi Anna 2015 Bánsághi Anna 1 of 31

Java VI. Egy kis kitérő: az UML. Osztály diagram. Általános Informatikai Tanszék Utolsó módosítás:

Dr. Schuster György február 21. Real-time operációs rendszerek RTOS

Shared IMAP beállítása magyar nyelvű webmailes felületen

Korszerű geodéziai adatfeldolgozás Kulcsár Attila

Objektumorientált programozás C# nyelven

A szerzõrõl... xi Bevezetés... xiii

E-ADÓ RENSZER HASZNÁLATI ÚTMUTATÓ

Eddig még nem használt vezérlőket is megismerünk: PlaceHolder, RadioButtonList.

ÁFA felhasználói dokumentum Lezárva:

Bánsághi Anna

Átírás:

Eötvös Loránd Tudományegyetem Informatikai Kar Eseményvezérelt alkalmazások fejlesztése II 3. előadás Windows Forms alapismeretek, eseményvezérlés Giachetta Roberto A jegyzet az ELTE Informatikai Karának 2014. évi Jegyzetpályázatának támogatásával készült

Grafikus felületek.net keretrendszerben A.NET keretrendszer több grafikus felület megvalósítási technológiát is biztosít: a Windows Forms (WinForms) az elsőként kifejlesztett felület (.NET 1.0), amely raszteres grafikára (GDI+) épül, és teljes mértékben processzor által vezérelt a Windows Presentation Foundation (WPF) a később kifejlesztett felület (.NET 3.0), mely vektoros grafikára épül, célja a 3D gyorsítókártyák lehetőségeinek kihasználása a Modern UI direkt hordozható eszközökre szánt egyszerűsített, letisztult felület, amely a WPF architektúrára épít ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:2

A Visual Studio eszközei A Microsoft Visual Studio biztosít egy felülettervező eszközt, amivel grafikusan készítjük el a GUI-t, a hozzá tartozó kód pedig legenerálódik, így nem szükséges a teljes kódot megírnunk egy eszköztárból (ToolBox) válogathatunk a vezérlők közül, és ezt grafikusan ( drag and drop módszerrel) helyezhetjük a felületre a vezérlő tulajdonságait (Properties) és eseményeit (Events) külön menüben állíthatjuk bármikor válthatunk a kód és a tervező nézet között, és felváltva szerkeszthetjük a felületet, a szerkesztett kód nem lesz hatással a generált kódra ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:3

Vezérlők A Windows Forms grafikus felülete vezérlőkből épül fel az osztályok a System.Windows.Forms névtérben helyezkednek el minden vezérlő egy ősosztály leszármazottja (Control) A vezérlők csoportosítása: ablak (Form) elrendező elemek (FlowLayoutPanel, TableLayoutPanel, SplitConatiner, GroupBox, ) menük és eszköztárak (ToolStrip, StatusStrip, ) adatkezelő vezérlők (DataGridView, BindingSource, ) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:4

Vezérlők felületi elemek: megjelenítők (Label, ListView, Panel, WebBrowser, ) gombok (Button, RadioButton, CheckBox, ) beviteli mezők (TextBox, NumericUpDown, ComboBox, ListBox, ) egyedi vezérlők (UserControl) dialógusablakok (MessageBox, OpenFileDialog, FolderBrowserDialog, PrintDialog, ) segédelemek (ToolTip, ErrorProvider, Help, ) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:5

Vezérlők Control ListView ButtonBase ListControl ScrollableControl Label GroupBox Button ComboBox Panel ContainerControl ToolStrip RadioButton ListBox Form CheckBox CheckedListBox PrintPreviewDialog ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:6

Vezérlők A vezérlők tulajdonságait általában létrehozás után állítjuk be (de konstruktorban is megadhatóak alapvető értékek) Fontosabb tulajdonságok: pozícionálás és méretezés (Location, Size, Anchor, AutoSize, Dock) engedélyezettség (Enabled), fókuszáltság (Focused) láthatóság (Visible), áttetszőség (Opacity) tabulátorkezelés (TabIndex, TabStop) felirat (Text), szöveget tartalmazó elemekben név (Name), a későbbi azonosításra szolgál ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:7

Vezérlők szülő és gyerek vezérlők (Parent, Controls) színezés (ForeColor, BackColor), amelyek a Color osztály segítségével állíthatunk be tetszőleges RGB kombinációra, vagy fix értékre (pl. Color.Red) Pl. egy címke esetén: Label mylabel = new Label(); mylabel.location = new Point(6, 18); // pozíció mylabel.name = "cimke"; // név mylabel.size = new Size(65, 13); // méret mylabel.tabindex = 1; // tabulátor index mytext.forecolor = Color.Blue; // kék feliratszín mylabel.text = "valami felirat"; // felirat ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:8

Események és eseménykezelés A C# nyelvi szinten valósítja meg az eseménykezelést, amelyhez eseményeket (event) és delegáltakat (delegate) használ az eseménykezelő egy szabványos metódus, de mindig két paramétere van, a küldő objektum (object sender), és az eseménytulajdonságok (EventArgs e), amelyek leszármazottai hordozhatnak speciális értéket a delegált szabja meg az eseménytulajdonságok (EventArgs) típusát az alapértelmezett delegált az EventHandler lehet delegáltakat létrehozni, vagy sablont használni más tulajdonságokhoz ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:9

Események és eseménykezelés Az eseménykezelő hozzárendelésekor az eseménykezelő nevét kell megadnunk: <objektumnév>.<eseménynév> += new EventHandler(<metódusnév>); a += operátor lehetővé teszi, hogy egy eseményhez több eseménykezelőt is hozzárendeljünk a társításban bármely objektum eseményét rendelhetjük bármely, azonos szintaktikájú eseménykelőhöz a -= operátor segítségével tudjuk bontatni a kapcsolatot Pl.: class EventClass { public event EventHandler MyEvent; // esemény } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:10

Események és eseménykezelés Pl.: class HandlerClass { private EventClass ec; } public HandlerClass(){ ec = new EventClass(); ec.myevent += new EventHandler(MyEventHandler); // eseménykezelő társítás } private void MyEventHandler(object sender, EventArgs e){ } // eseménykezelő metódus ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:11

Események és eseménykezelés Események kiváltása az esemény meghívásával történik, ahol átadjuk a megfelelő paramétereket esemény csak akkor váltható ki, ha van hozzárendelve eseménykezelő, különben az esemény null értéknek felel meg (és így kivételt kapunk) általában a kiváltást külön metódusban végezzük Pl.: if (ec.myevent!= null) // ha van hozzárendelve eseménykezelő ec.myevent(this, null); // kiváltjuk // a küldő az aktuális objektum, az // eseményargumentumok üresek ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:12

Vezérlők eseményei A vezérlők számos eseménnyel rendelkeznek, több csoportban: egér és billentyűzet tevékenységek (Click, MouseClick, MouseHover, KeyDown, KeyUp, ) vezérlőállapot megváltozása (Validating, Validated, Resize, Paint, GotFocus, ) tulajdonságok megváltozása (BackColorChanged, TabIndexChanged, TextChanged, SizeChanged, ) Bizonyos események csak akkor váltódnak ki, ha a vezérlő fókuszban van (Focus()), pl. billentyűzetesemények ugyanakkor a billentyűzet lekezelhető az ablak szintjén is ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:13

Vezérlők eseményei Pl.: Button b = new Button(); b.click += new EventHandler(B_Click); // társítás b.mousedoubleclick += new MouseEventHandler(B_DClick); // társítás void B_Click(object sender, EventArgs e) { } // eseménykezelő void B_DClick(object sender, MouseEventArgs e) { // speciális eseményargumentum, amelytől // lekérdezhető az egérgomb (Button) és a // pozíció (Location) } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:14

Ablakok Az ablak ősosztálya a Form, amely példányosítással, vagy specializációval használható, fontosabb tulajdonságai: vezérlő eszköztár (ControlBox, MinimizeBox, MaximizeBox) menü (Menu) kezdőpozíció (StartPosition) ablakállapot (WindowState) vezérlőgombok (AcceptButton, CancelButton) dialóguseredmény (DialogResult) billentyű-esemény elfogás (KeyPreview) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:15

Ablakok Pl. (MyForm.cs): class MyForm : Form // saját ablak osztály { private Button okbutton; // mezők public MyForm() { // konstruktor Text = "Az ablak"; // ablakcím okbutton = new Button(); // vezérlők inicializálása okbutton.text = "OK"; okbutton.location = new Point(5, 5); } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:16

Ablakok Felülettervező használata esetén az ablakaink több fájlban helyezkednek el a felülettervező által generált kód egy másik (Designer) fájlba kerül, így két fájl alkotja az ablak osztályát <osztálynév>.cs <osztálynév>.designer.cs ezen felül az ablakhoz használt erőforrások (képek, ikonok,...) erőforrásfájlban helyezhetőek el: <osztálynév>.resx az ablakok úgynevezett parciális (partial) osztályokká válnak, amelyek több fájlban helyezkedhetnek el ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:17

Ablakok saját kód, eseménykezelők, dinamikus vezérlők MyForm.cs MyForm.Designer.cs felülettervezővel generált kód MyForm MyForm.resx képek, ikonok, hangok ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:18

Ablakok A felülettervező által generált kód is olvasható, átírható, azonban a módosítása hatással lehet a felülettervező ablakra, ezért a saját kódot (eseménykezelők, dinamikus vezérlők, ) ne keverjük a generált kóddal A tervezőben létrehozott felület (vezérlők létrehozása, tulajdonságok beállítása) az InitializeComponent() metódus segítségével jön létre az osztály konstruktorának első utasítása, ez után tetszőlegesen bővíthetjük a kódot Emellett a tervező felülírja automatikusan a Dispose() metódust, ami a vezérlők törlését végzi ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:19

Ablakok Pl. (MyForm.cs): namespace MyFormsApplication { partial class MyForm : Form { // parciális ablak osztály public MyForm() { // konstruktor InitializeComponent(); // felülettervező által létrehozott // vezérlők inicializálása } } } // további inicializáció ezt követően ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:20

Ablakok Pl. (MyForm.Designer.cs): namespace MyFormsApplication { partial class MyForm { // parciális ablak osztály másik része public void Dispose() { } // ablak megsemmisítése public void InitializeComponent(){ } // vezérlők inicializálása } } // vezérlők ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:21

Dialógusablakok Amellett, hogy bármely ablakot kezelhetünk dialógusablakként, vannak előre legyártott dialógusablakok is, a legegyszerűbb az előugró üzenet (MessageBox) a statikus Show( ) művelettel használható, amely paraméterezhető (pl. üzenet, gombok, ikon, ) a művelet visszatérési értéke DialogResult, így lekérdezhető, milyen gombot használt a felhasználó pl.: MessageBox.Show("Really quit?", "My Application", // cím MessageBoxButtons.YesNo, // gombok MessageBoxIcon.Question); // ikon ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:22

Dialógusablakok A további dialógusablakok megegyeznek az operációs rendszerben fellelhető ablakokkal, pl.: fájl megnyitó (OpenFileDialog), fájl mentő (SaveFileDialog), könyvtárböngésző (FolderBrowserDialog) betűtípus-választó (FontDialog), színválasztó (ColorDialog) nyomtatási beállítások (PrintDialog), előnézet (PrintPreviewDialog), oldalbeállítás (PageSetupDialog) További dialógusablakok (pl. szövegbeviteli mező) egyedileg készíthetőek ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:23

Dialógusablakok Pl. : SaveFileDialog dialog = new SaveFileDialog(); // fájl mentő dialógus dialog.title = "Save file"; // cím dialog.filter = "txt files (*.txt) *.txt All files (*.*) *.*"; // szűrés a megjelenített tartalomra if (dialog.showdialog() == DialogResult.OK) { // ha OK-val zárták le az ablakot StreamWriter writer = new StreamWriter(dialog.FileName); // a megadott fájlnévre mentünk } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:24

Alkalmazás osztályok A grafikus felületű alkalmazásokat egy alkalmazásnak (Application) kell vezérelnie statikus osztály, a főprogramban használjuk legfőbb művelete a futtatás (Run), amely paraméterben megkapja az első indítandó képernyő objektumát, illetve lehetőséget ad a kilépésre is (Exit) ezen felül alkalmas a környezet beállítására (EnableVisualStyles, UseWaitCursor, ), valamint információgyűjtésre (StartupPath, OpenForms, ProductName, ) eseményeivel követhetjük a programfutást (ApplicationExit, Idle) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:25

Alkalmazás osztályok Pl. (Program.cs): namespace MyFormsApplication { class Program { static void Main() // főprogram { Application.EnableVisualStyles(); Application.Run(new MyForm()); // alkalmazás indítása a megadott // ablakkal } } } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:26

Példa Feladat: Készítsünk egy egyszerű számológépet, amellyel a négy alapműveletet végezhetjük el, illetve láthatjuk korábbi műveleteinket is. az alkalmazás felületét a felülettervezővel készítjük el, elhelyezünk 5 gombot (Button), egy szövegbeviteli mezőt (TextBox), valamint egy listát (ListBox) az ablak osztályban (CalculatorForm) létrehozunk egy eseménykezelőt (Button_Click) a gombokra, amely a megfelelő műveleteket végzi el egy felsorolási típussal (Operation) tároljuk el a műveletet ellenőrizzük kivételkezeléssel, hogy a bevitt érték megfelelő-e ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:27

Példa Tervezés: «enumeration» Operation None Add Substract Multiply Divide -_lastoperation CalculatorForm - _operation :Operation - _result :Double Form + CalculatorForm() - Button_Click(object, EventArgs) :void Program - Main() :void ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:28

Példa Megvalósítás (CalculatorForm.cs): public partial class CalculatorForm : Form { // egy közös eseménykezelő az összes gombnak private void Button_Click(object sender, EventArgs e){ try { // minden esetben: _fistnumber = Double.Parse(_textNumber.Text); // eltároljuk az első operandust ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:29

Példa Megvalósítás (CalculatorForm.cs): switch (((sender as Button).Text) { // megvizsgáljuk, milyen az eseményt // kiváltó gomb felirata, így // eldönthetjük, melyik gombot // nyomták le } catch (OverflowException) { MessageBox.Show("Your input has to many digits!", "Calculation Error", MessageBoxButtons.OK, MessageBoxIcon.Error); ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:30

Ablakok használata Ablakok megnyitására két lehetőségünk van: a Show() művelet megnyitja az ablakot, de utána tovább fut a megnyitó ablak kódja a ShowDialog() művelet dialógusablakként nyitja meg, ekkor a megnyitó ablak blokkolódik, és csak az új ablak bezárása után lehet bármely más tevékenységet végezni utóbbi esetben kaphatunk eredményt (DialogResult) az ablaktól a lezárást illetően (pl. None, OK, Cancel, Yes, ), amelyet lekérdezhetünk, pl.: if (myform.showdialog() == DialogResult.Yes) Ablak bezárása a Close() művelettel történik ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:31

Időzítő Az időzítő kezelést egyfelől szálak segítségével, másfelől a Timer osztályon keresztül vehetjük igénybe lehetőségünk van indításra (Start), leállításra (Stop), állapotlekérdezésre (Enabled), valamint az intervallum (Interval) beállítására, az idő eltelésekor a Tick esemény váltódik ki pl.: Timer mytimer = new Timer(); // időzítő mytimer.interval = 1000; // 1 másodpercenként váltódik ki az esemény mytimer.tick += new EventHandler(Timer_Tick); // eseménykezelő társítás mytimer.start(); // indítás ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:32

Példa Feladat: Készítsünk egy vizsgatétel generáló alkalmazást, amely ügyel arra, hogy a vizsgázók közül ketten ne kapják ugyanazt a tételt. a főablakban két gombot (Start/Stop, Beállít), valamint egy szövegmezőt helyezünk el, a generálást időzítővel (Timer) valósítjuk meg, a generált számokat elmentjük egy listába az ellenőrzéshez egy segédablakban két számbeállító (NumericUpDown) segítségével állítjuk be a tételek számát és a bent lévő hallgatók számát egy kijelölhető lista (CheckedListBox) segítségével ellenőrizhetjük és korrigálhatjuk a kiadott tételszámokat ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:33

Példa Tervezés: MainForm - _historylist :List<Int32> - _periodlength :Int32 - _questioncount :Int32 - _questiongenerator :Random - _timer :Timer Form + MainForm() - Timer_Tick(object, EventArgs) :void - ButtonStart_Click(object, EventArgs) :void - ButtonSet_Click(object, EventArgs) :void - _historylist :List<Int32> SettingsForm Form + SettingsForm(Int32, Int32, List<Int32>) - ButtonOk_Click(object, EventArgs) :void - ButtonCancel_Click(object, EventArgs) :void - NumericQuestionCount_ValueChanged(object, EventArgs) :void «property» + QuestionCount() :Int32 + PeriodLength() :Int32 A Program - Main() :void ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:34

Példa Megvalósítás (MainForm.cs): void Timer_Tick(object sender, EventArgs e) { Int32 number = _questiongenerator.next(1, _questioncount + 1); // új szám generálása 1 és a tételszám // között while (_historylist.contains(number)) // ha a szám szerepel a korábbiak között number = _questiongenerator.next(1, _questioncount + 1); // akkor új generálása } _textnumber.text = number.tostring(); ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:35

Példa Megvalósítás (MainForm.cs): void ButtonSet_Click(object sender, EventArgs e) { SettingsForm f = new SettingsForm( _questioncount, _periodlength, _historylist); // dialógusablak létrehozása paraméterekkel } if (f.showdialog() == DialogResult.OK) { // dialógusablak megjelenítése _questioncount = f.questioncount; // elmentjük az új értékeket _periodlength = f.periodlength; ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:36

Billentyűzet és egérkezelés A billentyűzet kezelésére lehetőség van a fókuszált vezérlőn, de az ablak is le tudja kezelni a billentyű eseményeket (PreviewKeyDown, KeyDown, KeyUp, KeyPress) az ablaknál engedélyeznünk kell a kezelést (KeyPreview), különben nem fogja el az eseményt eseményargumentumban (KeyEventArgs) megkapjuk a billentyűzet adatait (KeyCode, KeyData, Modifiers, ) az ablak mellett a vezérlő is megkapja az eseményt, amennyiben ezt nem szeretnénk, lehetőség van beavatkozni (SuppressKeyPress) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:37

Billentyűzetkezelés Pl.: KeyPreview = true; // az ablak lekezeli a billentyűzetet KeyDown += new KeyEventHandler(Form_KeyDown); // billentyű lenyomásának eseménye void Form_KeyDown(object sender, KeyEventArgs e) { if (e.keycode == Keys.Enter) // Enter hatására { // tevékenység elvégzése e.suppresskeypress = true; // a vezérlő nem kapja meg az eseményt } } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:38

A modell/nézet architektúra Összetettebb alkalmazásoknál az egyrétegű felépítés korlátozza a program áttekinthetőségét, tesztelését (pl. nehezen látható át, hol tároljuk a számításokhoz szükséges adatokat) módosíthatóságát, bővíthetőségét (pl. nehezen lehet a felület kinézetét módosítani) újrafelhasználhatóságát (pl. komponens kiemelése és áthelyezése másik alkalmazásba) A legegyszerűbb felbontás a felhasználói felület leválasztása a háttérbeli tevékenységekről, ezt nevezzük, modell/nézet (MV, model-view) architektúrának ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:39

A modell/nézet architektúra A modell/nézet architektúrában a modell tartalmazza a háttérben futó logikát, azaz a tevékenységek végrehajtását, az állapotkezelést, valamint az adatkezelést, ezt nevezzük alkalmazáslogikának, vagy üzleti logikának a nézet tartalmazza a grafikus felhasználói felület megvalósítását, beleértve a vezérlőket és eseménykezelőket a felhasználó a nézettel kommunikál, a modell és a nézet egymással a modell nem függ a nézettől, függetlenül, önmagában is felhasználható, ezért könnyen átvihető másik alkalmazásba, és más felülettel is üzemképes ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:40

A modell/nézet architektúra alkalmazás felhasználó megjelenítés nézet eseménykezelés adatelérés modell állapotkezelés ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:41

Példa Feladat: Készítsük a számológép alkalmazást modell/nézet architektúrában. leválasztjuk a modellt a felületről, így létrejön a számológép (CalculatorModel), amely végrehajtja a műveletet (Calculate), tárolja az eredményt (Result), valamint a művelet szöveges leírását (CalculationString) a nézet (CalculatorForm) feladata a modell példányosítása és használata a gombok eseménykezelése mellett célszerű a billentyűzetet is kezelni az ablakon keresztül, a tevékenység végrehajtását pedig külön alprogramba helyezzük (PerformCalculation) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:42

Példa Tervezés: CalculatorForm - _model :CalculatorModel Form Program + CalculatorForm() - Button_Click(object, EventArgs) :void - CalculatorForm_KeyDown(object, KeyEventArgs) :void - PerformCalculation(Operation) :void - Main() :void «enumerati... Operation None Add Subtract Multiply Divide -_operation -_model CalculatorModel - _result :Double - _calculationstring :String - _operation :Operation + CalculatorModel() + Calculate(Double, Operation) :void «property» + Result() :Double + CalculationString() :String ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:43

Példa Megvalósítás (CalculatorForm.cs): private void CalculatorForm_KeyDown(object sender, KeyEventArgs e) { switch (e.keycode) { // megkapjuk a billentyűt case Keys.Add: PerformCalculation(Operation.Add); e.suppresskeypress = true; // az eseményt nem adjuk tovább a // vezérlőnek break; } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:44

Példa Megvalósítás (CalculatorForm.cs): private void PerformCalculation(Operation operation){ try { _model.calculate( Double.Parse(_textNumber.Text), operation); // művelet végrehajtása _textnumber.text = _model.result.tostring(); // eredmény kiírása if (operation!= Operation.None) _listhistory.items.add( _model.calculationstring); // művelet kiírása a listába ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:45

A modell/nézet architektúra A modell és a nézet kapcsolatát úgy kell megvalósítani, hogy a nézet ismerheti a modell felületét (interfészét), és hívhatja annak (publikus) műveleteit a modellnek semmilyen tudomása sem lehet a nézetről, ezért nem hívhatja annak műveleteit, de eseményeken keresztül kommunikálhat vele nézet metódushívás események modell A megvalósításban a nézet hivatkozhat a modellre, tartalmazhatja annak példányát ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:46

Példa Feladat: Módosítsuk a számológép alkalmazást úgy, hogy a modell jelezze a számítás befejeződését, és annak eredményét. a modellhez felveszünk egy új eseményt (CalculationPerformed), amelyet a nézet feldolgoz az esemény mellé adatokat is szolgáltatunk, ezért szükség van egy speciális eseményargumentumra (CalculatorEventArgs), amely tartalmazza az eredményt, és a szöveges kiírást a nézetnek így már nem kell lekérdeznie a számítás eredményét, mert automatikusan megkapja az osztályokat helyezzük külön névterekbe ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:47

Példa Tervezés: Program - Main() :void - _model :CalculatorModel View::CalculatorForm Form + CalculatorForm() - Model_CalculationPerformed(object, CalculatorEventArgs) :void - Button_Click(object, EventArgs) :void - CalculatorForm_KeyDown(object, KeyEventArgs) :void - PerformCalculation(Operation) :void -_model EventArgs Model::CalculatorEventArgs - _result :Double - _calculationstring :String + CalculatorEventArgs(Double, String) «property» + Result() :Double + CalculationString() :String - _result :Double - _operation :Operation Model::CalculatorModel + CalculatorModel() + Calculate(Double, Operation) :void - OnCalculationPerformed(String) :void «property» + Result() :Double «event» + CalculationPerformed() :EventHandler<CalculatorEventArgs> ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:48

Példa Megvalósítás (CalculatorModel.cs): public event EventHandler<CalculatorEventArgs> CalculationPerformed; // számítás végrehajtásának eseménye private void OnCalculationPerformed(String calculationstring){ if (CalculationPerformed!= null) CalculationPerformed(this, new CalculatorEventArgs(_result, calculationstring)); // feltöltjük az eseményargumentumot } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:49

Időzítés modell/nézet architektúrában Amennyiben a modell szintjén akarunk időzítést végezni, nem használhatunk felületi időzítőt, de használhatjuk a System.Timers.Timer időzítőt, amely független a felülettől hasonlóan kezelhető az intervallum (Interval), indítás és leállítás (Start, Stop), valamint az időzített esemény kiváltása (Elapsed) hátránya, hogy nem szinkronizál a grafikus felülettel, és emiatt a közvetlen manipulálása a felületnek hibát vált ki ez feloldható a vezérlő Invoke műveletével, amely egy lambda-kifejezéssel megadott akciót (Action) tud futtatni a felület szálán ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 4:50

Időzítés modell/nézet architektúrában Pl.: Timers.Timer mytimer = new Timer(); // időzítő mytimer.elapsed += new ElapsedEventHandler(Timer_Elapsed); // időzített esemény void Timer_Elapsed( ){ // itt nem használhatjuk a felületet Invoke(new Action(() => { // itt már igen mylabel.text = e.signaltime.tostring(); // kiírjuk az eltelt időt a felületre })); } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 4:51

Példa Feladat: Készítsünk egy vizsgatétel generáló alkalmazást modell/nézet architektúrában. a modell (ExamGeneratorModel) végzi a tételek generálását (Generate), amihez időzítőt használ, továbbá eseménnyel (NumberGenerated) jelzi, ha generált egy új számot emellett lehetőség van a tétel elfogadására (Take), illetve a korábban húzott tételek visszahelyezésére (Return) mindkét nézet kapcsolatban áll a modellel, a főablak az esemény hatására frissíti a megjelenítést (ügyelve a szinkronizációra) ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:52

Példa Tervezés: ExamGeneratorModel - _questioncount :Int32 - _periodcount :Int32 - _questionnumber :Int32 - _historylist :List<Int32> - _questiongenerator :Random - _timer :Timer + ExamGeneratorModel(Int32, Int32) + Generate() :void + Takeable(Int32) :Boolean + Take() :void + Return(Int32) :void - OnNumberGenerated() :void - Timer_Elapsed(object, ElapsedEventArgs) :void «property» + QuestionNumber() :Int32 + IsGenerating() :Boolean + QuestionCount() :Int32 + PeriodCount() :Int32 «event» + NumberGenerated() :EventHandler -_model -_model - _model :ExamGeneratorModel MainForm - _model :ExamGeneratorModel SettingsForm Form + MainForm() - Model_NumberGenerated(object, EventArgs) :void - ButtonStart_Click(object, EventArgs) :void - ButtonSet_Click(object, EventArgs) :void Form + SettingsForm(ExamGeneratorModel) - ButtonOk_Click(object, EventArgs) :void - ButtonCancel_Click(object, EventArgs) :void - NumericQuestionCount_ValueChanged(object, EventArgs) :void Program - Main() :void ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:53

Példa Tervezés: MainForm ExamGeneratorModel User ButtonStart_Clicked() Generate() _timer.start() loop Timer_Elapsed() Model_NumberGenerated() OnNumberGenerated() ButtonStart_Clicked() Take() ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:54

Példa Megvalósítás (MainForm.cs): public MainForm(){ _model = new ExamGeneratorModel(10, 0); _model.numbergenerated += new EventHandler(Model_NumberGenerated); // modell eseménye } private void Model_NumberGenerated(object sender, EventArgs e){ Invoke(new Action(() => { _textnumber.text = _model.questionnumber.tostring(); })); // szinkronizált végrehajtás } ELTE IK, Eseményvezérelt alkalmazások fejlesztése II 3:55