diff --git a/programs/fs/Eolite/trunk/include/LVabout.c-- b/programs/fs/Eolite/trunk/include/LVabout.c-- new file mode 100644 index 0000000000..af5b1b9ec3 --- /dev/null +++ b/programs/fs/Eolite/trunk/include/LVabout.c-- @@ -0,0 +1,129 @@ +#include "imgs\logo.cpp" + +/*void authors() +{ + _HH: + WindowRedrawStatus(1); + DefineAndDrawWindow(500,200,181,256,0x04,0x10EFEBEF,0,0,"About Eolite"); + //DrawTitle("About Eolite"); + DrawBar(5,0,172,50,0x8494C4); //голубое сзади + PutImage(#logo,85,85,48,7); + WriteText(32,100,0x80,0xBF40BF,"Eolite v0.96.4 beta7",0); + WriteText(68,120,0x80,0,"Authors:",0); + WriteText(44,130,0x80,0,"Leency & Veliant",0); + WriteText(50,140,0x80,0,"KolibriOS Team",0); + WriteText(26,160,0x80,0,"Made using C-- in 2008",0); + WriteText(23,170,0x80,0,"Visit www.kolibrios.org",0); + DrawFlatButton(90,190,70,22,2,0x00D7D7D7, "Close"); + WindowRedrawStatus(2); + loop() + { + SWITCH(WaitEvent()) + { + CASE evButton: ExitProcess(); + CASE evKey: IF (GetKey()==27) ExitProcess(); break; + CASE evReDraw: GOTO _HH; + BREAK; + } + } + ExitProcess(); +}*/ + + +void authors() +{ + loop() + { + switch(WaitEvent()) + { + CASE evButton: ExitProcess(); + CASE evKey: IF (GetKey()==27) ExitProcess(); break; + CASE evReDraw: + WindowRedrawStatus(1); + DefineAndDrawWindow(500,200,181,256,0x04,0x10EFEBEF,0,0,"About Eolite"); + //DrawTitle("About Eolite"); + DrawBar(5,0,172,50,0x8494C4); //голубое сзади + PutImage(#logo,85,85,48,7); + WriteText(32,100,0x80,0xBF40BF,"Eolite v0.96.7 beta7",0); + WriteText(68,120,0x80,0,"Authors:",0); + WriteText(44,130,0x80,0,"Leency & Veliant",0); + WriteText(50,140,0x80,0,"KolibriOS Team",0); + WriteText(26,160,0x80,0,"Made using C-- in 2008",0); + WriteText(23,170,0x80,0,"Visit www.kolibrios.org",0); + DrawFlatButton(90,190,70,22,2,0x00D7D7D7, "Close"); + WindowRedrawStatus(2); + } + } + //ExitProcess(); +} + + +dword ConvertSize(dword bytes) +{ + byte size_prefix[7], temp[3]; + IF (bytes>=1073741824) copystr(" Gb",#temp); + ELSE IF (bytes>=1048576) copystr(" Mb",#temp); + ELSE IF (bytes>=1024) copystr(" Kb",#temp); + ELSE copystr(" b ",#temp); + WHILE (bytes>1023) bytes/=1024; + copystr(IntToStr(bytes),#size_prefix); + copystr(#temp,#size_prefix+strlen(#size_prefix)); + EAX=#size_prefix; +} + + +void Sort_by_Size(int a, b) // для первого вызова: a = 0, b = <элементов в массиве> - 1 +{ + int i= a; + IF (a >= b) return; + FOR (j = a; j <= b; j++) + { + IF (ESDWORD[file_mas[j]*304 + buf+72-8] <= ESDWORD[file_mas[b]*304 + buf+72-8]) + { file_mas[i] >< file_mas[j]; i++;} + } + Sort_by_Size (a, i-2); + Sort_by_Size (i, b); +} + + +void Sort_by_Name(int a, b) // для первого вызова: a = 0, b = <элементов в массиве> - 1 +{ + int i = a; + IF (a >= b) return; + FOR (j = a; j <= b; j++) + IF (strcmp(file_mas[j]*304 + buf+72, file_mas[b]*304 + buf+72)<=0) { file_mas[i] >< file_mas[j]; i++;} + Sort_by_Name(a, i-2); + Sort_by_Name(i, b); +} + + +int partition1(dword a, b) +{ + dword i = a; byte filename1[256], filename2[256]; int n; + for (j = a; j <= b; j++) + { + // + copystr(file_mas[j]*304 + buf+72, #filename1); + copystr(file_mas[b]*304 + buf+72, #filename2); + n=strlen(#filename1)-1; + WHILE (filename1[n]<>'.') && (n>0) n--; + IF (n) copystr(#filename1+n+1, #filename1); + n=strlen(#filename2)-1; + WHILE (filename2[n]<>'.') && (n>0) n--; + IF (n) copystr(#filename2+n+1, #filename2); + // + n=strcmp(#filename1, #filename2); + IF (n<0) { file_mas[i] >< file_mas[j]; i++;} + IF (n==0) && (strcmp(file_mas[j]*304 + buf+72, file_mas[b]*304 + buf+72)<=0) { file_mas[i] >< file_mas[j]; i++;} + } + EAX = i-1; +} + +void Sort_by_Type(dword a, b) // для первого вызова: a = 0, b = <элементов в массиве> - 1 +{ + int c; + IF (a >= b) RETURN; + c = partition1(a, b); + Sort_by_Type(a, c-1); + Sort_by_Type(c+1, b); +} diff --git a/programs/fs/Eolite/trunk/include/icons_f.h-- b/programs/fs/Eolite/trunk/include/icons_f.h-- new file mode 100644 index 0000000000..edbeeadc84 --- /dev/null +++ b/programs/fs/Eolite/trunk/include/icons_f.h-- @@ -0,0 +1,68 @@ +void IconFairing(dword filenum, y, videlenie) +{ + if (filenum<5) //файлик + { + DrawBar(200,y-26,2,15,videlenie); + DrawBar(214,y-26,2,15,videlenie); + DrawBar(210,y-26,4,1,videlenie);//ле + DrawBar(211,y-25,3,1,videlenie);//сен + DrawBar(212,y-24,2,1,videlenie);//ка + DrawBar(213,y-23,1,1,videlenie);// + } + if (filenum==16) || (filenum==17) //папка + { + DrawBar(201,y-13,15,2,videlenie); //снизу линия + DrawBar(200,y-26,1,15,videlenie); //слева линия + DrawBar(208,y-26,8,2,videlenie); //сверху справа линия + IF (filenum==17) DrawBar(211,y-25,1,1,0x1A7B17); //зелёная точка стрелки + //.точки + PutPixel(201,y-26+skin_width,videlenie); //сверху слева точка + PutPixel(207,y-26+skin_width,videlenie); //сверху справа точка + PutPixel(201,y-14+skin_width,videlenie); //слева снизу точка + PutPixel(215,y-14+skin_width,videlenie); //справа снизу точка + PutPixel(215,y-24+skin_width,videlenie); //какая разница где + } + IF (filenum==13) PutPixel(215,y-26+skin_width,videlenie); //skin + IF (filenum==14) {DrawBar(200,y-26,1,15,videlenie); DrawBar(215,y-26,1,15,videlenie);} //video +} + +dword Put_icon(dword extension, yy) +{ + dword ftype="", fnum=0; //еши неизвесный файл + IF (strcmp(extension,".kex")==0) {fnum = 6; ftype="Program";} + IF (strcmp(extension,".cvs")==0) {fnum = 18; ftype="Graph";} + IF (strcmp(extension,".cmd")==0) {fnum = 5; ftype="CMD skript";} + IF (strcmp(extension,".skn")==0) {fnum = 13; ftype="Skin";} + IF (strcmp(extension,".chr")==0) {fnum = 10; ftype="Font";} + IF (strcmp(extension,".avi")==0) {fnum = 14; ftype="Video";} + IF (strcmp(extension,".asm")==0) {fnum = 11; ftype="Source";} + IF (strcmp(extension,".inc")==0) fnum = 9; + IF (strcmp(extension,".exe")==0) {fnum = 7; ftype="Win32 Exec";} + IF (strcmp(extension,".dll")==0) || (strcmp(extension,".obj")==0) {fnum = 8; ftype="Library";} + IF (strcmp(extension,".ini")==0) || (strcmp(extension,"conf")==0) {fnum = 8; ftype="Config";} + IF (strcmp(extension,".htm")==0) || (strcmp(extension,"html")==0) {fnum = 2; ftype="Web-page";} + //text + IF (strcmp(extension,".txt")==0) {fnum = 1; ftype="Text";} + IF (strcmp(extension,".doc")==0) {fnum = 1; ftype="Text";} + IF (strcmp(extension,".rtf")==0) {fnum = 1; ftype="Text";} + //изображения + IF (strcmp(extension,".gif")==0) || (strcmp(extension,".bmp")==0) || + (strcmp(extension,".tga")==0) || (strcmp(extension,".pcx")==0) || + (strcmp(extension,".png")==0) || (strcmp(extension,".jpg")==0) || + (strcmp(extension,"jpeg")==0) || (strcmp(extension,".raw")==0) {fnum = 3; ftype="Image";} + //архивы + IF (strcmp(extension,".rar")==0) || (strcmp(extension,".zip")==0) || + (strcmp(extension,".cab")==0) || (strcmp(extension,".tar")==0) || + (strcmp(extension,".ajr")==0) {fnum = 15; ftype="Archive";} + //audio + IF (strcmp(extension,".mp3")==0) {fnum = 12; ftype="Music";} + IF (strcmp(extension,".wav")==0) || (strcmp(extension,".mid")==0) || + (strcmp(extension,"midi")==0) || (strcmp(extension,".ogg")==0) {fnum = 12; ftype="Audio";} + //папка + IF (strcmp(extension,"