Dialogy a vyskakovací okna
Z MiS
(Rozdíly mezi verzemi)
(Přidán filtr souborů vybraného typu.) |
(→Dialogy pro výběr souboru: Změna struktury JFileChooser, doplnění volby cesty dodatečně.) |
||
Řádka 23: | Řádka 23: | ||
== Dialogy pro výběr souboru == | == Dialogy pro výběr souboru == | ||
* Dialogy pro výběr souboru realizuje třída <code>JFileChooser</code> z balíčku <code>javax.swing</code>. | * Dialogy pro výběr souboru realizuje třída <code>JFileChooser</code> z balíčku <code>javax.swing</code>. | ||
+ | |||
+ | ; Zobrazení jednotlivých typů dialogu: | ||
+ | * Třída má předdefinované dialogy pro otevření a uložení a můžeme si vytvořit i dialog s vlastním popisem. | ||
* Dialogy mají společný základ, liší se v detailech chování a v popisu tlačítek. | * Dialogy mají společný základ, liší se v detailech chování a v popisu tlačítek. | ||
− | * | + | * K dispozici jsou: |
− | * | + | ** <code>showOpenDialog</code> |
+ | ** <code>showSaveDialog</code> | ||
+ | ** <code>showDialog</code>... zde zadáváme jako parametr i popis dialogu | ||
+ | * Při zobrazení dáváme jako parametr rodičovské okno — dialog bude umístěn uprostřed okna. | ||
+ | |||
+ | JFileChooser fc = new JFileChooser(); | ||
+ | fc.showOpenDialog(this); | ||
+ | |||
+ | ; Návratová hodnota a vybraný soubor? | ||
+ | * Dialog vrací návratovou hodnotu, kterou můžeme porovnat s konstantou <code>JFileChooser.APPROVE_OPTION</code> a zjistit tak, jestli uživatel potvrdil výběr souboru. | ||
+ | * Vybraný soubor získáme voláním metody <code>getSelectedFile()</code>. | ||
+ | |||
+ | JFileChooser fc = new JFileChooser(); | ||
+ | int result = fc.showOpenDialog(this); | ||
+ | if (result == JFileChooser.APPROVE_OPTION) { | ||
+ | File selectedFile = fc.getSelectedFile(); | ||
+ | System.out.println("Uživatel vybral soubor: "+selectedFile.getPath()); | ||
+ | } else { | ||
+ | System.out.println("Uživatel ukončil dialog bez výběru souboru." | ||
+ | System.out.println("Například zvolil Storno/Cancel."); | ||
+ | } | ||
+ | |||
+ | ; Výchozí cesta (path) | ||
* Pokud v konstruktoru předáme cestu ke složce, otevře se dialog na začátku v této složce. | * Pokud v konstruktoru předáme cestu ke složce, otevře se dialog na začátku v této složce. | ||
JFileChooser fc = new JFileChooser("."); | JFileChooser fc = new JFileChooser("."); | ||
− | * Instance < | + | * Instance <code>JFileChooser</code> si mezi jednotlivými voláními pamatuje naposledy použitou cestu. Je tedy vhodné používat po celou dobu běhu aplikace jednu instanci. |
+ | |||
+ | * Dodatečně lze výchozí cestu nastavit pomocí metody <code>setCurrentDirectory(...)</code>. | ||
− | |||
− | |||
− | |||
− | |||
; Nastavení filtru souborů zvoleného typu | ; Nastavení filtru souborů zvoleného typu | ||
* Můžeme nastavit, že dialog bude nabízet jen soubory s vybranými příponami. | * Můžeme nastavit, že dialog bude nabízet jen soubory s vybranými příponami. | ||
fc.setFileFilter(new FileNameExtensionFilter("Obrázky", "png", "jpg")); | fc.setFileFilter(new FileNameExtensionFilter("Obrázky", "png", "jpg")); | ||
− | |||
− | |||
− | |||
− | |||
; Příklad použití: | ; Příklad použití: |
Aktuální verze z 7. 3. 2023, 07:36
Vyskakovací okna
- Vyskakovací okno (message box) je modální — běh aplikace se přeruší, dokud uživatel nepotvrdí okno.
- K vyvolání okna slouží třída
JOptionPane
z balíčkujavax.swing
. - Vyskakovací okno by mělo vyskočit uprostřed okna, ze kterého je vyvoláno, proto potřebuje odkaz na své rodičovské okno.
- Rodičovské okno předáváme jako první parametr.
- Pokud předáme
null
, bude vyskakovací okno uprostřed obrazovky.
- Jako poslední parametr předáváme typ okna:
-
JOptionPane.ERROR_MESSAGE
-
JOptionPane.WARNING_MESSAGE
-
JOptionPane.INFORMATION_MESSAGE
-
- Příklad
if (chyba > 3) { JOptionPane.showMessageDialog(null, "Tohle píši ve vyskakovacím okně!", "Titulek okna", JOptionPane.WARNING_MESSAGE); }
Dialogy pro výběr souboru
- Dialogy pro výběr souboru realizuje třída
JFileChooser
z balíčkujavax.swing
.
- Zobrazení jednotlivých typů dialogu
- Třída má předdefinované dialogy pro otevření a uložení a můžeme si vytvořit i dialog s vlastním popisem.
- Dialogy mají společný základ, liší se v detailech chování a v popisu tlačítek.
- K dispozici jsou:
-
showOpenDialog
-
showSaveDialog
-
showDialog
... zde zadáváme jako parametr i popis dialogu
-
- Při zobrazení dáváme jako parametr rodičovské okno — dialog bude umístěn uprostřed okna.
JFileChooser fc = new JFileChooser(); fc.showOpenDialog(this);
- Návratová hodnota a vybraný soubor?
- Dialog vrací návratovou hodnotu, kterou můžeme porovnat s konstantou
JFileChooser.APPROVE_OPTION
a zjistit tak, jestli uživatel potvrdil výběr souboru. - Vybraný soubor získáme voláním metody
getSelectedFile()
.
JFileChooser fc = new JFileChooser(); int result = fc.showOpenDialog(this); if (result == JFileChooser.APPROVE_OPTION) { File selectedFile = fc.getSelectedFile(); System.out.println("Uživatel vybral soubor: "+selectedFile.getPath()); } else { System.out.println("Uživatel ukončil dialog bez výběru souboru." System.out.println("Například zvolil Storno/Cancel."); }
- Výchozí cesta (path)
- Pokud v konstruktoru předáme cestu ke složce, otevře se dialog na začátku v této složce.
JFileChooser fc = new JFileChooser(".");
- Instance
JFileChooser
si mezi jednotlivými voláními pamatuje naposledy použitou cestu. Je tedy vhodné používat po celou dobu běhu aplikace jednu instanci.
- Dodatečně lze výchozí cestu nastavit pomocí metody
setCurrentDirectory(...)
.
- Nastavení filtru souborů zvoleného typu
- Můžeme nastavit, že dialog bude nabízet jen soubory s vybranými příponami.
fc.setFileFilter(new FileNameExtensionFilter("Obrázky", "png", "jpg"));
- Příklad použití
JFileChooser fc = new JFileChooser("."); ... fc.setFileFilter(new FileNameExtensionFilter("Project files", "csv", "prj")); int vysledek = fc.showOpenDialog(this); if (vysledek == JFileChooser.APPROVE_OPTION) { File zvolenySoubor = fc.getSelectedFile(); Otevři soubor a zpracuj ho... }
- Další zdroje