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 公开了与模态相关的功能。