PDA

View Full Version : [Java] undecorated as full screen?


ally
29-11-2010, 11:58
...sto smanacciando con alcuni applicativi che necessitano di funzionare in full screen...per impedirne la chiusura da parte degli utenti e per rendere il tutto piu' carino ho deciso di eliminare le cornici sfruttando jframe.setUndecorated(true); ...il problema si presenta quando decido di mettere sopra questa finestra java un filmato tramite mplayer come player video...comandi come l'ontop su file di configurazione o above tramite il gestore di finestre devilspie vengono ignorati nel caso in cui java abbia clausola undecorated attiva...nel caso contrario il tutto funge...in sinto il problema sorge perchè mplayer perde l'ontop quando qualcuno usa l'interfaccia java se questa ha proprietà undecorated...come se prendesse il sopravvento su tutte le altre finestre...è un bug noto?...o una proprietà nota?...idee per risolvere il problema?...

ally
29-11-2010, 12:01
...il titolo piu' adatto sarebbe stato undecorated as on top?...

banryu79
29-11-2010, 12:25
Fammi capire, quando dici che la tua finestra java è in fullscreen intendi semplicemente che è massimizzata in larghezza e altezza oppure che funziona in fullscreen mode (rendering attivo)?

Comunque metto già le mani avanti: a parte la conoscenza di Swing è di qualche particolare interazione con il window manager dei sistemi Windows, non ho esperienze con mplayer, devilspie e window manager dei sitemi linux.

Non vuoi la "title bar" della finestra per evitare sia la chiusura della stessa che la riduzione a icona e/o ridimensionamenti vari?
Perchè se la versione undecorated ti crea questi problemi potresti visualizzare la finestra come al solito e impostare (sto ipotizzando l'uso di Swing e di JFrame):
- la "default close operation" a "DO NOTHING";
- rendere il JFrame non ridimensionabile con "setResizable(false)";
- registrare un WindowListener (o WindowAdapter) che risponde agli eventi "window closing", "window iconified" negando l'operazione e, volendo, mostrando una Dialog modale all'utente che lo informa del fatto.

Sempre se una simile soluzione è per te accettabile.

ally
29-11-2010, 12:28
Fammi capire, quando dici che la tua finestra java è in fullscreen intendi semplicemente che è massimizzata in larghezza e altezza oppure che funziona in fullscreen mode (rendering attivo)?

Comunque metto già le mani avanti: a parte la conoscenza di Swing è di qualche particolare interazione con il window manager dei sistemi Windows, non ho esperienze con mplayer, devilspie e window manager dei sitemi linux.


...setSize scelto da me...è una jframe normalissima senza appunto la barra di ridimensionamento/chiusura...potrebbe anche non occupare tutto il video...il risultato è come un full screen...ma non ho lanciato nulla di simile in realtà...l'ambiente è linux ubuntu 9.10...

banryu79
29-11-2010, 12:34
Up: ho editato il mio primo post.

ally
29-11-2010, 12:43
Up: ho editato il mio primo post.

...si si letto ora...il mio intento è eliminare la barra per occupare tutta l'area utile...sarà un client usato per un solo scopo non midificabile dagli utenti...

banryu79
29-11-2010, 12:56
...si si letto ora...il mio intento è eliminare la barra per occupare tutta l'area utile...sarà un client usato per un solo scopo non midificabile dagli utenti...
Beh, usa un "truccone sporco": il tuo sistema vuole la finestra con la "title bar"?
E tu dagliela, basta solo che la posizioni a video (setBounds, oppure setLocation + setSize, dopo aver fatto i calcoli, tenendo conto che dovrai nascondere anche gli "insets" della finestra, cioè anche i bordi snx, dx, e inferiore) in modo opportuno.
Solo che come soluzione non è portabile perchè dipende dal LnF e dal sistema ospite. Di sicuro impedisce al mouse utente di andare a cliccare dove non deve :D

Poi comunque undecorated o no se (su windows, ad esempio) uno preme la combinazione ALT+F4 oppure ALT+TAB il danno è fatto: non basta che la finestra sia undecorated per "disabilitare" questi comportamenti.

ally
29-11-2010, 13:51
Beh, usa un "truccone sporco": il tuo sistema vuole la finestra con la "title bar"?
E tu dagliela, basta solo che la posizioni a video (setBounds, oppure setLocation + setSize, dopo aver fatto i calcoli, tenendo conto che dovrai nascondere anche gli "insets" della finestra, cioè anche i bordi snx, dx, e inferiore) in modo opportuno.
Solo che come soluzione non è portabile perchè dipende dal LnF e dal sistema ospite. Di sicuro impedisce al mouse utente di andare a cliccare dove non deve :D

Poi comunque undecorated o no se (su windows, ad esempio) uno preme la combinazione ALT+F4 oppure ALT+TAB il danno è fatto: non basta che la finestra sia undecorated per "disabilitare" questi comportamenti.

...gnome non è contento che vengano nascoste le barre delle applicazioni...non permette giochini di questo tipo...il sistema finale sarà privo di tastiera quindi il problema non si pone...

ally
29-11-2010, 13:52
...resta da capire per quale motivo l'undecorated prende caratteristiche di always on top...

banryu79
29-11-2010, 14:16
In pratica stai lavorando su un sistema kiosk-like?
Prova a fare così per rendere la tua finestra undecorated:

JFrame frame = new JFrame();
frame.setUndecorated(true);
frame.getRootPane().setWindowDecorationStyle(JRootPane.FRAME);


La terza riga in teoria dice che, se possibile, si vuole sia il LnF a provvedere per le decorazioni dei frame swing, invece che il window manager del sistema. Non so se la cosa risolva il tuo problema, tentar non nuoce. Per sapere se il LnF corrente supporta le window decoration bisogna invocare javax.swing.LookAndFeel.getSupportsWindowDecorations().

Ho trovato questo esempio nei javadoc: parti dalla documentazione di javax.swing.JFrame, metodo "setUndecorated", c'è un link di tipo "see also" per JFrame.setDefaultLookAndFeelDecorated e nella descrizione spiega tutto.

Comunque non ho capito una cosa: la finestra con mplayer e la finestra estesa a tutto schermo sono la stessa finestra o sono due finestre diverse?
Se sono due finestre diverse è importante che, dato che quella estesa e undecorated viene, da quanto dici, considerata come "alwaysOnTop", anche la seconda finestra (quella con mplayer) sia impostata come "alwaysOnTop" e all'apertura di quest'ultima la "mandi davanti" con una chiamta a 'toFront' (e di converso, puoi provare a mandare 'toBack' quella full screen).

ally
29-11-2010, 14:44
...ottimo spunto...tornando al discorso principale...non ho mai detto a java di mettere il frame on top...anzi da file di configurazione e tramite devilspie ho detto a mplayer di stare sempre on top...ma java despota fa bello sfoggio di se sopra tutte le finestre...

banryu79
29-11-2010, 15:15
Scusa, chiariamo una cosa che temo di non aver capito bene: ma la finestra di mplayer è in pratica un altro processo che gira fuori della JVM e non c'entra nulla con la tua applicazione Java (a parte il fatto di essere appunto lanciato come processo esterno)?

In questo caso non so proprio come aiutarti. Non c'è modo di embeddare mplayer in una finestra Swing? Magari come finestra "principale" dell'applicazione potresti usare una JDesktopPane massimizzata e per le finestre figlie dei JInternalFrame: avresti così creato una sorta di desktop "sintetico".
Se anche il JDesktopPane undecorated venisse creato sempre con quell'effetto collaterale di essere "alwaysOnTop" i JInternalFrame, in quanto figli contenuti nella "client area" di JDesktopPane, sarebbero sempre visibili (e tra l'altro potresti gestirne esplicitamente lo z-order tramite Swing).

