Torna indietro   Hardware Upgrade Forum > Software > Programmazione

FUJIFILM X-T30 III, la nuova mirrorless compatta
FUJIFILM X-T30 III, la nuova mirrorless compatta
FUJIFILM X-T30 III è la nuvoa fotocamera mirrorless pensata per chi si avvicina alla fotografia e ricerca una soluzione leggera e compatta, da avere sempre a disposizione ma che non porti a rinunce quanto a controllo dell'immagine.
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati
Da Las Vegas, la visione di Larry Ellison e la concretezza di Clay Magouyrk definiscono la nuova traiettoria di Oracle: portare l’intelligenza artificiale ai dati, non i dati all’intelligenza, costruendo un’infrastruttura cloud e applicativa in cui gli agenti IA diventano parte integrante dei processi aziendali, fino al cuore delle imprese europee
Micron e millisecondi: la piattaforma ServiceNow guida l'infrastruttura IT di Aston Martin F1
Micron e millisecondi: la piattaforma ServiceNow guida l'infrastruttura IT di Aston Martin F1
Dalla precisione estrema dei componenti alla gestione digitale dei processi: come la piattaforma ServiceNow consente ad Aston Martin Aramco Formula One Team di ottimizzare risorse IT e flussi operativi in un ambiente dove ogni millesimo di secondo conta
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 05-05-2010, 21:33   #1
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
[Java] Due SwingWorker contemporanei nello stesso metodo? Non vanno

Salve,

Oggi mentre provavo a giocherellare con SwingWorker e sperimentare il multithreading con Swing, ho steso queste righe di codice nel costruttore di un JPanel:

Codice:
		SwingWorker sw1 = new SwingWorker<Void, Void>()
		{
			@Override
			public Void doInBackground()
			{
				while(true)
				{
					clock.setText(Long.toString(System.currentTimeMillis()));			
					
					try
					{
						Thread.sleep(25);
					}
					catch (InterruptedException e)
					{
						Thread.currentThread().interrupt();
					}
				}
			}			
		};
		
		SwingWorker sw2 = new SwingWorker<Void, Void>()
		{
			@Override
			public Void doInBackground()
			{
				while(true)
				{
					clocc.setText(Long.toString(System.currentTimeMillis()));			
					
					try
					{
						Thread.sleep(250);
					}
					catch (InterruptedException e)
					{
						Thread.currentThread().interrupt();
					}
				}
			}			
		};
		
		sw1.execute();		
		sw2.execute();
Gli SwingWorker sw1 e sw2 si occupano di modificare in background nell'applicazione due JLabel (clock e clocc) con il tempo in millisecondi di sistema, ad intervalli diversi (non considerate che cio` possa essere possibile con altre implementazioni, e` solo un proof of concept). Quando pero` vado ad eseguirli (ultime due righe di codice), solo la JLabel clock viene modificata, clocc no.

Se commento la penultima riga sw1.execute() invece, la JLabel clocc viene modificata come previsto.

Che cosa succede? E` possibile far partire in background due SwingWorker contemporaneamente dallo stesso metodo? (In questo caso un costruttore, il codice e` stato omesso qui)

Mi aspettavo di si`, ma invece...
O c'e` qualcosa che sbaglio?
Mi aspettavo che gli SwingWorker fossero un'alternativa comoda built-in al creare un EventQueue.invokeLater in un oggetto Runnable incapsulato in un un Thread.
__________________
~
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 21:59   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Veramente a me così funziona:
Codice:
import java.awt.GridLayout;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.SwingWorker;

/**
 *
 * @author francesco
 */
public class DoubleSwingworker extends JPanel
{
    public static void main(String[] args) {
        JFrame frame = new JFrame("Double SwingWorker");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        DoubleSwingworker dsw = new DoubleSwingworker();
        frame.add(dsw);
        frame.pack();
        frame.setLocationRelativeTo(null);
        frame.setVisible(true);
    }

    private JLabel clock, clocc;

