X-Git-Url: http://git.nikiroo.be/?a=blobdiff_plain;f=src%2Fbe%2Fnikiroo%2Fjvcard%2Ftui%2FTuiLauncher.java;h=deb09d4636e499c0cd5f2d3357e747309c9ec7c6;hb=6b6a62ca3293ed5f52ee07ee3d39e920d42ba887;hp=efaa68939421e8f24e89a4d5aa02672a34fdf310;hpb=a3b510ab4bf89a7a2a05f3851ffe0f030b8a78f4;p=jvcard.git diff --git a/src/be/nikiroo/jvcard/tui/TuiLauncher.java b/src/be/nikiroo/jvcard/tui/TuiLauncher.java index efaa689..deb09d4 100644 --- a/src/be/nikiroo/jvcard/tui/TuiLauncher.java +++ b/src/be/nikiroo/jvcard/tui/TuiLauncher.java @@ -2,6 +2,7 @@ package be.nikiroo.jvcard.tui; import java.io.IOException; +import com.googlecode.lanterna.TerminalSize; import com.googlecode.lanterna.TextColor; import com.googlecode.lanterna.gui2.DefaultWindowManager; import com.googlecode.lanterna.gui2.EmptySpace; @@ -10,22 +11,18 @@ import com.googlecode.lanterna.gui2.Window; import com.googlecode.lanterna.screen.Screen; import com.googlecode.lanterna.screen.TerminalScreen; import com.googlecode.lanterna.terminal.DefaultTerminalFactory; +import com.googlecode.lanterna.terminal.ResizeListener; import com.googlecode.lanterna.terminal.Terminal; -/* - * - * Change in Lanterna3 (issue and fix reported to GitHub): - * - * java.lang.StringIndexOutOfBoundsException: String index out of range: 83 - * at java.lang.String.charAt(String.java:686) - * at com.googlecode.lanterna.TerminalTextUtils.getWordWrappedText(TerminalTextUtils.java:237) - * +/** + * Starting the TUI. * + * @author niki + * */ - public class TuiLauncher { - public static void start(Boolean textMode, Window win) - throws IOException { + + static public void start(Boolean textMode, Window win) throws IOException { Terminal terminal = null; DefaultTerminalFactory factory = new DefaultTerminalFactory(); @@ -38,6 +35,17 @@ public class TuiLauncher { terminal = factory.createTerminalEmulator(); } + if (win instanceof MainWindow) { + final MainWindow mwin = (MainWindow) win; + mwin.refresh(terminal.getTerminalSize()); + terminal.addResizeListener(new ResizeListener() { + @Override + public void onResized(Terminal terminal, TerminalSize newSize) { + mwin.refresh(newSize); + } + }); + } + Screen screen = new TerminalScreen(terminal); screen.startScreen();