X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fjexer%2Fdemos%2FDemoMainWindow.java;h=f1cbe2122cdbb54ee2088a3fbed979d805cecfdd;hb=0525b2ed026e0d510fdf23f6d8f4cb4562a17e0b;hp=85d03414307465fe3930f881d979c2e4fc7b81f3;hpb=df602ccf5e32585c26dc618dd3b4a759b6820943;p=nikiroo-utils.git diff --git a/src/jexer/demos/DemoMainWindow.java b/src/jexer/demos/DemoMainWindow.java index 85d0341..f1cbe21 100644 --- a/src/jexer/demos/DemoMainWindow.java +++ b/src/jexer/demos/DemoMainWindow.java @@ -29,6 +29,7 @@ package jexer.demos; import java.io.*; +import java.util.*; import jexer.*; import jexer.event.*; @@ -41,21 +42,46 @@ import static jexer.TKeypress.*; */ public class DemoMainWindow extends TWindow { - // Timer that increments a number. + // ------------------------------------------------------------------------ + // Variables -------------------------------------------------------------- + // ------------------------------------------------------------------------ + + /** + * Timer that increments a number. + */ private TTimer timer; - // Timer label is updated with timer ticks. + /** + * Timer label is updated with timer ticks. + */ TLabel timerLabel; /** - * We need to override onClose so that the timer will no longer be called - * after we close the window. TTimers currently are completely unaware - * of the rest of the UI classes. + * Timer increment used by the timer loop. Has to be at class scope so + * that it can be accessed by the anonymous TAction class. */ - @Override - public void onClose() { - getApplication().removeTimer(timer); - } + int timerI = 0; + + /** + * Progress bar used by the timer loop. Has to be at class scope so that + * it can be accessed by the anonymous TAction class. + */ + TProgressBar progressBar; + + /** + * Day of week label is updated with TSpinner clicks. + */ + TLabel dayOfWeekLabel; + + /** + * Day of week to demonstrate TSpinner. Has to be at class scope so that + * it can be accessed by the anonymous TAction class. + */ + GregorianCalendar calendar = new GregorianCalendar(); + + // ------------------------------------------------------------------------ + // Constructors ----------------------------------------------------------- + // ------------------------------------------------------------------------ /** * Construct demo window. It will be centered on screen. @@ -66,11 +92,6 @@ public class DemoMainWindow extends TWindow { this(parent, CENTERED | RESIZABLE); } - // These are used by the timer loop. They have to be at class scope so - // that they can be accessed by the anonymous TAction class. - int timerI = 0; - TProgressBar progressBar; - /** * Constructor. * @@ -86,7 +107,7 @@ public class DemoMainWindow extends TWindow { // Add some widgets addLabel("Message Boxes", 1, row); - addButton("&MessageBoxes", 35, row, + TWidget first = addButton("&MessageBoxes", 35, row, new TAction() { public void DO() { new DemoMsgBoxWindow(getApplication()); @@ -105,7 +126,7 @@ public class DemoMainWindow extends TWindow { ); row += 2; - addLabel("Text fields", 1, row); + addLabel("Text fields and calendar", 1, row); addButton("Field&s", 35, row, new TAction() { public void DO() { @@ -115,11 +136,11 @@ public class DemoMainWindow extends TWindow { ); row += 2; - addLabel("Radio buttons and checkboxes", 1, row); - addButton("&Checkboxes", 35, row, + addLabel("Radio buttons, check and combobox", 1, row); + addButton("&CheckBoxes", 35, row, new TAction() { public void DO() { - new DemoCheckboxWindow(getApplication()); + new DemoCheckBoxWindow(getApplication()); } } ); @@ -197,12 +218,43 @@ public class DemoMainWindow extends TWindow { timerLabel.setWidth(timerLabel.getLabel().length()); if (timerI < 100) { timerI++; + } else { + timer.setRecurring(false); } progressBar.setValue(timerI); } } ); + dayOfWeekLabel = addLabel("Wednesday-", 35, row - 1, "tmenu", false); + dayOfWeekLabel.setLabel(String.format("%-10s", + calendar.getDisplayName(Calendar.DAY_OF_WEEK, + Calendar.LONG, Locale.getDefault()))); + + addSpinner(35 + dayOfWeekLabel.getWidth(), row - 1, + new TAction() { + public void DO() { + calendar.add(Calendar.DAY_OF_WEEK, 1); + dayOfWeekLabel.setLabel(String.format("%-10s", + calendar.getDisplayName( + Calendar.DAY_OF_WEEK, Calendar.LONG, + Locale.getDefault()))); + } + }, + new TAction() { + public void DO() { + calendar.add(Calendar.DAY_OF_WEEK, -1); + dayOfWeekLabel.setLabel(String.format("%-10s", + calendar.getDisplayName( + Calendar.DAY_OF_WEEK, Calendar.LONG, + Locale.getDefault()))); + } + } + ); + + + activate(first); + statusBar = newStatusBar("Demo Main Window"); statusBar.addShortcutKeypress(kbF1, cmHelp, "Help"); statusBar.addShortcutKeypress(kbF2, cmShell, "Shell"); @@ -210,6 +262,20 @@ public class DemoMainWindow extends TWindow { statusBar.addShortcutKeypress(kbF10, cmExit, "Exit"); } + // ------------------------------------------------------------------------ + // TWindow ---------------------------------------------------------------- + // ------------------------------------------------------------------------ + + /** + * We need to override onClose so that the timer will no longer be called + * after we close the window. TTimers currently are completely unaware + * of the rest of the UI classes. + */ + @Override + public void onClose() { + getApplication().removeTimer(timer); + } + /** * Method that subclasses can override to handle posted command events. *