„2. Java ablakkezelés, Swing összefoglaló (2012)” változatai közötti eltérés

A VIK Wikiből
Ferrero (vitalap | szerkesztései)
Nincs szerkesztési összefoglaló
Nagy Marcell (vitalap | szerkesztései)
a autoedit v2: fájlhivatkozások egységesítése, az új közvetlenül az adott fájlra mutat
 
(7 közbenső módosítás, amit 3 másik szerkesztő végzett, nincs mutatva)
1. sor: 1. sor:
__TOC__
__TOC__


==2.1. AWT (Abstract Window Toolkit)==
==Az oldal rengeteg hibát tartalmaz, tanulj inkább a diákból!==
Jelöld a hibákat. Ezzel a kijelentéssel érdemileg nem javítottál a wiki-n.
--[[Szerkesztő:Ferrero|Szabó Csaba]] ([[Szerkesztővita:Ferrero|vita]]) 2013. május 29., 17:28 (UTC)
 
==AWT (Abstract Window Toolkit)==


* natív kinézetű, natív implementációjú megjelenítő könyvtár
* natív kinézetű, natív implementációjú megjelenítő könyvtár
12. sor: 16. sor:
* elhelyezés: LayoutManager (Strategy pattern!)
* elhelyezés: LayoutManager (Strategy pattern!)


==2.2. Eseménykezelés==
==Eseménykezelés==


* public boolean handleEvent, mouseDown, keyDown, action(Event e, ...)
* public boolean handleEvent, mouseDown, keyDown, action(Event e, ...)
23. sor: 27. sor:
* xxxEventAdapter - xxxEventListener megvalósítása üres metódusokkal
* xxxEventAdapter - xxxEventListener megvalósítása üres metódusokkal


==2.3. Fókusz-kezelés==
==Fókusz-kezelés==


* azé a billentyűzet-input, akinél a fókusz van
* azé a billentyűzet-input, akinél a fókusz van
65. sor: 69. sor:
** requestFocusInWindow()
** requestFocusInWindow()


==2.4. Layout managerek==
==Layout managerek==


* az ő feladatuk a Containerben lévő elemek elhelyezése
* az ő feladatuk a Containerben lévő elemek elhelyezése
86. sor: 90. sor:


* NORTH, SOUTH, EAST, WEST és CENTER elhelyezés
* NORTH, SOUTH, EAST, WEST és CENTER elhelyezés
[[Fájl:borderlayout.png]]
[[File:borderlayout.png]]


===FlowLayout===
===FlowLayout===
92. sor: 96. sor:
* sorban egymás mellé
* sorban egymás mellé
* LEFT, RIGHT, CENTER, LEADING, TRAILING orientációval
* LEFT, RIGHT, CENTER, LEADING, TRAILING orientációval
[[Fájl:flowlayout.png]]
[[File:flowlayout.png]]


===CardLayout===
===CardLayout===
101. sor: 105. sor:


* táblázatos, sorok/oszlopok száma rögzíthető
* táblázatos, sorok/oszlopok száma rögzíthető
[[Fájl:gridlayout.png]]
[[File:gridlayout.png]]


===GridBagLayout===
===GridBagLayout===
108. sor: 112. sor:
* GridBagConstraint segít az elrendezésben (gridx/y, gridwidth/height, weightx/y, ipadx/y, insets, fill, anchor)
* GridBagConstraint segít az elrendezésben (gridx/y, gridwidth/height, weightx/y, ipadx/y, insets, fill, anchor)


[[Fájl:gridbaglayout.png]]
[[File:gridbaglayout.png]]
 


===BoxLayout (Swing)===
===BoxLayout (Swing)===


* kb. FlowLayout, csak nem tör a sor végén hanem nyújt
* kb. FlowLayout, csak nem tör a sor végén hanem nyújt
[[Fájl:boxlayout.png]]
[[File:boxlayout.png]]


===SpringLayout (Swing)===
===SpringLayout (Swing)===


* rugalmas táblázat, formok egyszerű megjelenítésére
* rugalmas táblázat, formok egyszerű megjelenítésére
[[Fájl:springlayout.png]]
[[File:springlayout.png]]


===GroupLayout (Swing)===
===GroupLayout (Swing)===
* egymásba ágyazott csoportok, soros/párhuzamos elhelyezésben
* egymásba ágyazott csoportok, soros/párhuzamos elhelyezésben
[[Fájl:grouplayout.png]]
[[File:grouplayout.png]]


==2.5. Swing==
==Swing==


* Java-ban megírt, platformfüggetlen
* Java-ban megírt, platformfüggetlen
165. sor: 168. sor:
===JTree===
===JTree===


* modellje: BinTreeModel
* modellje: TreeModel


====BinTreeModel====
====TreeModel====


