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 公开了模态相关函数。 |