„Eseményvezérelt és vizuális programozás” változatai közötti eltérés
A VIK Wikiből
→Előadás: Óra anyagának hozzáadása |
→Előadás: Óra anyagának hozzáadása |
||
91. sor: | 91. sor: | ||
* 10. hét: threading ([[Media:evip_eloadas_10.pdf |korábbi előadás]]): lock, dispatch loop; async, await, Run(), DoItAsync(), ContinueWith(), Report(), Dispatcher, DispatchAsync() | * 10. hét: threading ([[Media:evip_eloadas_10.pdf |korábbi előadás]]): lock, dispatch loop; async, await, Run(), DoItAsync(), ContinueWith(), Report(), Dispatcher, DispatchAsync() | ||
* 11. hét: ''szünet'' | * 11. hét: ''szünet'' | ||
* 12. hét: performance profiler ([[Media:evip_eloadas_12.pdf |korábbi előadás]]); reflection ([[Media:evip_eloadas_11.pdf |korábbi előadás]]) | * [https://github.com/eviplabs/peldak2023/tree/main/PerformanceProfiling 12. hét]: performance profiler ([[Media:evip_eloadas_12.pdf |korábbi előadás]]); reflection ([[Media:evip_eloadas_11.pdf |korábbi előadás]]) | ||
* [ 13. hét]: felkészülés a [[#ZH | ZH2]]-re | * [https://github.com/eviplabs/peldak2023/tree/main/Zh2Konzi 13. hét]: felkészülés a [[#ZH | ZH2]]-re | ||
=== Labor === | === Labor === |
A lap 2023. december 5., 20:38-kori változata
A tárgy keretein beül a hallgatók a korábbi objektum-orientált ismereteikre alapozva megismerik az eseményvezérelt és grafikus programozás legfontosabb módszereit. A hallgatók megismerik a C# nyelvet és a .NET környezeten keresztül elsajátítják a grafikus felhasználói felület (GUI - Graphical User Interface) programozási alapjait. Megismerik a modern osztálykönyvtárak fontosabb szolgáltatásait (reflexiós technikák, adatkötés, rajz és szöveg megjelenítése stb.), valamint betekintést kapnak a feladatok párhuzamos futtatásának lehetőségeibe.
Követelmények
Előtanulmányi rend
- A tárgy felvételéhez az Objektumorientált programozás tárgy kredite szükséges hozzá.
A szorgalmi időszakban
- A laboron megjelenés kötelező. Minden nem házi feladat leadási laboron az órai aktivitást és eredményeket a laborvezető pontozza 0-1-2 ponttal. Egyes előadásokon és laborokon előre be nem jelentett módon további bónusz pontok nyerhetők, melyek hozzáadódnak a félév során gyűjtött pontokhoz. A félév sikeres teljesítésének feltétele a laborok 70%-án való részvétel. A laborok értékelésébe beszámít a „beugró”, ami vagy konkrétan megválaszolandó kérdéssor, vagy a laborfeladat eleje, aminek elkészítésében a laborvezető még nem segít, azt teljesen önállóan kell tudni elkészíteni. Amennyiben ez nem sikerül, a laborra a hallgató 0 pontot kap.
- A laborok lehetnek:
- Hagyományos labor: kiadott segédlettel feladatok elvégzése, önnálló labor, de laborvezető segíthet.
- Code review labor: házi feladatokat egymásnak elmagyarázzátok. A cél a forráskód minőségének növelése, az „ezt hogyan érdemes elegánsan megoldani” kérdések megvitatása.
- Házi feladat konzultációs labor: házi feladattal kapcsolatos egyéni kérdésekre feltevése, házi feladaton való munkálkodás.
- Páros programozással tanuló labor: mindig más párral kell dolgozni, hagyományos laborfeladatok vagy házi feladatok közös megbeszélése.
- Házi feladat leadási labor
- A laborok lehetnek:
- A házi feladatok darabonként 30-30 pontot érnek. A házi feladatok idő előtt való leadása pluszpontot ér.
2020. őszén (A "hibrid" oktatás alatt) hozott változtatások
- A laborok jelentősen megváltoztak. Összesen 10 darab labor, mindegyik pontozva van 0-5 között és akkor számít részvételnek ha egy laboron min. 1 pontot elért valaki (70% részvétel követelmény, lehetnek fél pontok is). Moodle-ön tartozhat "online beugró" egy laborhoz, amit teljesíteni kell az érintett labor előtti vasárnap éjféléjig, különben mínusz pont jár érte. Laborokat mindenki egy külön github repository-ba csinálta és leadás egy pull request ahol a "laborvezető" meg van adva reviewer-nek.
- Csak a csapatmunka (3 fős) házi feladat van és maximum 25 pontot lehet rá kapni.
- Van jelenléti ZH, ami 25 pontos.
- Engedélyezve volt az online források használata (labvez szavai: "StackOverflow-t nyugodtan kérdezzük, de a padtársakat légyszi ne").
- Teljesítése nem követelmény, de póthéten lehet pótolni.
- Tehát a pontszámítás a következő: Laborok(max. 50) + házi(max. 25) + zh(max. 25) = max. 100 pont
2021. őszén hozott változtatások
- Nincsen NHF.
- Két jelenléti ZH van és mindegyik min. 40%-os teljesítése kötelező.
- Laborokra nem kötelező jelenlétiben bejárni, otthon is elvégezhetőek.
- Ha mégis jelenléti laborra szeretnél menni, azt Moodle-n előre jelezni kell.
- Teams-en van egy egységes felület a laborral kapcsolatos kérdéseknek. Válaszolhat rájuk az előadó, a laborvezető, de hallgató is.
- A félév végén lehet szavazni azon hallgató társaidra, akik a legtöbbet segítettek neked vagy másoknak a kérdéseitek megválaszolásával. 50 pontot osztanak szét azon 5 ember között, akikre a legtöbb szavazat jön.
- Pontszámítás: Laborok(max.50)+2 ZH(max.50)+bónuszpontok
Pótlási lehetőségek:
- A házi feladatok előre kihirdetett időpontokban, késedelmesen is le lehet adni.
- A laborok nem pótolhatóak. A házi feladat korábbi időpontban való leadás további pluszpontokkal járhat.
- A zh 1szer pótolható, egy előre kihirdetett időponton póthéten.
Félévvégi jegy
- Az évvégi jegy a házi feladatokra és laborokra kapott pontszámok összege alapján adódik össze. A tárgy teljesítéséhez legalább 40 pontot kell elérni.
- Ponthatárok:
Pont Jegy 0 - 40 1 40 - 54 2 55 - 69 3 70 - 84 4 85 - 100 5
Tematika
Előadás
A prezentációk a Moodle-re, a példakódok pedig a GitHubra vannak feltöltve.
.NET
- 1. hét: bevezetés, culture deck
- 2. hét: Git-kvíz; Visual Studio; C#-bevezetés (korábbi előadás): args, Console.WriteLine(), static, ref, nullable type, getter-setter
- 3. hét: compiler és interpreter, bytecode, JVM, JIT, CIL; ref, getter-setter, virtual, override, interface, factory method, base, $-string, StringBuilder, Exception, TryParse, out
- 4. hét: regex (korábbi előadás), serialization
- 5. hét: kollekciók (korábbi előadás): IEnumerable, Dictionary, tuple, 2D array; foreach, yield return
- 6. hét: 2022. őszi ZH1 (A csoport) megoldása
- 7. hét ([Media:evip_eloadas_4.pdf |korábbi előadás]]): IComparer, CompareTo(), linq: Select(), Where(), Contains(), GroupBy(), OrderBy(), First(), FirstOrDefault(), Last(), Single(), SingleOrDefault()
.NET MAUI
- 8. hét: partial, VerticalStackLayout, HorizontalStackLayout, Button, Image, xmlns, x:(Static)
- 9. hét: data binding (korábbi előadás): x:Binding, event, nameof(), typeof(), Frame, converter, BindingContext, x:Reference, SelectedItem.Model, BoxView; MVVM (korábbi előadás)
- 10. hét: threading (korábbi előadás): lock, dispatch loop; async, await, Run(), DoItAsync(), ContinueWith(), Report(), Dispatcher, DispatchAsync()
- 11. hét: szünet
- 12. hét: performance profiler (korábbi előadás); reflection (korábbi előadás)
- 13. hét: felkészülés a ZH2-re
Labor
A GitHub Classroom csatlakozási linkek a Moodle-re vannak feltöltve.
.NET
- 1. hét: elmaradt
- 2. hét: szünet
- 3. hét: Git(hub) és Visual Studio setup (debug); class és unit test prímszámok összegének kiszámítására
- 4. hét: TurkMite: teljes refaktorálás, OpenCvSharp, xUnit
- 5. hét: regex
- 6. hét: generics, collections
- 7. hét: ZH1
.NET MAUI
- 8. hét: LINQ, .svg (XML)
- 9. hét: MAUI bevezető
- 10. hét: Expenses: data binding
- 11. hét: AttaxxPlus: módosítások (BorderColor, StaticResource)
- 12. hét: progress bars: módosítások
- 13. hét: Mandelbrot: módosítások
Segédanyagok
- A tantárgyi oldalon rengeteg segédanyaggal találkozhattok, akár pptx, akár videó formájában, melyeket érdemes átnézni a laborok előtt.
- GitHub használat alapok
- C# OOP bevezető
- .NET dokumentáció
ZH
- 2022. ősz
- ZH1
- A csoport, megoldások
- A 4. feladat 1. bekezdésének vége helyesen (mivel nem lehet csupán korból születési dátumot számolni): "Aladár (130 cm) kora: 15 év."
- A 4. feladat 2. bekezdése helyesen (hiányzó lényeges vesszők): A ClassRoom osztályba tegyél egy GetAverageAge függvényt, ami visszaadja az osztály átlagéletkorát, és egy GetTallestPerson függvényt, ami visszaadja a legmagasabb tagját.
- B csoport
- A csoport, megoldások
- ZH2
- ZH1
- 2021. ősz
- 2020. ősz
Házi feladat
- A félév során két házi feladat lesz
- C# nyelvben
- WPF-es GUI fejlesztés
- A feladatok megoldása során mindenki személyre szóló github repositoryba dolgozik (GitHub classroom), melyben bizonyos feladatok előre elkészített unit tesztek formájában adottak.
- Az első házi feladat további specialitása, hogy két leadási határideje van és az első után előre ismeretlen módon megváltozik a feladat specifikációja. Ennek célja, hogy rávilágítson az áttekinthető fejlesztés, objektumorientált dekompozíció és beszédes, karbantartható forráskód fontosságára.
- 2020.-ban a csapatmunka házi feladat max 25 pontos lehetett és egy videót is kellet hozzá készíteni, ahol a csapat bemutatja, hogy milyen feladatokat teljesített.
Tippek
- Érdemes hétről hétre tanulni, készülni a laborokra. Nagyban megkönnyíti a tárgy elvégzését.
1. félév | |
---|---|
2. félév | |
3. félév | |
4. félév | |
5. félév | |
6. félév |