Eolite 1.8: improved menu, rename fixed

git-svn-id: svn://kolibrios.org@3439 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
Kirill Lipatov (Leency) 2013-04-01 15:41:17 +00:00
parent 2826905814
commit 8effd409af
6 changed files with 39 additions and 28 deletions

View File

@ -24,8 +24,8 @@
#define WITH_REDRAW 1
#define ONLY_OPEN 2
#define TITLE "Eolite File Manager v1.77"
#define ABOUT_TITLE "Eolite v1.77"
#define TITLE "Eolite File Manager v1.8"
#define ABOUT_TITLE "Eolite v1.80"
dword col_work = 0xE4DFE1;
dword col_border = 0x819FC5;
dword col_padding = 0xC8C9C9;
@ -45,10 +45,9 @@ byte
copy_file[4096],
temp[4096];
byte
cut_active,
rename_active,
del_active;
byte
cut_active=0,
rename_active=0,
del_active=0,
show_dev_name=1,
sort_num=2,
isdir;
@ -185,13 +184,14 @@ void main()
//Button pressed-----------------------------------------------------------------------------
case evButton:
id=GetButtonID();
IF (id==1) ExitProcess();
IF (del_active)
if (id==1) ExitProcess();
if (rename_active) break;
if (del_active)
{
IF (id==301) || (id==302) Del_File(302-id);
break;
}
switch(id)
{
case 21: //Back
@ -350,6 +350,7 @@ void main()
files.SetSizes(192, 57, onLeft(192,27), onTop(57,6), disc_num*16+195,files.line_h);
if (Form.height < files.min_h) MoveSize(OLD,OLD,OLD,files.min_h);
if (Form.width<480) MoveSize(OLD,OLD,480,OLD);
GetProcessInfo(#Form, SelfInfo); //if win_size changed
draw_window();
}
}
@ -380,6 +381,7 @@ inline fastcall void draw_window()
DrawFlatButton(onLeft(27,0),onTop(22,0),16,16,0,col_work,"\x19");
Open_Dir(#path,ONLY_SHOW);
if (del_active) Del_Form();
if (rename_active) ActionsProcess(2);
}
@ -467,7 +469,6 @@ void List_ReDraw()
void Line_ReDraw(dword color, filenum){
dword text_col=0, name_len=0, y=filenum*files.line_h+57;
IF (rename_active==1) ReName(false);
DrawBar(192,y,3,files.line_h,color);
DrawBar(192+19,y,onLeft(46,192),files.line_h,color); DrawBar(195,y+17,16,1,color);
if (files.line_h>18) DrawBar(195,y+18,16,files.line_h-18,color);
@ -755,7 +756,6 @@ void ActionsProcess(char N)
break;
case 2:
if (!files.count) break;
DeleteButton(files.current+201);
edit2.flags=100000000000010b; //set active
edit2.width=onLeft(24,217);
edit2.top=files.current*files.line_h+59;

View File

@ -2,7 +2,7 @@
char *captions[] = {
"Open", "Enter",
"Open with...", "Ctrl+Ent",
"Open with...", "CrlEnt",
"View as text", "F3",
"View as HEX", "F4",
"Rename", "F2",
@ -12,14 +12,15 @@ char *captions[] = {
void FileMenu()
{
proc_info MenuForm;
mouse mm;
word id, key, slot;
int ccount=0, linew=10, lineh=18, texty;
int ccount=0, cur, newi, linew=10, lineh=18, texty;
for (i=0; captions[i]!=0; i+=2)
{
ccount++;
if (strlen(captions[i])>linew) linew = strlen(captions[i]);
}
linew = linew + 3 * 6 + 70;
linew = linew + 3 * 6 + 50;
texty = lineh/2-4;
SetEventMask(100111b);
@ -29,6 +30,14 @@ void FileMenu()
case evMouse:
slot = GetProcessSlot(MenuForm.ID);
if (slot != GetActiveProcess()) ExitProcess();
mm.get();
newi = mm.y - 1 / lineh;
//if (m.y<0) || (newi+1>items_num) || (m.x<0) || (m.x>ITEM_WIDTH) break;
if (cur<>newi)
{
cur=newi;
goto _ITEMS_DRAW;
}
break;
case evButton:
@ -47,20 +56,22 @@ void FileMenu()
break;
case evReDraw: _MENU_DRAW:
DefineAndDrawWindow(m.x+Form.left+5,m.y+Form.top+GetSkinHeight(),linew+2,ccount*lineh+2,0x01,0xEEEeee,0x01fffFFF);
DefineAndDrawWindow(m.x+Form.left+5,m.y+Form.top+GetSkinHeight(),linew+2,ccount*lineh+5,0x01, 0, 0, 0x01fffFFF);
GetProcessInfo(#MenuForm, SelfInfo);
/* _PutImage(1,23, 16,44, #factions); //èêîíêè */
DrawRectangle(0,0,linew+1,ccount*lineh+1,col_border);
PutShadow(linew+2,1,1,ccount*lineh+1,0,1);
PutShadow(1,ccount*lineh+2,linew+1,1,0,1);
DrawRectangle(0,0,linew+1,ccount*lineh+2,col_border);
DrawBar(1,1,linew,1,0xFFFfff);
PutShadow(linew+2,1,1,ccount*lineh+2,0,1);
PutShadow(1,ccount*lineh+3,linew+2,1,0,1);
_ITEMS_DRAW:
for (i=0; captions[i*2]!=0; i++)
{
DefineButton(1,i*lineh,linew,lineh-1,i+100+BT_HIDE,0xFFFFFF);
DrawBar(1,i*lineh+1,1,lineh,0xFFFfff);
DrawBar(2,i*lineh+1,linew-1,lineh,col_work);
WriteText(6,i*lineh+texty+1,0x80,0x000000,captions[i*2]);
WriteText(-strlen(captions[i*2+1])*6-7+linew,i*lineh+texty+1,0x80,0x999999,captions[i*2+1]);
DefineButton(1,i*lineh+1,linew,lineh-1,i+100+BT_HIDE+BT_NOFRAME,0xFFFFFF);
DrawBar(1,i*lineh+2,1,lineh,0xFFFfff);
if (i==cur) DrawBar(2,i*lineh+2,linew-1,lineh,0xFFFfff); else DrawBar(2,i*lineh+2,linew-1,lineh,col_work);
WriteText(7,i*lineh+texty+2,0x80,0x000000,captions[i*2]);
WriteText(-strlen(captions[i*2+1])*6-6+linew,i*lineh+texty+2,0x80,0x999999,captions[i*2+1]);
}
}
}

View File

@ -1,6 +1,6 @@
01.05.13 -- v1.77
01.05.13 -- v1.8
- исправлено падение при изменении размера окна (нашёл 0CodErr);
- меню файлов (не закончено);
- לום‏ פאיכמג;
- перевод программы на элемент list_box: упрощение кода, гибкость элемента,
задел на двупанельность;
- вместо кнопок файлов теперь используются события мыши;

View File

@ -21,7 +21,7 @@ inline fastcall int StatusSocket( ECX)
$int 0x40
}
inline fastcall dword ReadSocket( ECX)
inline fastcall dword ReadSocket( ECX) //ecx - handle
{
$mov eax,53
$mov ebx,3

View File

@ -147,7 +147,7 @@ void OpenMailDat()
void SaveAndExit()
{
char write_data[512], pass_b64[256];
if (!CloseSocket(socket)) debug("An error occurred during closing of the socket");
CloseSocket(socket);
strcpy(#write_data, #email_text);
strcat(#write_data, "\n");
base64_encode stdcall (#pass_text, #pass_b64, strlen(#pass_text));

View File

@ -132,7 +132,7 @@ void MailBoxLoop()
if (id==EXIT_MAIL)
{
StopLoading();
if (!CloseSocket(socket)) debug("An error occurred during closing of the socket");
CloseSocket(socket);
LoginBoxLoop();
}
if (id==CHANGE_CHARSET)