* változásakor eseményt küld a TreeModelListener-eknek
* változásakor eseményt küld a TreeModelListener-eknek
175. sor: 178. sor:
* public void insert(double d)
* public void insert(double d)


==2.6. Drag and Drop==
==Drag and Drop==


* JComponent.setDragEnabled(boolean b)
* JComponent.setDragEnabled(boolean b)
213. sor: 216. sor:
* DropLocation getDropLocation()
* DropLocation getDropLocation()


==2.7. Szálkezelés==
==Szálkezelés==


* a Swing nem szálbiztos
* a Swing nem szálbiztos
236. sor: 239. sor:
** DONE -> megállt
** DONE -> megállt


==2.8. Beágyazott==
==Beágyazott==


* kevés erőforrás, kicsi memória és CPU
* kevés erőforrás, kicsi memória és CPU

A lap jelenlegi, 2017. július 12., 15:14-kori változata

Az oldal rengeteg hibát tartalmaz, tanulj inkább a diákból!

Jelöld a hibákat. Ezzel a kijelentéssel érdemileg nem javítottál a wiki-n. --Szabó Csaba (vita) 2013. május 29., 17:28 (UTC)

AWT (Abstract Window Toolkit)

  • natív kinézetű, natív implementációjú megjelenítő könyvtár

Container

  • konténer elemek: Panel, ScrollPane, Window, Frame, stb.
  • komponensek megtalálása: pozíció, sorszám, listázás
  • fókusz továbbadása
  • elhelyezés: LayoutManager (Strategy pattern!)

Eseménykezelés

  • public boolean handleEvent, mouseDown, keyDown, action(Event e, ...)
  • eseményre meghívja az fenti függvényeket (Observer pattern!)
  • ha a visszatérés false, az esemény feljebb gyűrűzik

xxxEventListener, xxxEventAdapter

  • xxxEventListener - minden függvényt tartalmazó interfész
  • xxxEventAdapter - xxxEventListener megvalósítása üres metódusokkal

Fókusz-kezelés

  • azé a billentyűzet-input, akinél a fókusz van

KeyEventDispatcher interfész

  • az implementáló osztály a focus owner előtt elkaphatja az eseményt
  • boolean dispatchKeyEvent(KeyEvent e) // továbbadódjon-e
  • KeyboardFocusManager-nél kell regisztrálni

KeyEventPostProcessor interfész

  • az implementáló osztály a focus owner után elkaphatja az eseményt
  • boolean postProcessKeyEvent(KeyEvent e) // továbbadódjon-e
  • KeyboardFocusManager-nél kell regisztrálni

WindowEvent, FocusEvent

  • fókusz elvesztés/elnyerés sorrendje:
Frame F2-ben K2 komponensre kattintunk
  K1: FOCUS_LOST // K1 Component elveszti
  F1: WINDOW_LOST_FOCUS // F1 Frame elveszti
  F1: WINDOW_DEACTIVATED // F1 Window elveszti
  F2: WINDOW_ACTIVATED // F2 Window elnyeri
  F2: WINDOW_GAINED_FOCUS // F2 Frame elnyeri
  K2: FOCUS_GAINED // K2 Component elnyeri
  • lehetséges a fókusz ideiglenes elkérése (scrollbar)

Fókusz továbbadás

  • fókuszváltó billentyűk újrakonfigurálása:
    • !setFocusTraversalKeys(int id, Set< extends AWTKeyStroke> keystrokes)
    • KeyboardFocusManager.XXX_TRAVERSAL_KEYS: FORWARD, BACKWARD, UP_CYCLE
  • FocusTraversalPolicy - fókusz továbbadási sorrend definiálása
  • Programozott továbbadás
    • KeyboardFocusManager: focusNextComponent(Component) // up, down, next, previous
    • Component: transferFocus() // up, down, back
    • requestFocusInWindow()

Layout managerek

  • az ő feladatuk a Containerben lévő elemek elhelyezése

Container

  • setLayout()/getLayout() - layout manager beállítása
  • validate() - tartalmazott elemek pozíciójának frissítése
  • add() - új elem hozzáadása (adott pozícióra)

LayoutManager

  • void layoutContainer(Container parent) - Container layoutjának beállítása
  • void addLayoutComponent(String name, Component comp) - új elem hozzáadása
  • Dimension maximum/preferred/minimumLayoutSize(Container parent) - méretbeállítás
  • float getLayoutAlignmentX/Y(Container target) - X/Y irányú igazítás
  • void invalidateLayout(Container target) - elrendezés érvénytelenítése

BorderLayout

  • NORTH, SOUTH, EAST, WEST és CENTER elhelyezés

FlowLayout

  • sorban egymás mellé
  • LEFT, RIGHT, CENTER, LEADING, TRAILING orientációval

CardLayout

  • mindig csak a legfelső látszik, lapozhatunk közöttük