    public DoubleSwingworker() {
        super(new GridLayout(1, 2, 20, 0));

        clock = new JLabel("clock");
        clocc = new JLabel("clocc");

        add(clock);
        add(clocc);

        SwingWorker sw1 = new SwingWorker<Void, Void>() {
            @Override public Void doInBackground() {
                while(true) {
                    clock.setText(Long.toString(System.currentTimeMillis()));
                    try { Thread.sleep(25);
                    } catch (InterruptedException e) { Thread.currentThread().interrupt(); }
                }
            }
        };

        SwingWorker sw2 = new SwingWorker<Void, Void>() {
            @Override public Void doInBackground() {
                while(true) {
                    clocc.setText(Long.toString(System.currentTimeMillis()));
                    try { Thread.sleep(250);
                    } catch (InterruptedException e) { Thread.currentThread().interrupt(); }
                }
            }
        };

        sw1.execute();
        sw2.execute();
    }
}
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 05-05-2010 alle 22:02.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:04   #3
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Mi da' lo stesso problema che ho con il mio codice:



In teoria le due JLabel dovrebbero ad intervalli diversi riportare l'orario del sistema in millisecondi.
__________________
~

Ultima modifica di s12a : 05-05-2010 alle 22:11.
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:13   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Ah, beh, non saprei

Vediamo un po', prova a darci questi dati:
Versione del JDK? della JVM? Su che SO?
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:22   #5
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Ah, beh, non saprei
Credevo di starmi rincretinendo, invece c'e` davvero qualcosa di strano allora!

