forked from KolibriOS/kolibrios
SysMon: better key control, save ini
git-svn-id: svn://kolibrios.org@9584 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
8800305655
commit
00d6588c05
@ -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
|
||||||
|
@ -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;
|
||||||
|
@ -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();
|
||||||
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user