Subversion Repositories Kolibri OS

Rev

Rev 7507 | Rev 7628 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | Download | RSS feed

  1.   /////////////////////////////////////////////////////////////////////////////////////////
  2.  /////////////////////////                   GUI                      ////////////////////
  3. /////////////////////////////////////////////////////////////////////////////////////////
  4.  
  5. #include "..\lib\gui.h"
  6. #include "..\lib\obj\box_lib.h"
  7.  
  8. #ifdef LANG_RUS
  9. ?define T_ADD_DISK " „®¡ ¢¨âì ¤¨áª [Ins]"      
  10. ?define T_DELETE_DISK " “¤ «¨âì ¤¨áª [Del]"
  11. ?define INTRO_TEXT_1 "‡¤¥áì ¡ã¤¥â ®â®¡à ¦ âìáï ᯨ᮪"
  12. ?define INTRO_TEXT_2 "¢¨àâã «ì­ëå ¤¨áª®¢ ¢ á¨á⥬¥."
  13. ?define INTRO_TEXT_3 "®¯à®¡ã©â¥ ¤®¡ ¢¨âì ®¤¨­..."
  14. ?define SIZE_TEXT " §¬¥à:"
  15. ?define NOTIFY_TEXT_NO_DISK    "'„«ï ­ ç «  ¤®¡ ¢ì⥠å®âï ¡ë ®¤¨­ ¤¨áª' -W"
  16. ?define NOTIFY_SYSTEM_DISK0    "'„¨áª á ­®¬¥à®¬ 0 ï¥âáï á¨á⥬­ë¬ ¨ 㤠«ïâì ¥£® ­¥ ४®¬¥­¤ã¥âáï.
  17. ‚ á«ãç ¥, ¥á«¨ ¢ë â®ç­® §­ ¥â¥, çâ® ¤¥« ¥â¥, 㤠«¨âì ¥£® ¬®¦­® á § ¦ â®© ª« ¢¨è¥© SHIFT.' -W"
  18. ?define NOTIFY_TEXT_DISK_LIMIT "'„®á⨣­ã⠯।¥« ª®«¨ç¥á⢠ ¢¨àâã «ì­ëå ¤¨áª®¢' -W"
  19. ?define FREE_RAM_TEXT " §¬¥à ᢮¡®¤­®© ®¯¥à â¨¢­®© ¯ ¬ïâ¨: "
  20.        
  21. #else
  22. ?define T_ADD_DISK " Add disk [Ins]"
  23. ?define T_DELETE_DISK " Delete disk [Del]"
  24. ?define INTRO_TEXT_1 " There will be list of mounted"
  25. ?define INTRO_TEXT_2 " virtual disks."
  26. ?define INTRO_TEXT_3 " Try to add one..."
  27. ?define SIZE_TEXT "Size:"
  28. ?define NOTIFY_TEXT_NO_DISK    "'You need to have at least one disk' -W"
  29. ?define NOTIFY_SYSTEM_DISK0    "'Disc number 0 is a system disk. It is not recommended to delete it.
  30. In case when you know what you are doing you can delete it with the SHIFT key pressed.' -W"
  31. ?define NOTIFY_TEXT_DISK_LIMIT "'Reached the limit of the number of virtual disks' -W"
  32. ?define FREE_RAM_TEXT "Free RAM size: "
  33. #endif
  34.  
  35. struct path_string { unsigned char Item[10]; };
  36. path_string disk_list[10];
  37.  
  38. dword devbuf;
  39. char disk_num;
  40. char selected;
  41.  
  42. proc_info Form;
  43.  
  44. unsigned char icons[] = FROM "icons.raw";
  45. #define TOPPANELH 68
  46. #define BOTPANELH 26
  47.  
  48. char new_disk_size[7];
  49. edit_box edit_disk_size= {50,0,7,0xffffff,0x94AECE,0xFFFfff,0xffffff,0x10000000,
  50.         sizeof(new_disk_size)-2,#new_disk_size,0, ed_focus+ed_figure_only};
  51.  
  52. void Main_Window()
  53. {
  54.         word id;
  55.         int x;
  56.  
  57.         load_dll(boxlib, #box_lib_init,0);
  58.         GetNewSizeDisk();
  59.         edit_disk_size.left = strlen(SIZE_TEXT)*9 + 10;
  60.         SetEventMask(EVM_REDRAW + EVM_KEY + EVM_BUTTON + EVM_MOUSE + EVM_MOUSE_FILTER);
  61.         loop()
  62.         {
  63.                 switch(WaitEvent())
  64.                 {
  65.                 case evMouse:
  66.                         if (!CheckActiveProcess(Form.ID)) break;
  67.                         edit_box_mouse stdcall (#edit_disk_size);
  68.                         break;
  69.                        
  70.                 case evButton:
  71.                         id=GetButtonID();              
  72.                         if (id==1) return;
  73.                         if (id==10) AddDisk();
  74.                         if (id==11) {
  75.                                 GetKeys();
  76.                                 DelDisk();
  77.                         }
  78.                         if (id>=20)
  79.                         {
  80.                                 if (selected==id-20) OpenTmpDisk();
  81.                                 selected=id-20;
  82.                                 DrawTmpDisks();
  83.                         }
  84.             break;
  85.         case evKey:
  86.                         GetKeys();
  87.                         // PROCESS KEYS WHEN EDIT BOX INACTIVE
  88.                         if ( ! edit_disk_size.flags&ed_focus)   switch(key_scancode)
  89.                         {
  90.                                 case SCAN_CODE_TAB:
  91.                                         edit_disk_size.flags = ed_figure_only + ed_focus;
  92.                                         edit_box_draw stdcall (#edit_disk_size);
  93.                                         DrawTmpDisks();
  94.                                         break;
  95.                                 case SCAN_CODE_UP:
  96.                                         if (selected==0) break;
  97.                                         selected--;
  98.                                         DrawTmpDisks();
  99.                                         break;
  100.                                 case SCAN_CODE_DOWN:
  101.                                         if (selected+2>disk_num) break;
  102.                                         selected++;
  103.                                         DrawTmpDisks();
  104.                                         break;
  105.                                 case SCAN_CODE_LEFT:
  106.                                         if (selected<3) break;
  107.                                         selected-=3;
  108.                                         DrawTmpDisks();
  109.                                         break;
  110.                                 case SCAN_CODE_RIGHT:
  111.                                         if (selected+4>disk_num) break;
  112.                                         selected+=3;
  113.                                         DrawTmpDisks();
  114.                                         break;                                 
  115.                                 case SCAN_CODE_INS:
  116.                                         AddDisk();
  117.                                         break;
  118.                                 case SCAN_CODE_DEL:
  119.                                         DelDisk();
  120.                                         break;
  121.                                 case SCAN_CODE_ENTER:
  122.                                         OpenTmpDisk();
  123.                                         break;
  124.                         }
  125.                         // PROCESS KEYS WHEN EDIT BOX ACTIVE           
  126.                         else switch(key_scancode)
  127.                         {
  128.                                 case SCAN_CODE_TAB:
  129.                                         edit_disk_size.flags = ed_figure_only;
  130.                                         edit_box_draw stdcall (#edit_disk_size);
  131.                                         DrawTmpDisks();
  132.                                         break;
  133.                                 case SCAN_CODE_ENTER:
  134.                                 case SCAN_CODE_INS:
  135.                                         AddDisk();
  136.                                         break;
  137.                                 default:
  138.                                         EAX = key_editbox;
  139.                                         edit_box_key stdcall(#edit_disk_size);
  140.                                         break;
  141.                         }
  142.                         break;
  143.          case evReDraw:                
  144.                         system.color.get();
  145.                         DefineAndDrawWindow(170,150,405,290,0x74,system.color.work,"Virtual Disk Manager 0.68",0);
  146.                         GetProcessInfo(#Form, SelfInfo);
  147.                         if (Form.status_window>2) break;
  148.  
  149.                         DrawBar(0,0,  Form.cwidth,TOPPANELH, system.color.work);
  150.                         DrawBar(0,TOPPANELH, Form.cwidth,1,  system.color.work_graph);
  151.                         WriteText(6, 9, 0x90, system.color.work_text, SIZE_TEXT);
  152.                         WriteText(edit_disk_size.left + edit_disk_size.width + 12, 9, 0x90, system.color.work_text, "MB.");
  153.                         DrawEditBox(#edit_disk_size);
  154.                         x = 6 + DrawStandartCaptButton(6, 36, 10, T_ADD_DISK);
  155.                         DrawStandartCaptButton(x, 36, 11, T_DELETE_DISK);
  156.                         _PutImage(6+6, 42,  14,14,   #icons);
  157.                         _PutImage(x+6, 42,  14,14,   1*14*14*3+#icons);        
  158.                         GetDisks();
  159.                         DrawTmpDisks();
  160.                 }
  161.         }
  162. }
  163.  
  164.  
  165. void GetNewSizeDisk()
  166. {
  167.         int fr;
  168.         fr = GetFreeRAM() / 5 * 2;
  169.         fr = itoa(fr / 2048);
  170.         strcpy(#new_disk_size, fr);
  171.         EditBox_UpdateText(#edit_disk_size, edit_disk_size.flags);
  172.         edit_box_draw stdcall (#edit_disk_size);
  173. }
  174.  
  175.  
  176. void OpenTmpDisk()
  177. {
  178.         unsigned char eol_param[10];
  179.         if (!disk_num) return;
  180.         strcpy(#eol_param, "/tmp#/1/");
  181.         eol_param[4] = disk_list[selected].Item[3];
  182.         RunProgram("/sys/File managers/Eolite", #eol_param);
  183. }
  184.  
  185.  
  186. void GetDisks()
  187. {
  188.         unsigned int j, fcount=30;
  189.         unsigned char disk_name[10];
  190.        
  191.         mem_Free(devbuf);
  192.         devbuf= mem_Alloc(32);
  193.         ReadDir(0, devbuf, "/");
  194.         fcount=ESDWORD[devbuf+8];
  195.         mem_Free(devbuf);
  196.         devbuf = mem_Alloc(fcount+1*304+32);
  197.         ReadDir(fcount, devbuf, "/");
  198.        
  199.         disk_num=0;
  200.         for (j=0; j<fcount; j++;)
  201.         {
  202.                 strcpy(#disk_name, j*304+devbuf+72);
  203.                 if (disk_name[0]!='t') continue;
  204.                 strcpy(#disk_list[disk_num].Item, #disk_name);
  205.                 disk_num++;
  206.         }
  207.         if (disk_num>12) disk_num=12;
  208. }
  209.  
  210.  
  211. dword GetDiskSize(dword disk_n)
  212. {
  213.         BDVK bdvk;
  214.         char tmp_path[8];
  215.         strcpy(#tmp_path, "/tmp0/1");
  216.         tmp_path[4] = disk_n + '0';
  217.         GetFileInfo(#tmp_path, #bdvk);         
  218.         return bdvk.sizelo;
  219. }
  220.  
  221. unsigned int disk_pos_x[]={13,13,13,102,102,102,191,191,191,279,279,279};
  222. unsigned int disk_pos_y[]={79,127,175, 79,127,175, 79,127,175, 79,127,175};
  223.  
  224. void DrawTmpDisks()
  225. {
  226.         #define SELECTION_ACTIVE 0x0080FF;
  227.         #define SELECTION_INACTIVE 0x757489;
  228.         dword selection_color;
  229.         char free_ram_text[60];
  230.         byte i, real_id;
  231.         int FreeRAM=GetFreeRAM()/1024;
  232.  
  233.         DrawBar(0,TOPPANELH+1, Form.cwidth,Form.cheight-TOPPANELH-BOTPANELH-2, 0xFFFFFF);
  234.         DrawBar(0,Form.cheight-BOTPANELH-1, Form.cwidth,1, system.color.work_graph);
  235.         DrawBar(0,Form.cheight-BOTPANELH, Form.cwidth,BOTPANELH, system.color.work);
  236.         sprintf(#free_ram_text, "%s%i MB", FREE_RAM_TEXT, FreeRAM);
  237.         WriteText(10, Form.cheight-20, 0x90, system.color.work_text, #free_ram_text);
  238.         if (disk_num==0)
  239.         {
  240.                 WriteText(17,TOPPANELH+15,    0x90, 0x777777, INTRO_TEXT_1);
  241.                 WriteText(17,TOPPANELH+15+15, 0x90, 0x777777, INTRO_TEXT_2);
  242.                 WriteText(17,TOPPANELH+15+42, 0x90, 0x777777, INTRO_TEXT_3);
  243.                 return;
  244.         };
  245.         if (selected>=disk_num) selected=disk_num-1; //restore selected
  246.         for (i=0; i<10; i++) DeleteButton(20+i);
  247.         for (i=0; i<disk_num; i++)
  248.         {
  249.                 DefineButton(disk_pos_x[i], disk_pos_y[i], 80, 40, 20+i, 0xFFFfff);
  250.                 WriteText(disk_pos_x[i]+26,disk_pos_y[i]+6,  10110000b, 0x222222, #disk_list[i].Item);
  251.                 real_id = disk_list[i].Item[3] - '0';
  252.                 WriteText(disk_pos_x[i]+27,disk_pos_y[i]+24, 0x80, 0x555555, ConvertSize(GetDiskSize(real_id)));
  253.                 _PutImage(disk_pos_x[i]+6,disk_pos_y[i]+6, 14,14, 2*14*14*3+#icons);
  254.                 if (selected==i) {
  255.                         if ( edit_disk_size.flags & ed_focus)
  256.                                 selection_color = SELECTION_INACTIVE;
  257.                         else
  258.                                 selection_color = SELECTION_ACTIVE;
  259.                         DrawWideRectangle(disk_pos_x[i], disk_pos_y[i], 80, 40, 2, selection_color);
  260.                         PutPixel(disk_pos_x[i], disk_pos_y[i], 0xFFFfff);
  261.                 }
  262.         }
  263. }
  264.  
  265.  
  266. void AddDisk()
  267. {
  268.         byte i, j, err;
  269.         if (disk_num>=10)
  270.         {
  271.                 notify(NOTIFY_TEXT_DISK_LIMIT);
  272.                 return;
  273.         }
  274.        
  275.         param[0]='a';
  276.         for (i=0; i<9; i++)
  277.         {
  278.                 for (j=0; j<=disk_num; j++)
  279.                 {
  280.                         if (i+48==disk_list[j].Item[3]) continue 1;
  281.                 }
  282.                 break;
  283.         }
  284.        
  285.         param[1]=i+48;
  286.         param[2]='s';
  287.         param[3]='\0';
  288.         strcat(#param, #new_disk_size);
  289.         err = Console_Work();
  290.         if ((err!=0) && (err<7)) notify(rezult_text[err]);
  291.         pause(5);
  292.         GetDisks();
  293.         DrawTmpDisks();
  294.         GetNewSizeDisk();
  295. }
  296.  
  297.  
  298. void DelDisk()
  299. {
  300.         byte err;
  301.         if (disk_num==0)
  302.         {
  303.                 notify(NOTIFY_TEXT_NO_DISK);
  304.                 return;
  305.         }
  306.         if (disk_list[selected].Item[3]=='0') && (! key_modifier & KEY_LSHIFT) && (! key_modifier & KEY_RSHIFT)
  307.         {
  308.                 notify(NOTIFY_SYSTEM_DISK0);
  309.                 return;
  310.         }
  311.         param[0]='d';
  312.         param[1]=disk_list[selected].Item[3];
  313.         err = byte Console_Work();
  314.         if ((err!=0) && (err<7)) notify(rezult_text[err]);
  315.         pause(15);
  316.         GetDisks();
  317.         DrawTmpDisks();
  318. }
  319.  
  320.  
  321.  
  322.  
  323.  
  324.