Quote:
Vediamo un po', prova a darci questi dati:
Versione del JDK? della JVM? Su che SO?
Java 6 Update 20 (build 1.6.0_20-b02)
Ho installate sia la versione a 32 che a 64 bit.
(Come IDE uso Eclipse per Windows, il quale e` solo a 32 bit e funziona solo abbinandogli da riga di comando la JVM a 32 bit)
OS: Windows 7 64 bit con tutti gli ultimi aggiornamenti installati.
__________________
~
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:41   #6
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Non noto niente di strano. Più che altro volevo controllare la versione del JDK, francamente.

Comunque io sono su SO WindowsXP, e come ide NetBeans.
La JDK è la 1.6.0_05.

Prova questo codice (i due SwingWorker vengono mandati in esecuzione solo quando viene aperta la finestra, non più nel costruttore):
Codice:
import java.awt.GridLayout;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
import java.awt.event.WindowListener;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.SwingWorker;

/**
 *
 * @author francesco
 */
public class DoubleSwingworker extends JPanel
{
    public static void main(String[] args) {
        JFrame frame = new JFrame("Double SwingWorker");
        frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
        DoubleSwingworker dsw = new DoubleSwingworker();
        frame.add(dsw);
        frame.addWindowListener(dsw.getListener());
        frame.pack();
        frame.setLocationRelativeTo(null);
        frame.setVisible(true);
    }

    private JLabel clock, clocc;
    private WindowListener listener;

    public DoubleSwingworker() {
        super(new GridLayout(1, 2, 20, 0));

        clock = new JLabel("clock clock clock");
        clocc = new JLabel("clocc clocc clocc");
        add(clock);
        add(clocc);

        final SwingWorker sw1 = new ClockCounter(clock, 25);
        final SwingWorker sw2 = new ClockCounter(clocc, 250);

        listener = new WindowAdapter() {
            @Override public void windowOpened(WindowEvent e) {
                sw1.execute();
                sw2.execute();
            }
        };
    }

    public WindowListener getListener() {
        return listener;
    }


    class ClockCounter extends SwingWorker<Void, Void>
    {
        final JLabel CLOCK;
        final long MILLIS;

        public ClockCounter(JLabel lab, long millis) {
            CLOCK = lab;
            MILLIS = millis;
        }

        @Override
        public Void doInBackground() {
            while (true) {
                CLOCK.setText(Long.toString(System.currentTimeMillis()));
                try {
                    Thread.sleep(MILLIS);
                } catch (InterruptedException e) { 
                    Thread.currentThread().interrupt();
                }
            }
        }
    }
}
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:44   #7
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Idem:



Mi chiedo se magari gli ultimi update abbiano introdotto qualche bug o regressione... ma ad occhio mi sembra qualcosa di troppo grosso per passare inosservato.
__________________
~
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:49   #8
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Sembra quasi che da te l'implementazione di SwingWorker usi un thread unico come worker thread...

Aggiungi queste due righe al metodo doInBackground, subito prima del while:
Codice:
System.out.println("Worker Thread launched:");
System.out.println(Thread.currentThread().getName());
A me a runtime stampa:
Quote:
run:
Worker Thread launched:
SwingWorker-pool-1-thread-2
Worker Thread launched:
SwingWorker-pool-1-thread-1
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:50   #9
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Si`, hai ragione. Questo e` quello che stampa a me.
Il secondo thread non parte:

Quote:
Worker Thread launched:
SwingWorker-pool-1-thread-1
__________________
~

Ultima modifica di s12a : 05-05-2010 alle 22:53.
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:53   #10
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Estratto dai sorgenti del mio JDK (metodo execute di SwingWorker):
Quote:
/**
* Schedules this {@code SwingWorker} for execution on a <i>worker</i>
* thread. There are a number of <i>worker</i> threads available. In the
* event all <i>worker</i> threads are busy handling other
* {@code SwingWorkers} this {@code SwingWorker} is placed in a waiting
* queue.

*
* <p>
* Note:
* {@code SwingWorker} is only designed to be executed once. Executing a
* {@code SwingWorker} more than once will not result in invoking the
* {@code doInBackground} method twice.
*/
public final void execute() {
getWorkersExecutorService().execute(this);
}
Parrebbe che da te, l'implementazione ha a disposizione solo 1 thread libero come "worker thread"... Il perchè francamente lo ignoro

Se vuoi avere confrema al 100% prova a eseguire un ciclo che termina dopo un po' nel doInBackground: finita l'esecuzione del primo SwingWorker dovresti notare la partenza del secondo...
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 22:59   #11
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Sorpresa!

E' un bug di SwingWorker.

http://bugs.sun.com/view_bug.do?bug_id=6880336

in pratica dalla 1.6._17 fino alla 20 "execute" è bloccante. Puoi aggirare il problema con:

ExecutorService pool = Executors.newFixedThreadPool(2);
pool.submit(sw1);
pool.submit(sw2);
pool.shutdown();

Ps.: il "setText" va messo nel metodo process di SwingWorker, non nel doInBackground.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!

Ultima modifica di PGI-Bis : 05-05-2010 alle 23:01.
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 23:03   #12
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Estratto dai sorgenti del mio JDK (metodo execute di SwingWorker):

Parrebe che da te, l'implementazione ha a disposizione solo 1 thread come "worker thread"... Il perchè francamente lo ignoro
Anche io

Quote:
Se vuoi avere confrema al 100% prova a eseguire un ciclo che termina dopo un po' nel doInBackground: finita l'esecuzione del primo SwingWorker dovresti notare la partenza del secondo...
Avevo gia` effettuato qualche prova precedentemente: se faccio partire il primo SwingWorker, non poi non posso far partire il secondo, neanche se interrompo il primo.

Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Sorpresa!

E' un bug di SwingWorker.

http://bugs.sun.com/view_bug.do?bug_id=6880336

in pratica dalla 1.6._17 fino alla 20 "execute" è bloccante. Puoi aggirare il problema con:

ExecutorService pool = Executors.newFixedThreadPool(2);
pool.submit(sw1);
pool.submit(sw2);
pool.shutdown();
Ah, pero`. Ed e` anche diverso tempo che sta li`!
Vedro` di tenere conto della soluzione.

Quote:
Ps.: il "setText" va messo nel metodo process di SwingWorker, non nel doInBackground.
Grazie per il suggerimento!
__________________
~

Ultima modifica di s12a : 05-05-2010 alle 23:05.
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 05-05-2010, 23:13   #13
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Sorpresa!
E' un bug di SwingWorker.
PGI, se non ci fossi, bisognerebbe inventarti!
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 12:13   #14
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Ps.: il "setText" va messo nel metodo process di SwingWorker, non nel doInBackground.
Scusate l'up, ma ho provato a documentarmi in merito e non mi e` assolutamente chiaro come implementare il tutto in process piuttosto che in doInBackground.

Lo SwingWorker qui da' problemi nel metodo process. @Override non da' nemmeno come corretto l'overloading del metodo:

Codice:
SwingWorker<Void, Void> sw1 = new SwingWorker<Void, Void>()	{
	@Override public Void doInBackground() { return null; }
	@Override protected void process(Void x) {
		while(true)	{
			try	{
				clock.setText(Long.toString(System.currentTimeMillis()));			
				Thread.sleep(25);
			} catch (InterruptedException e) {
				Thread.currentThread().interrupt();
			}
		}
	}			
};

Thread t2 = new Thread(new Runnable() {
	@Override public void run() {
		while(true) {
			try {
				SwingUtilities.invokeLater(updater);
				Thread.sleep(200);
			} catch (InterruptedException e) {
				Thread.currentThread().interrupt();
			}
		}
	}
});

sw1.execute();		
t2.start();
Per il momento trovo molto piu` pratico ed intuitivo creare un nuovo thread come da esempio qui sopra (updater e` un Runnable che aggiorna la seconda JLabel una sola volta).
__________________
~

