refresh mit cooldown
This commit is contained in:
parent
167e0a3ce8
commit
24688ff183
BIN
driver/cli
BIN
driver/cli
Binary file not shown.
|
@ -14,6 +14,9 @@
|
|||
#include <sys/ioctl.h>
|
||||
#include <unistd.h>
|
||||
#include <signal.h>
|
||||
#include <future>
|
||||
#include <thread>
|
||||
#include <chrono>
|
||||
#include "ui/view_selection.h"
|
||||
#include "ui/view_info.h"
|
||||
#include "ui/view_monitor.h"
|
||||
|
@ -25,8 +28,14 @@ std::string ERR_MSG;
|
|||
|
||||
std::vector<View*> win_stack;
|
||||
|
||||
volatile int win_changed_cooldown = 0;
|
||||
volatile bool t_refresh_active = false;
|
||||
std::thread t_refresh;
|
||||
|
||||
void cleanup()
|
||||
{
|
||||
if(t_refresh.joinable())
|
||||
t_refresh.join();
|
||||
clrtoeol();
|
||||
refresh();
|
||||
endwin();
|
||||
|
@ -36,11 +45,26 @@ void signal_handler(int signal)
|
|||
{
|
||||
if(signal == SIGWINCH)
|
||||
{
|
||||
if(win_stack.size())
|
||||
win_changed_cooldown = 10; // 100ms
|
||||
|
||||
if (!t_refresh_active)
|
||||
{
|
||||
usleep(1000);
|
||||
win_stack.back()->repaint();
|
||||
if(t_refresh.joinable())
|
||||
t_refresh.join();
|
||||
t_refresh_active = true;
|
||||
t_refresh = std::thread([](){
|
||||
|
||||
while(win_changed_cooldown--)
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(10));
|
||||
|
||||
t_refresh_active = false;
|
||||
|
||||
if(win_stack.size())
|
||||
win_stack.back()->repaint();
|
||||
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
else if(signal == SIGINT)
|
||||
{
|
||||
|
@ -56,7 +80,7 @@ void init()
|
|||
{
|
||||
// init b15 driver
|
||||
B15F::getInstance();
|
||||
//std::cout << std::endl << "Starte in 3s ..." << std::endl;
|
||||
std::cout << std::endl << "Starte in 3s ..." << std::endl;
|
||||
//sleep(3);
|
||||
|
||||
// init all ncurses stuff
|
||||
|
|
BIN
driver/main
Executable file
BIN
driver/main
Executable file
Binary file not shown.
|
@ -58,9 +58,8 @@ std::function<void(int)> ViewPromt::keypress(int& key)
|
|||
if(input.length())
|
||||
input.pop_back();
|
||||
break;
|
||||
case '\t':
|
||||
case KEY_LEFT:
|
||||
selection = (selection + 1 ) % 2;
|
||||
break;
|
||||
case KEY_RIGHT:
|
||||
selection = (selection + 1 ) % 2;
|
||||
break;
|
||||
|
|
|
@ -29,11 +29,14 @@ std::function<void(int)> ViewSelection::keypress(int& key)
|
|||
selection = (selection - 1 + choices.size()) % choices.size();
|
||||
while(!choices[selection].length() && choices.size());
|
||||
break;
|
||||
|
||||
case '\t':
|
||||
case KEY_DOWN:
|
||||
do
|
||||
selection = (selection + 1) % choices.size();
|
||||
while(!choices[selection].length() && choices.size());
|
||||
break;
|
||||
|
||||
case KEY_MOUSE:
|
||||
{
|
||||
// http://pronix.linuxdelta.de/C/Linuxprogrammierung/Linuxsystemprogrammieren_C_Kurs_Kapitel10b.shtml
|
||||
|
@ -58,6 +61,7 @@ std::function<void(int)> ViewSelection::keypress(int& key)
|
|||
// fall through to next case
|
||||
__attribute__ ((fallthrough));
|
||||
}
|
||||
|
||||
case KEY_ENT:
|
||||
if(selection == choices.size() - 1) // exit
|
||||
key = -1; // do return from view
|
||||
|
|
Loading…
Reference in a new issue