ally
29-11-2010, 15:32
...il cruccio è che l'undecorated non dovrebbe comportarsi così...tutte le finestre di tutte le altre applicazioni non riescono a disegnare sopra mplayer settato on top...ma java in undecorated per qualche malsano motivo lo fa...

banryu79
29-11-2010, 16:02
...il cruccio è che l'undecorated non dovrebbe comportarsi così...
E daje :D questo l'ho capito, sono altri gli aspetti della tua situazione che non ho compreso bene.
Per un caso come questo ci vorrebe il "dottor" Pgi, o qualcuno che mastica bene Swing e ha esperienza sul sitema su cui stai lavorando.

ally
29-11-2010, 16:05
E daje :D questo l'ho capito, sono altri gli aspetti della tua situazione che non ho compreso bene.
Per un caso come questo ci vorrebe il "dottor" Pgi, o qualcuno che mastica bene Swing e ha esperienza sul sitema su cui stai lavorando.

...ah ah...si scusa...era per ribadire che a mio avviso il problema non sta nel codice...ma in altro luogo...

banryu79
29-11-2010, 16:36
...ah ah...si scusa...era per ribadire che a mio avviso il problema non sta nel codice...ma in altro luogo...
eh, eh, colpa mia, non sono stato esplicito: sono d'accordo con te, quello che descrivi sembrerebbe un bug, ma non ne sono certo al 100%, non conoscendo il window manager del tuo sistema.
Io invece cercavo di suggerirti dei work-around, per quello stavo tentando di comprende bene il tuo contesto applicativo.

ally
29-11-2010, 16:55
eh, eh, colpa mia, non sono stato esplicito: sono d'accordo con te, quello che descrivi sembrerebbe un bug, ma non ne sono certo al 100%, non conoscendo il window manager del tuo sistema.
Io invece cercavo di suggerirti dei work-around, per quello stavo tentando di comprende bene il tuo contesto applicativo.

...per ora ho risolto mettendo l'undecorated a false e usando devilspie per eliminare le barre menu...delegando quindi al so il compito di amministrare l'estetica delle finestre...