diff --git a/programs/cmm/software_widget/compile.bat b/programs/cmm/software_widget/compile.bat index b871658473..1e9ba6e8c4 100644 --- a/programs/cmm/software_widget/compile.bat +++ b/programs/cmm/software_widget/compile.bat @@ -1,7 +1,7 @@ C-- software_widget.c @del game_center @copy software_widget.com game_center -@copy software_widget.com system_panel +@copy software_widget.com syspanel @del software_widget.com @pause @del warning.txt diff --git a/programs/cmm/software_widget/software_widget.c b/programs/cmm/software_widget/software_widget.c index cd522f95fc..9e5ba0cf16 100644 --- a/programs/cmm/software_widget/software_widget.c +++ b/programs/cmm/software_widget/software_widget.c @@ -1,5 +1,5 @@ /* -SOFTWARE CENTER v2.4 +SOFTWARE CENTER v2.8 */ #define MEMSIZE 0x9000 @@ -12,30 +12,25 @@ SOFTWARE CENTER v2.4 #include "..\lib\obj\libimg_lib.h" #include "..\lib\obj\libini.h" #include "..\lib\font.h" +#include "..\lib\list_box.h" +#include "..\lib\collection.h" #include "..\lib\patterns\libimg_load_skin.h" proc_info Form; - +llist list; +collection app_path_collection; byte kolibrios_mounted; -int item_id_need_to_run=-1, - current_item_id; - int window_width, - window_height; + window_height; -int col_max, - cell_w, - cell_h, - list_pos, - list_top, - row, - old_row, //to detect empty sections - col, - default_icon; +int list_pos, + row, + col, + default_icon; char window_title[128], - settings_ini_path[256] = "/sys/settings/"; + settings_ini_path[256] = "/sys/settings/"; #define LIST_BACKGROUND_COLOR 0xF3F3F3 @@ -44,12 +39,10 @@ void load_config() ini_get_str stdcall (#settings_ini_path, "Config", "window_title", #window_title, sizeof(window_title), "Software widget"); ini_get_int stdcall (#settings_ini_path, "Config", "window_width", 690); window_width = EAX; - ini_get_int stdcall (#settings_ini_path, "Config", "window_height", 540); - window_height = EAX; - ini_get_int stdcall (#settings_ini_path, "Config", "cell_w", 66); - cell_w = EAX; - ini_get_int stdcall (#settings_ini_path, "Config", "cell_h", 64); - cell_h = EAX; + ini_get_int stdcall (#settings_ini_path, "Config", "cell_w", 73); + list.item_w = EAX; + ini_get_int stdcall (#settings_ini_path, "Config", "cell_h", 71); + list.item_h = EAX; ini_get_int stdcall (#settings_ini_path, "Config", "default_icon", 0); default_icon = EAX; } @@ -57,14 +50,15 @@ void load_config() void main() { - dword id, key; - label.init("/sys/fonts/Tahoma.kf"); + dword id; + label.init(DEFAULT_FONT); load_dll(libio, #libio_init,1); load_dll(libimg, #libimg_init,1); load_dll(libini, #lib_init,1); Libimg_LoadImage(#skin, "/sys/icons32.png"); Libimg_FillTransparent(skin.image, skin.w, skin.h, LIST_BACKGROUND_COLOR); + kolibrios_mounted = isdir("/kolibrios"); if (param) { @@ -75,63 +69,56 @@ void main() strcat(#settings_ini_path, #program_path + strrchr(#program_path, '/')); strcat(#settings_ini_path, ".ini"); } + load_config(); + list.cur_y = -1; + list.y = 32; - loop() + DrawList(); + window_height = row+1*list.item_h + list_pos + skin_height + 15; + + loop() switch(WaitEvent()) { - switch(WaitEvent()) - { - case evButton: - id=GetButtonID(); - if (id==1) ExitProcess(); - if (id>=100) - { - item_id_need_to_run = id - 100; - current_item_id = 0; - ini_enum_sections stdcall (#settings_ini_path, #process_sections); - item_id_need_to_run = -1; - } + // case evKey: + // GetKeys(); + // if (list.ProcessKey(key_scancode)) DrawList(); + // break; + + case evButton: + id=GetButtonID(); + if (id==1) ExitProcess(); + if (id>=100) RunProgram(app_path_collection.get(id-100), ""); break; - case evReDraw: + case evReDraw: system.color.get(); DefineAndDrawWindow(GetScreenWidth()-window_width/2,GetScreenHeight()-window_height/2,window_width,window_height,0x74,system.color.work,""); GetProcessInfo(#Form, SelfInfo); if (Form.status_window>2) { DrawTitle(#window_title); break; } else DrawTitle(""); draw_top_bar(); - kolibrios_mounted = isdir("/kolibrios"); - col_max = Form.cwidth - 10 / cell_w; - current_item_id = 0; - row = -1; - ini_enum_sections stdcall (#settings_ini_path, #process_sections); - DrawBar(0, row + 1 * cell_h + list_pos, Form.cwidth, -row - 1 * cell_h - list_pos + Form.cheight, LIST_BACKGROUND_COLOR); + DrawList(); + DrawBar(0, row + 1 * list.item_h + list_pos, Form.cwidth, -row - 1 * list.item_h - list_pos + Form.cheight, LIST_BACKGROUND_COLOR); break; - } } } -byte search_for_id_need_to_run(dword key_value, key_name, sec_name, f_name) -{ - int icon_char_pos; - if (item_id_need_to_run == current_item_id) - { - icon_char_pos = strchr(key_value, ','); - if (icon_char_pos) ESBYTE[icon_char_pos] = 0; //delete icon from string - RunProgram(key_value, ""); - } - current_item_id++; - if (!strncmp(key_value, "/kolibrios/", 11)) && (!kolibrios_mounted) current_item_id--; - return true; +void DrawList() { + list.count = 0; + row = -1; + app_path_collection.drop(); + list_pos = list.y; + list.column_max = window_width - 10 / list.item_w; + ini_enum_sections stdcall (#settings_ini_path, #process_sections); + list.visible = list.count; } - byte draw_icons_from_section(dword key_value, key_name, sec_name, f_name) { int tmp, - icon_id, - icon_char_pos; + icon_id, + icon_char_pos; - if (col==col_max) { + if (col==list.column_max) { row++; col=0; } @@ -139,62 +126,55 @@ byte draw_icons_from_section(dword key_value, key_name, sec_name, f_name) //do not show items located in /kolibrios/ if this directory not mounted if (!strncmp(key_value, "/kolibrios/", 11)) && (!kolibrios_mounted) return true; - if (col==0) DrawBar(0, row * cell_h + list_pos, Form.cwidth, cell_h, LIST_BACKGROUND_COLOR); - DefineButton(col*cell_w+6,row*cell_h + list_pos,cell_w,cell_h-5,current_item_id + 100 + BT_HIDE,0); - tmp = cell_w/2; + if (col==0) DrawBar(0, row * list.item_h + list_pos, Form.cwidth, list.item_h, LIST_BACKGROUND_COLOR); + DefineButton(col*list.item_w+6, row*list.item_h + list_pos,list.item_w,list.item_h-5,list.count + 100 + BT_HIDE,0); + tmp = list.item_w/2; icon_char_pos = strchr(key_value, ','); if (icon_char_pos) icon_id = atoi(icon_char_pos+1); else icon_id = default_icon; - img_draw stdcall(skin.image, col*cell_w+tmp-10, row*cell_h+5 + list_pos, 32, 32, 0, icon_id*32); - label.write_center(col*cell_w+7,row*cell_h+47 + list_pos, cell_w,0, LIST_BACKGROUND_COLOR, 0xDCDCDC, 12, key_name); - label.write_center(col*cell_w+6,row*cell_h+46 + list_pos, cell_w,0, LIST_BACKGROUND_COLOR, 0x000000, 12, key_name); - current_item_id++; + img_draw stdcall(skin.image, col*list.item_w+tmp-10, row*list.item_h+5 + list_pos, 32, 32, 0, icon_id*32); + if (icon_char_pos) ESBYTE[icon_char_pos] = '\0'; //delete icon from string + app_path_collection.add(key_value); + //label.write_center(col*list.item_w+7,row*list.item_h+47 + list_pos, list.item_w,0, LIST_BACKGROUND_COLOR, 0xDCDCDC, 12, key_name); + label.write_center(col*list.item_w+6,row*list.item_h+46 + list_pos, list.item_w,0, LIST_BACKGROUND_COLOR, 0x000000, 12, key_name); + if (list.cur_y == list.count) DrawWideRectangle(col*list.item_w+6, row*list.item_h + list_pos,list.item_w,list.item_h-5, 2, 0x0080FF); + list.count++; col++; return true; } +int old_row; //to detect empty sections byte process_sections(dword sec_name, f_name) { int text_len; if (!strcmp(sec_name, "Config")) return true; - if (item_id_need_to_run!=-1) + if ((col==0) && (row==old_row)) { - ini_enum_keys stdcall (f_name, sec_name, #search_for_id_need_to_run); + list_pos -= 28; } else { - if ((col==0) && (row==old_row)) - { - list_pos -= 28; - } - else - { - row++; - } - col = 0; - old_row = row; - DrawBar(0, row * cell_h + list_pos, Form.cwidth , 29, LIST_BACKGROUND_COLOR); - //WriteTextB(10, row * cell_h + 9 + list_pos, 0x90, 0x000000, sec_name); - text_len = label.write(10, row * cell_h + 10 + list_pos, LIST_BACKGROUND_COLOR, 0, 15, sec_name); - DrawBar(text_len+20, row * cell_h + list_pos + 20, Form.cwidth-text_len-20, 1, 0xDCDCDC); - DrawBar(text_len+20, row * cell_h + list_pos + 21, Form.cwidth-text_len-20, 1, 0xFCFCFC); - list_pos += 29; - ini_enum_keys stdcall (f_name, sec_name, #draw_icons_from_section); + row++; } + col = 0; + old_row = row; + DrawBar(0, row * list.item_h + list_pos, Form.cwidth , 29, LIST_BACKGROUND_COLOR); + text_len = label.write(10, row * list.item_h + 10 + list_pos, LIST_BACKGROUND_COLOR, 0, 15, sec_name); + DrawBar(text_len+20, row * list.item_h + list_pos + 20, Form.cwidth-text_len-20, 1, 0xDCDCDC); + DrawBar(text_len+20, row * list.item_h + list_pos + 21, Form.cwidth-text_len-20, 1, 0xFCFCFC); + list_pos += 29; + ini_enum_keys stdcall (f_name, sec_name, #draw_icons_from_section); return true; } void draw_top_bar() { - int top_position = 32; - DrawBar(0,0,Form.cwidth, top_position-2, system.color.work); - DrawBar(0,top_position-2, Form.cwidth, 1, ShadowPixel(system.color.work, 1)); - DrawBar(0,top_position-1, Form.cwidth, 1, system.color.work_graph); - label.write_center(0,5, Form.cwidth, top_position, system.color.work, system.color.work_text, 16, #window_title); - list_top = top_position; - list_pos = list_top; + DrawBar(0,0,Form.cwidth, list.y-2, system.color.work); + DrawBar(0,list.y-2, Form.cwidth, 1, ShadowPixel(system.color.work, 1)); + DrawBar(0,list.y-1, Form.cwidth, 1, system.color.work_graph); + label.write_center(0,5, Form.cwidth, list.y, system.color.work, system.color.work_text, 16, #window_title); }