Ultima modifica di s12a : 06-05-2010 alle 12:17.
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 13:58   #15
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Per il tipo di compito che esegue il tuo esempio è più comodo javax.swing.Timer.

Codice:
Timer timer = new Timer(periodo, new ActionListener() {
    public void actionPerformed(ActionEvent e) {
        aggiorna etichetta
    }
});
timer.start();
Bug a parte, funziona anche con SwingWorker.

Codice:
new SwingWorker<Void, Void>() {
    protected Void doInBackground() throws Exception {
        while(true) {
            Thread.sleep(25);
            publish();
        }
    }

    protected void process(List<Void> chunks) {
        etichetta.setText(System.currentTimeMillis());
    }
}.execute();
Il contenuto di doInBackground è eseguito dal thread di SwingWorker, il contenuto di process è eseguito dall'EDT.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 14:18   #16
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Per il tipo di compito che esegue il tuo esempio è più comodo javax.swing.Timer.
Si`, come scritto nel primo post questo e` solo del codice semplice per testare il concetto.

Quote:
Bug a parte, funziona anche con SwingWorker.

[...]

Il contenuto di doInBackground è eseguito dal thread di SwingWorker, il contenuto di process è eseguito dall'EDT.
Ok, grazie per l'aiuto, funziona perfettamente in questo modo!

Ecco i tre modi che ho avuto modo di provare per fare la stessa identica cosa:

Codice:
SwingWorker<Void, Void> sw1 = new SwingWorker<Void, Void>()	{
	@Override public Void doInBackground() {
		while(true)	{
			try	{
				Thread.sleep(25);
				publish();
			} catch (InterruptedException e) {
				Thread.currentThread().interrupt();
			}
		}
	}
	@Override protected void process(List<Void> chunks) {
		clock.setText(Long.toString(System.currentTimeMillis()));			
	}			
};

Thread th2 = new Thread(new Runnable() {
	private Runnable updater = new Runnable() {
		@Override public void run() {
			clocc.setText(Long.toString(System.currentTimeMillis()));
		}
	};
	
	@Override public void run() {
		while(true) {
			try {
				SwingUtilities.invokeLater(updater);
				Thread.sleep(200);
			} catch (InterruptedException e) {
				Thread.currentThread().interrupt();
			}
		}
	}
});

Timer tm3 = new Timer(350, new ActionListener() {
	@Override public void actionPerformed(ActionEvent arg0) {
		clokk.setText(Long.toString(System.currentTimeMillis()));
	}
});

sw1.execute();		
th2.start();
tm3.start();
Effettivamente il timer e` la scelta che comporta meno codice e piu` semplicita` per questa specifica operazione.
__________________
~

Ultima modifica di s12a : 06-05-2010 alle 14:30.
s12a è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 15:15   #17
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Il contenuto di doInBackground è eseguito dal thread di SwingWorker, il contenuto di process è eseguito dall'EDT.
Curiosità mia: nel caso si usi SwingWorker, ma è proprio neccessario far eseguire una setText (che è uno dei pochi metodi di Swing ad essere thread-safe) nel metodo process, invece che in doInBackground?
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 15:41   #18
PGI-Bis
Senior Member
 
L'Avatar di PGI-Bis
 
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
Direi che il setText a cui fai riferimento sia quello di JTextComponent.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me!
PGI-Bis è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 15:49   #19
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da PGI-Bis Guarda i messaggi
Direi che il setText a cui fai riferimento sia quello di JTextComponent.
Proprio quello... d'ho!
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 06-05-2010, 17:25   #20
s12a
Senior Member
 
L'Avatar di s12a
 
Iscritto dal: Jan 2008
Messaggi: 11159
Non c'entra piu` molto con lo scopo iniziale del thread, ma visto che ci siamo mi chiedevo solo se in merito a questa applicazione un po' piu` pratica di uno SwingWorker (sempre comunque di prova/a scopi didattici) fosse possibile eliminare il return null evidenziato. Per qualche motivo qui mi viene richiesto. Nella prova precedente di qualche post fa l'ho omesso e non ho avuto problemi:

