SysMon: better key control, save ini

git-svn-id: svn://kolibrios.org@9584 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2022-01-06 22:02:02 +00:00
parent 8800305655
commit 00d6588c05
3 changed files with 63 additions and 17 deletions

View File

@ -40,7 +40,6 @@ char program_path[4096];
#define evReDraw 1 #define evReDraw 1
#define evKey 2 #define evKey 2
#define evButton 3 #define evButton 3
#define evExit 4
#define evDesktop 5 #define evDesktop 5
#define evMouse 6 #define evMouse 6
#define evIPC 7 #define evIPC 7
@ -51,7 +50,6 @@ char program_path[4096];
#define EVM_REDRAW 1b #define EVM_REDRAW 1b
#define EVM_KEY 10b #define EVM_KEY 10b
#define EVM_BUTTON 100b #define EVM_BUTTON 100b
#define EVM_EXIT 1000b
#define EVM_DESKTOPBG 10000b #define EVM_DESKTOPBG 10000b
#define EVM_MOUSE 100000b #define EVM_MOUSE 100000b
#define EVM_IPC 1000000b #define EVM_IPC 1000000b

View File

@ -44,7 +44,7 @@ signed SelectList_ProcessMouse()
return true; return true;
} }
if (mouse.up) && (mouse.lkm) if (mouse.up) && (mouse.click)
if (select_list.ProcessMouse(mouse.x, mouse.y)) { if (select_list.ProcessMouse(mouse.x, mouse.y)) {
SelectList_LineChanged(); SelectList_LineChanged();
return true; return true;

View File

@ -1,11 +1,11 @@
/* /*
* System Monitor * System Monitor
* version 1.4 * version 1.41
* Author: Leency * Author: Leency
*/ */
#define MEMSIZE 1024*60 #define MEMSIZE 1024*60
#define NO_DLL_INIT //#define NO_DLL_INIT
//===================================================// //===================================================//
// // // //
@ -18,6 +18,7 @@
#include "../lib/list_box.h" #include "../lib/list_box.h"
#include "../lib/obj/box_lib.h" #include "../lib/obj/box_lib.h"
#include "../lib/obj/libini.h"
#include "../lib/patterns/select_list.h" #include "../lib/patterns/select_list.h"
#include "../lib/patterns/restart_process.h" #include "../lib/patterns/restart_process.h"
@ -75,7 +76,7 @@ enum {
//===================================================// //===================================================//
int current_process_id = 0; int current_process_id = 0;
int proc_list[256]; int proc_list[MAX_PROCESS_COUNT];
checkbox show_system = { T_SHOW_SYSTEM, false }; checkbox show_system = { T_SHOW_SYSTEM, false };
@ -88,7 +89,9 @@ proc_info Form;
int right_w; int right_w;
bool show_sensors = true; bool show_sensors;
_ini ini = { "/sys/settings/app.ini", "Sysmon" };
//===================================================// //===================================================//
// // // //
@ -100,21 +103,42 @@ void main()
{ {
int btn; int btn;
load_dll(boxlib, #box_lib_init,0); load_dll(boxlib, #box_lib_init,0);
load_dll(libini, #lib_init,1);
ReadIni();
@SetEventMask(EVM_REDRAW + EVM_KEY + EVM_BUTTON + EVM_MOUSE + EVM_MOUSE_FILTER); @SetEventMask(EVM_REDRAW + EVM_KEY + EVM_BUTTON + EVM_MOUSE + EVM_MOUSE_FILTER);
loop() switch(@WaitEventTimeout(50)) loop() switch(@WaitEventTimeout(50))
{ {
case evMouse: case evMouse:
SelectList_ProcessMouse(); SelectList_ProcessMouse();
if (mouse.up) && (mouse.pkm) || (mouse.mkm) EventShowTinfo();
break; break;
case evKey: case evKey:
GetKeys(); GetKeys();
if (key_scancode == SCAN_CODE_ESC) ExitProcess(); switch(key_scancode) {
if (key_scancode == SCAN_CODE_DEL) EventKillCurrentProcess(); case SCAN_CODE_ESC:
if (select_list.ProcessKey(key_scancode)) SelectList_LineChanged(); EventExit();
case SCAN_CODE_DEL:
EventKillCurrentProcess();
break;
case SCAN_CODE_SPACE:
show_sensors ^= 1;
goto _DRAW_WINDOW;
case SCAN_CODE_ENTER:
EventShowTinfo();
break;
case SCAN_CODE_TAB:
show_system.checked ^= 1;
SelectList_LineChanged();
break;
default:
if (select_list.ProcessKey(key_scancode)) {
SelectList_LineChanged();
}
}
break; break;
case evButton: case evButton:
btn = @GetButtonID(); btn = @GetButtonID();
if (1==btn) ExitProcess(); if (1==btn) EventExit();
if (show_system.click(btn)) { if (show_system.click(btn)) {
SelectList_LineChanged(); SelectList_LineChanged();
@ -123,7 +147,7 @@ void main()
EventKillCurrentProcess(); EventKillCurrentProcess();
} }
if (BTN_PROC_INFO == btn) { if (BTN_PROC_INFO == btn) {
RunProgram("/sys/tinfo", itoa(GetProcessSlot(current_process_id))); EventShowTinfo();
} }
if (BTN_SHOWHIDE_SENSORS == btn) { if (BTN_SHOWHIDE_SENSORS == btn) {
show_sensors ^= 1; show_sensors ^= 1;
@ -132,7 +156,7 @@ void main()
break; break;
case evReDraw: case evReDraw:
sc.get(); sc.get();
DefineAndDrawWindow(screen.width/2 - 350, 100, 700, 490, 0x33, sc.work, T_APP_TITLE,0); DefineAndDrawWindow(Form.left, Form.top, Form.width, Form.height, 0x33, sc.work, T_APP_TITLE,0);
_DRAW_WINDOW: _DRAW_WINDOW:
GetProcessInfo(#Form, SelfInfo); GetProcessInfo(#Form, SelfInfo);
if (Form.status_window&ROLLED_UP) break; if (Form.status_window&ROLLED_UP) break;
@ -146,12 +170,12 @@ void main()
right_w &= ~1; // make sure the number is even right_w &= ~1; // make sure the number is even
WriteText(GAP+5, WIN_CONTENT_Y-20, 0x90, sc.work_text, T_PROC_HEADER); WriteText(GAP+5, WIN_CONTENT_Y-20, 0x90, sc.work_text, T_PROC_HEADER);
DefineButton(RIGHT_X-38,WIN_CONTENT_Y-25,18,18,BTN_SHOWHIDE_SENSORS,sc.work); DefineButton(RIGHT_X-38,WIN_CONTENT_Y-25,18,18,BTN_SHOWHIDE_SENSORS,sc.button);
DrawRectangle3D(RIGHT_X-38,WIN_CONTENT_Y-25,19,18,sc.work_graph,sc.work_light); DrawRectangle3D(RIGHT_X-38,WIN_CONTENT_Y-25,19,18,sc.work_graph,sc.work_light);
PutPixel(RIGHT_X-38+19,WIN_CONTENT_Y-25,sc.work_light); PutPixel(RIGHT_X-38+19,WIN_CONTENT_Y-25,sc.work_light);
EDX = "<\0>"; EDX = "<\0>";
EDX += show_sensors * 2; EDX += show_sensors * 2;
WriteText(RIGHT_X-38+5,WIN_CONTENT_Y-25+2,0x90,sc.work_text, EDX); WriteText(RIGHT_X-38+5,WIN_CONTENT_Y-25+2,0x90,sc.button_text, EDX);
//EBX += 5 << 16; //EBX += 5 << 16;
//$int 64 //$int 64
@ -369,4 +393,28 @@ void MonitorRam()
DrawIconWithText(RIGHT_X, ram.y - 25, 51, #param); DrawIconWithText(RIGHT_X, ram.y - 25, 51, #param);
} }
void EventShowTinfo()
{
RunProgram("/sys/tinfo", itoa(GetProcessSlot(current_process_id)));
}
void ReadIni()
{
Form.left = ini.GetInt("x", screen.width/2 - 350);
Form.top = ini.GetInt("y", 100);
Form.width = ini.GetInt("w", 700);
Form.height = ini.GetInt("h", 490);
show_sensors = ini.GetInt("show_sensors", true);
show_system.checked = ini.GetInt("show_system", false);
}
void EventExit()
{
ini.SetInt("x", Form.left);
ini.SetInt("y", Form.top);
ini.SetInt("w", Form.width);
ini.SetInt("h", Form.height);
ini.SetInt("show_sensors", show_sensors);
ini.SetInt("show_system", show_system.checked);
ExitProcess();
}