TerminalUI
TerminalUI
是驱动 UI 执行逻辑的主要实现。
创建 TerminalUI
您可以手动构建TerminalUI
,但推荐的方式是使用TerminalUIBuilder
,它会为您自动配置并设置必要的服务。
@Autowired
TerminalUIBuilder builder;
void sample() {
TerminalUI ui = builder.build();
// do something with ui
}
配置视图
TerminalUI
有一个辅助方法 *configure(View)*,可用于将必要的集成设置到 *eventloop* 和其他服务中。
TerminalUI ui;
void sample() {
BoxView view = new BoxView();
ui.configure(view);
}
运行UI循环
运行TerminalUI
执行循环是一个阻塞操作。您需要一种退出循环的方法,例如退出应用程序。
TerminalUI ui;
void sample() {
ui.run();
}
退出应用程序
如果您想使用普通的 *CTRL-Q* 组合键退出应用程序,请监听事件并请求 *中断*。
@Autowired
Terminal terminal;
void sample() {
TerminalUI ui = new TerminalUI(terminal);
BoxView view = new BoxView();
ui.configure(view);
ui.setRoot(view, true);
EventLoop eventLoop = ui.getEventLoop();
eventLoop.keyEvents()
.subscribe(event -> {
if (event.getPlainKey() == Key.q && event.hasCtrl()) {
eventLoop.dispatch(ShellMessageBuilder.ofInterrupt());
}
});
ui.run();
}
模态视图
TerminalUI
支持同时只有一个活动的模态视图。模态视图位于所有其他视图之上,并接收所有输入事件。
TerminalUI ui;
void sample() {
DialogView dialog = new DialogView();
// set modal
ui.setModal(dialog);
// clear modal
ui.setModal(null);
}
由于视图不应该直接知道任何关于TerminalUi 的信息,因此接口ViewService 公开了与模态相关的功能。 |