Codice:
import java.awt.EventQueue;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.util.List;
import java.util.Random;

import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JPanel;
import javax.swing.JProgressBar;
import javax.swing.SwingWorker;
import javax.swing.UIManager;
import javax.swing.WindowConstants;

import net.miginfocom.swing.MigLayout;

public class ProgressPanel extends JPanel {
	ProgressPanel() {
		setLayout(new MigLayout("wrap 1"));

		progress.setMinimum(0);
		progress.setMaximum(100);
		
		add(statusLabel, "align center");
		add(progress, "grow");
		add(startButton, "grow");
		
		startButton.addActionListener(new ActionListener() {
			@Override public void actionPerformed(ActionEvent e) {
				startButton.setEnabled(false);

				new SwingWorker<Void, Void>() {
					@Override public Void doInBackground() {
						statusLabel.setText("Status: working");
						
						while(progress.getValue() < 100) {
							try	{
								Thread.sleep(rand.nextInt(30));
								publish();
							} catch (InterruptedException e) {
								Thread.currentThread().interrupt();
								System.out.println("Worker thread " + Thread.currentThread().getName() + " abnormally interrupted");
							}
						}
						
						statusLabel.setText("Status: done!");
						
						startButton.setEnabled(true);
						startButton.setText("Quit");
						startButton.addActionListener(new ActionListener() {
							@Override public void actionPerformed(ActionEvent e) {
								System.exit(0); // Temporary implementation
							}
						});
						
						return null; // ???
					}
					@Override protected void process(List<Void> chunks) {
						progress.setValue(progress.getValue() + 1);
					}
				}.execute();				
			}
		});
	}
	
	private JProgressBar progress = new JProgressBar();
	private JButton startButton = new JButton("Start processing");
	private JLabel statusLabel = new JLabel("Status: idling");
	private Random rand = new Random();

	public static void main(String[] args) {
		if (args.length > 0) {
			try {
				UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName());
			} catch (Exception e) {
				System.out.println ("Unable to set the platform Look&Feel");
			}
		}
		
		EventQueue.invokeLater(new Runnable() {
			@Override public void run() {
				JFrame frame = new JFrame("Saving file");
				frame.setDefaultCloseOperation(WindowConstants.EXIT_ON_CLOSE);
				frame.setVisible(true);				
				frame.add(new ProgressPanel());				
				frame.pack();				
			}
		});
	}
}
Nota: per qualche motivo copiaincollando il codice da Eclipse alcuni tab vengono riprodotti in maniera un po' strana, non e` colpa mia.
__________________
~

Ultima modifica di s12a : 06-05-2010 alle 17:37.
s12a è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


FUJIFILM X-T30 III, la nuova mirrorless compatta FUJIFILM X-T30 III, la nuova mirrorless compatta
Oracle AI World 2025: l'IA cambia tutto, a partire dai dati Oracle AI World 2025: l'IA cambia tutto, a parti...
Micron e millisecondi: la piattaforma ServiceNow guida l'infrastruttura IT di Aston Martin F1 Micron e millisecondi: la piattaforma ServiceNow...
ASUS GeForce RTX 5080 Noctua OC Edition: una custom fenomenale, ma anche enorme ASUS GeForce RTX 5080 Noctua OC Edition: una cus...
Dreame Aqua10 Ultra Roller, la pulizia di casa con un rullo Dreame Aqua10 Ultra Roller, la pulizia di casa c...
Object First annuncia il nuovo Ootbi Min...
IA, workplace e sicurezza per guidare la...
Amazon chiarisce il blackout AWS del 20 ...
I browser agentici non sono ancora matur...
Monitor da sogno per gamer: Alienware QD...
Anche gli LLM possono "rimbecillirs...
Offerte DJI da non perdere: droni e vide...
Anche Redmi ha il suo Pro Max: arriver&a...
Nike Project Amplify, le scarpe che ti m...
LG OLED evo G5 da 48 pollici a soli 839€...
Ricoh ha anticipato l'arrivo di una nuov...
iPhone 17 Pro non ha rivali: la fotocame...
Leica M EV1: il futuro della fotografia ...
Passione retrò: arrivano THEC64 Mini Bla...
Google risolve il problema delle pause: ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 02:16.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v