Eolite 4.46: display cut
git-svn-id: svn://kolibrios.org@7998 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
3feca3e420
commit
942caa5ace
@ -87,8 +87,19 @@ void EventCopy(bool _cut_active)
|
||||
if (getElementSelectedFlag(i) == true) {
|
||||
sprintf(copy_buf_offset,"%s/%s",#path,items.get(i)*304+buf+72);
|
||||
copy_buf_offset += strlen(copy_buf_offset) + 1;
|
||||
|
||||
setElementSelectedFlag(i, false);
|
||||
|
||||
if (cut_active) {
|
||||
if (i>=files.first) && (i<files.first+files.visible)
|
||||
PutShadow(files.x+4,i-files.first*files.item_h+files.y,16,files.item_h,1,-3);
|
||||
}
|
||||
}
|
||||
}
|
||||
if (cut_active) {
|
||||
pause(20);
|
||||
List_ReDraw();
|
||||
}
|
||||
if (selected_count==1) setElementSelectedFlag(files.cur_y, false);
|
||||
Clipboard__SetSlotData(size_buf, buff_data);
|
||||
free(buff_data);
|
||||
|
@ -1,5 +1,5 @@
|
||||
#define TITLE "Eolite File Manager 4.45"
|
||||
#define ABOUT_TITLE "EOLITE 4.45"
|
||||
#define TITLE "Eolite File Manager 4.46"
|
||||
#define ABOUT_TITLE "EOLITE 4.46"
|
||||
|
||||
#ifdef LANG_RUS
|
||||
?define T_FILE "” ©«"
|
||||
|
@ -206,7 +206,7 @@
|
||||
DrawBar(x,y+8,w,1,0x4E00E7);
|
||||
}
|
||||
|
||||
:void PutShadow(dword x,y,w,h,skinned,strength)
|
||||
:void PutShadow(dword x,y,w,h,skinned, signed strength)
|
||||
{
|
||||
proc_info wForm;
|
||||
dword shadow_buf = mem_Alloc(w*h*3);
|
||||
@ -260,14 +260,15 @@
|
||||
return gray;
|
||||
}
|
||||
|
||||
:void ShadowImage(dword color_image, w, h, strength)
|
||||
:void ShadowImage(dword color_image, w, h, signed strength)
|
||||
{
|
||||
dword col, to;
|
||||
byte col;
|
||||
dword to;
|
||||
strength = 10 - strength;
|
||||
to = w*h*3 + color_image;
|
||||
for ( ; color_image < to; color_image++)
|
||||
{
|
||||
col = strength * DSBYTE[color_image] / 10;
|
||||
col = math.min(strength * DSBYTE[color_image] / 10, 255);
|
||||
DSBYTE[color_image] = col;
|
||||
}
|
||||
}
|
||||
|
@ -1,73 +0,0 @@
|
||||
#ifndef INCLUDE_LIBIMG_LOAD_SKIN_H
|
||||
#define INCLUDE_LIBIMG_LOAD_SKIN_H
|
||||
|
||||
#ifndef INCLUDE_LIBIMG_H
|
||||
#include "../lib/obj/libimg.h"
|
||||
#endif
|
||||
|
||||
:struct libimg_image {
|
||||
dword image, w, h, imgsrc;
|
||||
void load_as24b();
|
||||
void load();
|
||||
void replace_color();
|
||||
} skin;
|
||||
|
||||
:void libimg_image::load_as24b(dword file_path)
|
||||
{
|
||||
dword image_pointer = load_image(file_path);
|
||||
if (!image_pointer) notify("'Error: Image not loaded' -E");
|
||||
|
||||
img_convert stdcall(image_pointer, 0, Image_bpp24, 0, 0);
|
||||
if (!EAX) {
|
||||
notify("'Error: Image can not be converted to 24b' -E");
|
||||
} else {
|
||||
image = image_pointer = EAX;
|
||||
w = DSWORD[image_pointer+4];
|
||||
h = DSWORD[image_pointer+8];
|
||||
imgsrc = ESDWORD[image_pointer+24];
|
||||
}
|
||||
}
|
||||
|
||||
:void libimg_image::load(dword file_path)
|
||||
{
|
||||
dword image_pointer = load_image(file_path);
|
||||
if (!EAX) {
|
||||
notify("'Error: Image not loaded' -E");
|
||||
} else {
|
||||
image = image_pointer = EAX;
|
||||
w = DSWORD[image_pointer+4];
|
||||
h = DSWORD[image_pointer+8];
|
||||
imgsrc = ESDWORD[image_pointer+24];
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
:void libimg_image::replace_color(dword old_color, new_color)
|
||||
{
|
||||
dword i, max_i;
|
||||
max_i = w * h * 4 + imgsrc;
|
||||
for (i = imgsrc; i < max_i; i += 4) if (DSDWORD[i]==old_color) DSDWORD[i] = new_color;
|
||||
}
|
||||
|
||||
:libimg_image icons32draw;
|
||||
:void DrawIcon32(dword x,y, bg, icon_n) {
|
||||
//load_dll(libimg, #libimg_init,1);
|
||||
if (!icons32draw.image) {
|
||||
icons32draw.load("/sys/icons32.png");
|
||||
icons32draw.replace_color(0x00000000, bg);
|
||||
}
|
||||
if (icon_n>=0) img_draw stdcall(icons32draw.image, x, y, 32, 32, 0, icon_n*32);
|
||||
}
|
||||
|
||||
:libimg_image icons16draw;
|
||||
:void DrawIcon16(dword x,y, bg, icon_n) {
|
||||
//load_dll(libimg, #libimg_init,1);
|
||||
if (!icons16draw.image) {
|
||||
icons16draw.load("/sys/icons16.png");
|
||||
icons16draw.replace_color(0xffFFFfff, bg);
|
||||
icons16draw.replace_color(0xffCACBD6, MixColors(bg, 0, 220));
|
||||
}
|
||||
if (icon_n>=0) img_draw stdcall(icons16draw.image, x, y, 16, 16, 0, icon_n*16);
|
||||
}
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue
Block a user