forked from KolibriOS/kolibrios
update font.h, rename to kfont.h, fix Eolite font bug in prior rev
git-svn-id: svn://kolibrios.org@6805 a494cfbc-eb01-0410-851d-a64ba20cac60
This commit is contained in:
parent
bc40aab5af
commit
aa8338809f
@ -1,6 +1,6 @@
|
|||||||
#define MEMSIZE 4096*60
|
#define MEMSIZE 4096*60
|
||||||
|
|
||||||
#include "../lib/font.h"
|
#include "../lib/kfont.h"
|
||||||
#include "../lib/io.h"
|
#include "../lib/io.h"
|
||||||
#include "../lib/gui.h"
|
#include "../lib/gui.h"
|
||||||
#include "../lib/list_box.h"
|
#include "../lib/list_box.h"
|
||||||
|
@ -14,7 +14,7 @@
|
|||||||
#include "..\lib\gui.h"
|
#include "..\lib\gui.h"
|
||||||
#include "..\lib\list_box.h"
|
#include "..\lib\list_box.h"
|
||||||
#include "..\lib\random.h"
|
#include "..\lib\random.h"
|
||||||
#include "..\lib\font.h"
|
#include "..\lib\kfont.h"
|
||||||
#include "..\lib\collection.h"
|
#include "..\lib\collection.h"
|
||||||
#include "..\lib\obj\libini.h"
|
#include "..\lib\obj\libini.h"
|
||||||
#include "..\lib\obj\box_lib.h"
|
#include "..\lib\obj\box_lib.h"
|
||||||
@ -724,9 +724,9 @@ void Line_ReDraw(dword bgcol, filenum){
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
strcpy(#label_file_name, file_name_off);
|
strcpy(#label_file_name, file_name_off);
|
||||||
if (label.getsize(#label_file_name) + 141 + 26 > files.w)
|
if (label.getsize(label.size.pt, #label_file_name) + 141 + 26 > files.w)
|
||||||
{
|
{
|
||||||
while (label.getsize(#label_file_name) + 141 + 26 > files.w) {
|
while (label.getsize(label.size.pt, #label_file_name) + 141 + 26 > files.w) {
|
||||||
ESBYTE[#label_file_name+strlen(#label_file_name)-1] = NULL;
|
ESBYTE[#label_file_name+strlen(#label_file_name)-1] = NULL;
|
||||||
}
|
}
|
||||||
strcpy(#label_file_name+strlen(#label_file_name)-2, "...");
|
strcpy(#label_file_name+strlen(#label_file_name)-2, "...");
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#define MEMSIZE 0x2EE80
|
#define MEMSIZE 0x2EE80
|
||||||
|
|
||||||
#include "../lib/font.h"
|
#include "../lib/kfont.h"
|
||||||
#include "../lib/gui.h"
|
#include "../lib/gui.h"
|
||||||
|
|
||||||
#define PANELH 30
|
#define PANELH 30
|
||||||
@ -64,7 +64,7 @@ void DrawPreviewPhrase()
|
|||||||
label.WriteIntoBuffer(10,y,Form.cwidth,Form.cheight-PANELH, 0xFFFFFF, 0, i, #line);
|
label.WriteIntoBuffer(10,y,Form.cwidth,Form.cheight-PANELH, 0xFFFFFF, 0, i, #line);
|
||||||
}
|
}
|
||||||
if (label.smooth) label.ApplySmooth();
|
if (label.smooth) label.ApplySmooth();
|
||||||
label.show_buf(0, PANELH);
|
label.ShowBuffer(0, PANELH);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DrawPreviewChars()
|
void DrawPreviewChars()
|
||||||
@ -84,5 +84,5 @@ void DrawPreviewChars()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (label.smooth) label.ApplySmooth();
|
if (label.smooth) label.ApplySmooth();
|
||||||
label.show_buf(0, PANELH);
|
label.ShowBuffer(0, PANELH);
|
||||||
}
|
}
|
||||||
|
@ -41,14 +41,14 @@
|
|||||||
int WriteIntoWindow();
|
int WriteIntoWindow();
|
||||||
int WriteIntoWindowCenter();
|
int WriteIntoWindowCenter();
|
||||||
void WriteIntoBuffer();
|
void WriteIntoBuffer();
|
||||||
void show_buf();
|
void ShowBuffer();
|
||||||
} label;
|
} label;
|
||||||
|
|
||||||
:bool LABEL::changeSIZE()
|
:bool LABEL::changeSIZE()
|
||||||
{
|
{
|
||||||
dword file_size;
|
dword file_size;
|
||||||
dword ofs;
|
dword ofs;
|
||||||
if(size.pt<9) size.pt = 8;
|
if(size.pt<9) size.pt = 9;
|
||||||
font = font_begin;
|
font = font_begin;
|
||||||
ofs = DSDWORD[calc(size.pt-8<<2+font_begin)];
|
ofs = DSDWORD[calc(size.pt-8<<2+font_begin)];
|
||||||
if(ofs==-1)return false;
|
if(ofs==-1)return false;
|
||||||
@ -59,10 +59,11 @@
|
|||||||
block = math.ceil(height*width/32);
|
block = math.ceil(height*width/32);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
:dword LABEL::getsize(dword text1)
|
:dword LABEL::getsize(byte fontSizePoints, dword text1)
|
||||||
{
|
{
|
||||||
size.height = size.width = 0;
|
size.height = size.width = 0;
|
||||||
size.offset_x = size.offset_y = -1;
|
size.offset_x = size.offset_y = -1;
|
||||||
|
size.pt = fontSizePoints;
|
||||||
if(size.pt)if(!changeSIZE())return 0;
|
if(size.pt)if(!changeSIZE())return 0;
|
||||||
WHILE(DSBYTE[text1])
|
WHILE(DSBYTE[text1])
|
||||||
{
|
{
|
||||||
@ -77,81 +78,82 @@
|
|||||||
}
|
}
|
||||||
:byte LABEL::symbol_size(byte s)
|
:byte LABEL::symbol_size(byte s)
|
||||||
{
|
{
|
||||||
dword xi,yi;
|
//return symbol_size(s);
|
||||||
dword tmp,_;
|
dword xi,yi;
|
||||||
dword iii = 0;
|
dword tmp,_;
|
||||||
byte rw=0;
|
dword iii = 0;
|
||||||
byte X;
|
byte rw=0;
|
||||||
if(bold) size.width+=math.ceil(size.pt/17);
|
byte X;
|
||||||
if(s==32)
|
if(bold) size.width+=math.ceil(size.pt/17);
|
||||||
|
if(s==32)
|
||||||
|
{
|
||||||
|
size.width += width/4;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if(s==9)
|
||||||
|
{
|
||||||
|
size.width += width;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
s = Cp866ToAnsi(s);
|
||||||
|
tmp = block*s << 2 + font;
|
||||||
|
for(yi=0; yi<height; yi++)
|
||||||
|
{
|
||||||
|
for(xi=0; xi<width; xi++)
|
||||||
{
|
{
|
||||||
size.width += width/4;
|
if(iii%32) _ >>= 1;
|
||||||
return;
|
else
|
||||||
}
|
|
||||||
if(s==9)
|
|
||||||
{
|
|
||||||
size.width += width;
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
s = Cp866ToAnsi(s);
|
|
||||||
tmp = block*s << 2 + font;
|
|
||||||
for(yi=0; yi<height; yi++)
|
|
||||||
{
|
|
||||||
for(xi=0; xi<width; xi++)
|
|
||||||
{
|
{
|
||||||
if(iii%32) _ >>= 1;
|
tmp += 4;
|
||||||
else
|
_ = DSDWORD[tmp];
|
||||||
{
|
|
||||||
tmp += 4;
|
|
||||||
_ = DSDWORD[tmp];
|
|
||||||
}
|
|
||||||
if(_&1)
|
|
||||||
{
|
|
||||||
if(xi>rw)rw=xi;
|
|
||||||
if(size.height<yi)size.height = yi;
|
|
||||||
if(size.offset_y<0)size.offset_y = yi;
|
|
||||||
else if(yi<size.offset_y)size.offset_y = yi;
|
|
||||||
if(!X) X = xi;
|
|
||||||
else if(X>xi)X = xi;
|
|
||||||
}
|
|
||||||
iii++;
|
|
||||||
}
|
}
|
||||||
|
if(_&1)
|
||||||
|
{
|
||||||
|
if(xi>rw)rw=xi;
|
||||||
|
if(size.height<yi)size.height = yi;
|
||||||
|
if(size.offset_y<0)size.offset_y = yi;
|
||||||
|
else if(yi<size.offset_y)size.offset_y = yi;
|
||||||
|
if(!X) X = xi;
|
||||||
|
else if(X>xi)X = xi;
|
||||||
|
}
|
||||||
|
iii++;
|
||||||
}
|
}
|
||||||
size.width += rw;
|
}
|
||||||
if(size.offset_x<0)size.offset_x = X;
|
size.width += rw;
|
||||||
|
if(size.offset_x<0)size.offset_x = X;
|
||||||
}
|
}
|
||||||
:byte LABEL::symbol(signed x,y; byte s; dword image_raw)
|
:byte LABEL::symbol(signed x,y; byte s; dword image_raw)
|
||||||
{
|
{
|
||||||
dword xi,yi;
|
dword xi,yi;
|
||||||
dword iii = 0;
|
dword iii = 0;
|
||||||
dword offs;
|
dword offs;
|
||||||
byte rw=0;
|
byte rw=0;
|
||||||
if(s==32)return width/4;
|
if(s==32)return width/4;
|
||||||
if(s==9)return width;
|
if(s==9)return width;
|
||||||
s = Cp866ToAnsi(s);
|
s = Cp866ToAnsi(s);
|
||||||
EBX = block*s << 2 + font;
|
EBX = block*s << 2 + font;
|
||||||
for(yi=0; yi<height; yi++)
|
for(yi=0; yi<height; yi++)
|
||||||
|
{
|
||||||
|
EDI = size.offset_y + yi + y * size.width * 3 + image_raw;
|
||||||
|
for(xi=0; xi<width; xi++)
|
||||||
{
|
{
|
||||||
EDI = size.offset_y + yi + y * size.width * 3 + image_raw;
|
if(iii%32) $shr ecx,1
|
||||||
for(xi=0; xi<width; xi++)
|
else
|
||||||
{
|
{
|
||||||
if(iii%32) $shr ecx,1
|
EBX += 4;
|
||||||
else
|
ECX = DSDWORD[EBX];
|
||||||
{
|
|
||||||
EBX += 4;
|
|
||||||
ECX = DSDWORD[EBX];
|
|
||||||
}
|
|
||||||
if(ECX&true)
|
|
||||||
{
|
|
||||||
if(xi>rw)rw=xi;
|
|
||||||
offs = x + xi *3 + EDI;
|
|
||||||
DSDWORD[offs] = DSDWORD[offs] & 0xFF000000 | color;
|
|
||||||
if(bold) DSDWORD[offs+3] = DSDWORD[offs+3] & 0xFF000000 | color;
|
|
||||||
}
|
|
||||||
iii++;
|
|
||||||
}
|
}
|
||||||
|
if(ECX&true)
|
||||||
|
{
|
||||||
|
if(xi>rw)rw=xi;
|
||||||
|
offs = x + xi *3 + EDI;
|
||||||
|
DSDWORD[offs] = DSDWORD[offs] & 0xFF000000 | color;
|
||||||
|
if(bold) DSDWORD[offs+3] = DSDWORD[offs+3] & 0xFF000000 | color;
|
||||||
|
}
|
||||||
|
iii++;
|
||||||
}
|
}
|
||||||
return rw;
|
}
|
||||||
|
return rw;
|
||||||
}
|
}
|
||||||
|
|
||||||
inline fastcall Cp866ToAnsi(AL) {
|
inline fastcall Cp866ToAnsi(AL) {
|
||||||
@ -177,7 +179,6 @@ inline fastcall Cp866ToAnsi(AL) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
font_begin = label_io.buffer_data;
|
font_begin = label_io.buffer_data;
|
||||||
size.pt = 9;
|
|
||||||
changeSIZE();
|
changeSIZE();
|
||||||
smooth = true;
|
smooth = true;
|
||||||
return true;
|
return true;
|
||||||
@ -220,51 +221,6 @@ inline fastcall dword b24(EAX) { return DSDWORD[EAX] & 0x00FFFFFF; }
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
:int LABEL::WriteIntoWindowCenter(dword x,y,w,h; dword _background, _color; byte fontSizePoints; dword txt)
|
|
||||||
{
|
|
||||||
size.pt = fontSizePoints;
|
|
||||||
getsize(txt);
|
|
||||||
return WriteIntoWindow(w-size.width/2+x,y, _background, _color, fontSizePoints, txt);
|
|
||||||
}
|
|
||||||
|
|
||||||
:int LABEL::WriteIntoWindow(int x,y; dword _background, _color; byte fontSizePoints; dword text1)
|
|
||||||
{
|
|
||||||
signed len=0;
|
|
||||||
if(!text1)return false;
|
|
||||||
if(size.pt)if(!changeSIZE())return false;
|
|
||||||
size.pt = fontSizePoints;
|
|
||||||
getsize(text1);
|
|
||||||
color = _color;
|
|
||||||
background = _background;
|
|
||||||
y -= size.offset_y;
|
|
||||||
EDX = size.width*size.height*3;
|
|
||||||
if(!raw_size)
|
|
||||||
{
|
|
||||||
raw_size = EDX;
|
|
||||||
raw = malloc(raw_size);
|
|
||||||
}
|
|
||||||
else if(raw_size<EDX)
|
|
||||||
{
|
|
||||||
raw_size = EDX;
|
|
||||||
raw = realloc(raw,raw_size);
|
|
||||||
}
|
|
||||||
// Fill background color {
|
|
||||||
EBX = background;
|
|
||||||
EAX = raw_size+raw;
|
|
||||||
for (EDI=raw; EDI<EAX; EDI+=3) ESDWORD[EDI] = EBX;
|
|
||||||
// }
|
|
||||||
len = size.offset_x;
|
|
||||||
WHILE(DSBYTE[text1])
|
|
||||||
{
|
|
||||||
len+=symbol(len,0,DSBYTE[text1], raw);
|
|
||||||
if(bold)len+=math.ceil(size.pt/17);
|
|
||||||
text1++;
|
|
||||||
}
|
|
||||||
IF (smooth) ApplySmooth();
|
|
||||||
show_buf(x,y);
|
|
||||||
return len;
|
|
||||||
}
|
|
||||||
|
|
||||||
:void LABEL::WriteIntoBuffer(int x,y,w,h; dword _background, _color; byte fontSizePoints; dword text1)
|
:void LABEL::WriteIntoBuffer(int x,y,w,h; dword _background, _color; byte fontSizePoints; dword text1)
|
||||||
{
|
{
|
||||||
dword new_raw_size;
|
dword new_raw_size;
|
||||||
@ -272,8 +228,7 @@ inline fastcall dword b24(EAX) { return DSDWORD[EAX] & 0x00FFFFFF; }
|
|||||||
if(size.pt)if(!changeSIZE())return;
|
if(size.pt)if(!changeSIZE())return;
|
||||||
|
|
||||||
if (size.pt != fontSizePoints) {
|
if (size.pt != fontSizePoints) {
|
||||||
size.pt = fontSizePoints;
|
getsize(fontSizePoints, text1);
|
||||||
getsize(text1);
|
|
||||||
y -= size.offset_y;
|
y -= size.offset_y;
|
||||||
}
|
}
|
||||||
color = _color;
|
color = _color;
|
||||||
@ -302,7 +257,25 @@ inline fastcall dword b24(EAX) { return DSDWORD[EAX] & 0x00FFFFFF; }
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
:void LABEL::show_buf(dword x, y){
|
:int LABEL::WriteIntoWindow(int x,y; dword _background, _color; byte fontSizePoints; dword text1)
|
||||||
|
{
|
||||||
|
if(!text1)return 0;
|
||||||
|
getsize(fontSizePoints, text1);
|
||||||
|
raw_size = NULL;
|
||||||
|
WriteIntoBuffer(0, -size.offset_y, size.width-size.offset_x,
|
||||||
|
size.height-size.offset_y, _background, _color, fontSizePoints, text1);
|
||||||
|
if (smooth) ApplySmooth();
|
||||||
|
ShowBuffer(x,y);
|
||||||
|
return size.offset_x + size.width;
|
||||||
|
}
|
||||||
|
|
||||||
|
:int LABEL::WriteIntoWindowCenter(dword x,y,w,h; dword _background, _color; byte fontSizePoints; dword text1)
|
||||||
|
{
|
||||||
|
getsize(fontSizePoints, text1);
|
||||||
|
return WriteIntoWindow(w-size.width/2+x,y, _background, _color, fontSizePoints, text1);
|
||||||
|
}
|
||||||
|
|
||||||
|
:void LABEL::ShowBuffer(dword x, y){
|
||||||
_PutImage(x, y, size.width, size.height, raw);
|
_PutImage(x, y, size.width, size.height, raw);
|
||||||
}
|
}
|
||||||
|
|
@ -11,7 +11,7 @@ SOFTWARE CENTER v2.8
|
|||||||
#include "..\lib\obj\libio_lib.h"
|
#include "..\lib\obj\libio_lib.h"
|
||||||
#include "..\lib\obj\libimg_lib.h"
|
#include "..\lib\obj\libimg_lib.h"
|
||||||
#include "..\lib\obj\libini.h"
|
#include "..\lib\obj\libini.h"
|
||||||
#include "..\lib\font.h"
|
#include "..\lib\kfont.h"
|
||||||
#include "..\lib\list_box.h"
|
#include "..\lib\list_box.h"
|
||||||
#include "..\lib\collection.h"
|
#include "..\lib\collection.h"
|
||||||
#include "..\lib\patterns\libimg_load_skin.h"
|
#include "..\lib\patterns\libimg_load_skin.h"
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
#define MEMSIZE 4096*25
|
#define MEMSIZE 4096*25
|
||||||
|
|
||||||
#include "../lib/font.h"
|
#include "../lib/kfont.h"
|
||||||
#include "../lib/io.h"
|
#include "../lib/io.h"
|
||||||
#include "../lib/gui.h"
|
#include "../lib/gui.h"
|
||||||
#include "../lib/list_box.h"
|
#include "../lib/list_box.h"
|
||||||
|
Loading…
Reference in New Issue
Block a user