mirror of
https://github.com/ArthurSonzogni/FTXUI.git
synced 2024-11-27 13:48:51 +08:00
Compare commits
1 Commits
3830655b5b
...
566c9b3b64
Author | SHA1 | Date | |
---|---|---|---|
|
566c9b3b64 |
@ -121,6 +121,7 @@ class ScreenInteractive : public Screen {
|
||||
bool mouse_captured = false;
|
||||
bool previous_frame_resized_ = false;
|
||||
|
||||
bool validated_ = false;
|
||||
bool frame_valid_ = false;
|
||||
|
||||
bool force_handle_ctrl_c_ = true;
|
||||
|
@ -858,12 +858,15 @@ void ScreenInteractive::Draw(Component component) {
|
||||
ResetCursorPosition();
|
||||
std::cout << ResetPosition(/*clear=*/resized);
|
||||
|
||||
// If the terminal width decrease, the terminal emulator will start wrapping
|
||||
// lines and make the display dirty. We should clear it completely.
|
||||
if ((dimx < dimx_) && !use_alternative_screen_) {
|
||||
std::cout << "\033[J"; // clear terminal output
|
||||
// clear terminal output if screen dimx decreases
|
||||
// only on primary screen
|
||||
// only on POSIX systems (linux/macos)
|
||||
#if !defined(_WIN32)
|
||||
if ((dimx < dimx_) && validated_ && !use_alternative_screen_) {
|
||||
std::cout << "\033[J"; // clear
|
||||
std::cout << "\033[H"; // move cursor to home position
|
||||
}
|
||||
#endif
|
||||
|
||||
// Resize the screen if needed.
|
||||
if (resized) {
|
||||
@ -931,6 +934,7 @@ void ScreenInteractive::Draw(Component component) {
|
||||
std::cout << ToString() << set_cursor_position;
|
||||
Flush();
|
||||
Clear();
|
||||
validated_ = true;
|
||||
frame_valid_ = true;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user