GridLayout

  • táblázatos, sorok/oszlopok száma rögzíthető

GridBagLayout

  • táblázat összevont cellákkal
  • GridBagConstraint segít az elrendezésben (gridx/y, gridwidth/height, weightx/y, ipadx/y, insets, fill, anchor)

BoxLayout (Swing)

  • kb. FlowLayout, csak nem tör a sor végén hanem nyújt

SpringLayout (Swing)

  • rugalmas táblázat, formok egyszerű megjelenítésére

GroupLayout (Swing)

  • egymásba ágyazott csoportok, soros/párhuzamos elhelyezésben

Swing

  • Java-ban megírt, platformfüggetlen
  • MVC architektúrát használ
  • egyszerű komponensek: +J betű
  • AWT-hez hasonló eseménykezelés

JList

  • nem méretezhető: JScrollPane-be kell tenni (Decorator pattern!)
  • elemeket adó modell lehet: ListModel, Vector, Object[]

ListModel interfész

  • Object getElementAt(int index)
  • int getSize()
  • void add/removeListDataListener(ListDataListener l)
  • implementáció pl. DefaultListModel (add/get/remove)

ListDataListener

  • modell változásakor meghívott eseménykezelő
  • void intervalAdded/Removed(ListDataEvent e)
  • void contentsChanged(ListDataEvent e)

JTable

  • modellje: TableModel
  • görgetéshez JScrollPane kell

TableModel

  • változásakor eseményt küld a TableModelListener-eknek
  • boolean isCellEditable(int r, int c)
  • String getColumnName(int col)
  • void get/setValueAt(Object aValue, int rowIndex, int columnIndex)
  • int getRow/ColumnCount()

JTree

  • modellje: TreeModel

TreeModel

  • változásakor eseményt küld a TreeModelListener-eknek
  • public Object getChild(Object parent, int index)
  • public Object getRoot()
  • public boolean isLeaf(Object node)
  • public void insert(double d)

Drag and Drop

  • JComponent.setDragEnabled(boolean b)
  • setDropMode(DropMode dm) - elemek közé/elemre/stb. dobja

DataFlavor

  • adatformátumokat tárol, ami megjelenhet a drag and drop-ban (és a vágólap és fájrendszerben)
  • DataFlavor(Class representationClass, String humanPresentableName)

Transferable

  • interfész adatok átvitelére
  • Object getTransferData(DataFlavor flavor)
  • DataFlavor[] getTransferDataFlavors()
  • boolean isDataFlavorSupported(DataFlavor flavor)

TransferHandler

  • segítségével testre szabhatjuk a komponens drag&drop viselkedését
  • JComponent.setTransferHandler(TransferHandler th)
  • int getSourceActions(JComponent): COPY, MOVE, LINK
  • Transferable createTransferable(JComponent)
  • void exportDone(JComponent c, Transferable t, int action)
  • boolean canImport(TransferHandler.TransferSupport ts)
  • boolean importData(TransferHandler.TransferSupport ts)

TransferSupport

  • segít Drag and Drop lebonyolításában: résztvevő komponensek, adat, stb. tárolása
  • Component getComponent()
  • int getDropAction()
  • int getSourceDropActions()
  • DataFlavor[] getDataFlavors()
  • boolean isDataFlavorSupported(DataFlavor)
  • Transferable getTransferable()
  • DropLocation getDropLocation()

Szálkezelés

  • a Swing nem szálbiztos
  • alapból egy szálon fut az eseménykezelés és megjelenítés
  • SwingUtilities.invokeLater(Runnable r) vagy .invokeAndWait(Runnable r) különszálas GUI építésre

SwingWorker

  • új szálként viselkedik, hosszabb számítások esetén hasznos
  • visszatérési értéke van
  • protected abstract T doInBackground() - elvégzendő munka implementálása
  • void execute() - szál indítása
  • protected void done() - befejezéskor meghívódik
  • T get(long timeout, TimeUnit unit) - visszatérési érték lekérdezése
  • void setProgress(int i) - munka állása százalékban
  • void cancel(boolean mayInterruptIfRunning) - futás megszakítása
  • protected final void publish(V... chunks) - köztes futási eredményeket küld az eseménykezelő szálnak
  • protected void process(List<V> chunks) - átveszi a köztes eredményeket
  • public final SwingWorker.StateValue getState():
    • PENDING -> indítás előtt
    • STARTED -> fut, de még nem állt le
    • DONE -> megállt

Beágyazott

  • kevés erőforrás, kicsi memória és CPU
  • folyamatos VM futás, nem ragadhatnak be objektumok a memóriába
  • listener eseménykezelő nem nyerő, Whiteboard kell (l. tervezési minták)

-- MeszegetoBalazsIstvan - 2008.05.27.
-- Velias - 2009.05.27. --Szabó Csaba (vita) 2012. december 16., 14:18 (CET)