mirror of https://github.com/buggins/dlangui.git
add logging; fixes for font manager
This commit is contained in:
parent
5c77ebb3f1
commit
f39b95b354
|
@ -3936,17 +3936,17 @@ alias DRAWPATRECT* PDRAWPATRECT;
|
||||||
// ---------
|
// ---------
|
||||||
// Callbacks
|
// Callbacks
|
||||||
|
|
||||||
alias BOOL function (HDC, int) ABORTPROC;
|
alias extern(Windows) BOOL function (HDC, int) ABORTPROC;
|
||||||
alias int function (HDC, HANDLETABLE*, METARECORD*, int, LPARAM) MFENUMPROC;
|
alias extern(Windows) int function (HDC, HANDLETABLE*, METARECORD*, int, LPARAM) MFENUMPROC;
|
||||||
alias int function (HDC, HANDLETABLE*, const(ENHMETARECORD)*, int, LPARAM) ENHMFENUMPROC;
|
alias extern(Windows) int function (HDC, HANDLETABLE*, const(ENHMETARECORD)*, int, LPARAM) ENHMFENUMPROC;
|
||||||
alias int function (const(LOGFONTA)*, const(TEXTMETRICA)*, DWORD, LPARAM) FONTENUMPROCA, OLDFONTENUMPROCA;
|
alias extern(Windows) int function (const(LOGFONTA)*, const(TEXTMETRICA)*, DWORD, LPARAM) FONTENUMPROCA, OLDFONTENUMPROCA;
|
||||||
alias int function (const(LOGFONTW)*, const(TEXTMETRICW)*, DWORD, LPARAM) FONTENUMPROCW, OLDFONTENUMPROCW;
|
alias extern(Windows) int function (const(LOGFONTW)*, const(TEXTMETRICW)*, DWORD, LPARAM) FONTENUMPROCW, OLDFONTENUMPROCW;
|
||||||
alias int function (LPSTR, LPARAM) ICMENUMPROCA;
|
alias extern(Windows) int function (LPSTR, LPARAM) ICMENUMPROCA;
|
||||||
alias int function (LPWSTR, LPARAM) ICMENUMPROCW;
|
alias extern(Windows) int function (LPWSTR, LPARAM) ICMENUMPROCW;
|
||||||
alias void function (LPVOID, LPARAM) GOBJENUMPROC;
|
alias extern(Windows) void function (LPVOID, LPARAM) GOBJENUMPROC;
|
||||||
alias void function (int, int, LPARAM) LINEDDAPROC;
|
alias extern(Windows) void function (int, int, LPARAM) LINEDDAPROC;
|
||||||
alias UINT function (HWND, HMODULE, LPDEVMODEA, LPSTR, LPSTR, LPDEVMODEA, LPSTR, UINT) LPFNDEVMODE;
|
alias extern(Windows) UINT function (HWND, HMODULE, LPDEVMODEA, LPSTR, LPSTR, LPDEVMODEA, LPSTR, UINT) LPFNDEVMODE;
|
||||||
alias DWORD function (LPSTR, LPSTR, UINT, LPSTR, LPDEVMODEA) LPFNDEVCAPS;
|
alias extern(Windows) DWORD function (LPSTR, LPSTR, UINT, LPSTR, LPDEVMODEA) LPFNDEVCAPS;
|
||||||
|
|
||||||
|
|
||||||
// ---------
|
// ---------
|
||||||
|
|
|
@ -246,11 +246,9 @@
|
||||||
<Folder name="src">
|
<Folder name="src">
|
||||||
<Folder name="dlangui">
|
<Folder name="dlangui">
|
||||||
<Folder name="core">
|
<Folder name="core">
|
||||||
|
<File path="src\dlangui\core\logger.d" />
|
||||||
<File path="src\dlangui\core\types.d" />
|
<File path="src\dlangui\core\types.d" />
|
||||||
</Folder>
|
</Folder>
|
||||||
<Folder name="widgets">
|
|
||||||
<File path="src\dlangui\widgets\widget.d" />
|
|
||||||
</Folder>
|
|
||||||
<Folder name="graphics">
|
<Folder name="graphics">
|
||||||
<File path="src\dlangui\graphics\drawbuf.d" />
|
<File path="src\dlangui\graphics\drawbuf.d" />
|
||||||
<File path="src\dlangui\graphics\fonts.d" />
|
<File path="src\dlangui\graphics\fonts.d" />
|
||||||
|
@ -263,6 +261,9 @@
|
||||||
<File path="src\dlangui\platforms\windows\winapp.d" />
|
<File path="src\dlangui\platforms\windows\winapp.d" />
|
||||||
</Folder>
|
</Folder>
|
||||||
</Folder>
|
</Folder>
|
||||||
|
<Folder name="widgets">
|
||||||
|
<File path="src\dlangui\widgets\widget.d" />
|
||||||
|
</Folder>
|
||||||
</Folder>
|
</Folder>
|
||||||
</Folder>
|
</Folder>
|
||||||
<File path="3rdparty\win32\cderr.d" />
|
<File path="3rdparty\win32\cderr.d" />
|
||||||
|
|
|
@ -0,0 +1,78 @@
|
||||||
|
module dlangui.core.logger;
|
||||||
|
|
||||||
|
import std.stdio;
|
||||||
|
import std.datetime;
|
||||||
|
|
||||||
|
enum LogLevel : int {
|
||||||
|
Fatal,
|
||||||
|
Error,
|
||||||
|
Warn,
|
||||||
|
Info,
|
||||||
|
Debug,
|
||||||
|
Trace
|
||||||
|
}
|
||||||
|
|
||||||
|
__gshared LogLevel logLevel = LogLevel.Info;
|
||||||
|
__gshared std.stdio.File logFile;
|
||||||
|
|
||||||
|
public void setLogLevel(LogLevel level) {
|
||||||
|
logLevel = level;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setStdoutLogger() {
|
||||||
|
logFile = stdout;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setStderrLogger() {
|
||||||
|
logFile = stderr;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setFileLogger(File file) {
|
||||||
|
logFile = file;
|
||||||
|
}
|
||||||
|
|
||||||
|
class Log {
|
||||||
|
public static string logLevelName(LogLevel level) {
|
||||||
|
switch (level) {
|
||||||
|
case LogLevel.Fatal: return "F";
|
||||||
|
case LogLevel.Error: return "E";
|
||||||
|
case LogLevel.Warn: return "W";
|
||||||
|
case LogLevel.Info: return "I";
|
||||||
|
case LogLevel.Debug: return "D";
|
||||||
|
case LogLevel.Trace: return "V";
|
||||||
|
default: return "?";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void log(S...)(LogLevel level, S args) {
|
||||||
|
if (logLevel >= level && logFile.isOpen) {
|
||||||
|
SysTime ts = Clock.currTime();
|
||||||
|
logFile.writef("%04d-%02d-%02d %02d:%02d:%02d.%03d %s ", ts.year, ts.month, ts.day, ts.hour, ts.minute, ts.second, ts.fracSec.msecs, logLevelName(level));
|
||||||
|
logFile.writeln(args);
|
||||||
|
logFile.flush();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static void v(S...)(S args) {
|
||||||
|
if (logLevel >= LogLevel.Trace && logFile.isOpen)
|
||||||
|
log(LogLevel.Trace, args);
|
||||||
|
}
|
||||||
|
public static void d(S...)(S args) {
|
||||||
|
if (logLevel >= LogLevel.Debug && logFile.isOpen)
|
||||||
|
log(LogLevel.Debug, args);
|
||||||
|
}
|
||||||
|
public static void i(S...)(S args) {
|
||||||
|
if (logLevel >= LogLevel.Info && logFile.isOpen)
|
||||||
|
log(LogLevel.Info, args);
|
||||||
|
}
|
||||||
|
public static void w(S...)(S args) {
|
||||||
|
if (logLevel >= LogLevel.Warn && logFile.isOpen)
|
||||||
|
log(LogLevel.Warn, args);
|
||||||
|
}
|
||||||
|
public static void e(S...)(S args) {
|
||||||
|
if (logLevel >= LogLevel.Error && logFile.isOpen)
|
||||||
|
log(LogLevel.Error, args);
|
||||||
|
}
|
||||||
|
public static void f(S...)(S args) {
|
||||||
|
if (logLevel >= LogLevel.Fatal && logFile.isOpen)
|
||||||
|
log(LogLevel.Fatal, args);
|
||||||
|
}
|
||||||
|
}
|
|
@ -23,10 +23,10 @@ alias FontRef = Ref!Font;
|
||||||
|
|
||||||
class FontManager {
|
class FontManager {
|
||||||
static __gshared FontManager _instance;
|
static __gshared FontManager _instance;
|
||||||
public @property void instance(FontManager manager) {
|
public static @property void instance(FontManager manager) {
|
||||||
_instance = manager;
|
_instance = manager;
|
||||||
}
|
}
|
||||||
public @property FontManager instance() {
|
public static @property FontManager instance() {
|
||||||
return _instance;
|
return _instance;
|
||||||
}
|
}
|
||||||
abstract public Font getFont(int size, int weight, bool italic, FontFamily family, string face);
|
abstract public Font getFont(int size, int weight, bool italic, FontFamily family, string face);
|
||||||
|
|
|
@ -11,6 +11,7 @@ import std.stdio;
|
||||||
import dlangui.platforms.common.platform;
|
import dlangui.platforms.common.platform;
|
||||||
import dlangui.graphics.drawbuf;
|
import dlangui.graphics.drawbuf;
|
||||||
import dlangui.graphics.fonts;
|
import dlangui.graphics.fonts;
|
||||||
|
import dlangui.core.logger;
|
||||||
|
|
||||||
pragma(lib, "gdi32.lib");
|
pragma(lib, "gdi32.lib");
|
||||||
pragma(lib, "user32.lib");
|
pragma(lib, "user32.lib");
|
||||||
|
@ -43,6 +44,10 @@ class Win32Font : Font {
|
||||||
_baseline = 0;
|
_baseline = 0;
|
||||||
_size = 0;
|
_size = 0;
|
||||||
}
|
}
|
||||||
|
if (_drawbuf !is null) {
|
||||||
|
destroy(_drawbuf);
|
||||||
|
_drawbuf = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
public this(HFONT hfont, int size, int height, int weight, bool italic, string face, FontFamily family, int baseline) {
|
public this(HFONT hfont, int size, int height, int weight, bool italic, string face, FontFamily family, int baseline) {
|
||||||
_hfont = hfont;
|
_hfont = hfont;
|
||||||
|
@ -61,7 +66,7 @@ class Win32Font : Font {
|
||||||
public @property override bool italic() { return _italic; }
|
public @property override bool italic() { return _italic; }
|
||||||
public @property override string face() { return _face; }
|
public @property override string face() { return _face; }
|
||||||
public @property override FontFamily family() { return _family; }
|
public @property override FontFamily family() { return _family; }
|
||||||
public @property override bool isNull() { return _hfont !is null; }
|
public @property override bool isNull() { return _hfont is null; }
|
||||||
public bool create(const LOGFONTA * logfont) {
|
public bool create(const LOGFONTA * logfont) {
|
||||||
if (!isNull())
|
if (!isNull())
|
||||||
clear();
|
clear();
|
||||||
|
@ -88,60 +93,76 @@ class Win32Font : Font {
|
||||||
int i = 0;
|
int i = 0;
|
||||||
for (;_logfont.lfFaceName[i]; i++) {
|
for (;_logfont.lfFaceName[i]; i++) {
|
||||||
}
|
}
|
||||||
_face = _logfont.lfFaceName[0..i].dup;
|
_face = cast(string)(_logfont.lfFaceName[0..i].dup);
|
||||||
_height = tm.tmHeight;
|
_height = tm.tmHeight;
|
||||||
_baseline = _height - tm.tmDescent;
|
_baseline = _height - tm.tmDescent;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class Win32FontManager : FontManager {
|
class Win32FontManager : FontManager {
|
||||||
public this() {
|
public this() {
|
||||||
instance = this;
|
instance = this;
|
||||||
init();
|
init();
|
||||||
}
|
}
|
||||||
public bool init() {
|
public bool init() {
|
||||||
|
Log.i("Win32FontManager.init()");
|
||||||
Win32ColorDrawBuf drawbuf = new Win32ColorDrawBuf(1,1);
|
Win32ColorDrawBuf drawbuf = new Win32ColorDrawBuf(1,1);
|
||||||
LOGFONTA lf;
|
LOGFONTA lf;
|
||||||
lf.lfCharSet = ANSI_CHARSET;
|
lf.lfCharSet = ANSI_CHARSET; //DEFAULT_CHARSET;
|
||||||
|
lf.lfFaceName[0] = 0;
|
||||||
|
HDC dc = drawbuf.dc;
|
||||||
int res =
|
int res =
|
||||||
EnumFontFamiliesExA(
|
EnumFontFamiliesExA(
|
||||||
drawbuf.dc, // handle to DC
|
dc, // handle to DC
|
||||||
&lf, // font information
|
&lf, // font information
|
||||||
&LVWin32FontEnumFontFamExProc, // callback function (FONTENUMPROC)
|
&LVWin32FontEnumFontFamExProc, // callback function (FONTENUMPROC)
|
||||||
cast(LPARAM)(cast(void*)this), // additional data
|
cast(LPARAM)(cast(void*)this), // additional data
|
||||||
0U // not used; must be 0
|
0U // not used; must be 0
|
||||||
);
|
);
|
||||||
|
destroy(drawbuf);
|
||||||
|
Log.i("EnumFontFamiliesExA returned ", res);
|
||||||
return res!=0;
|
return res!=0;
|
||||||
}
|
}
|
||||||
public override Font getFont(int size, int weight, bool italic, FontFamily family, string face) {
|
public override Font getFont(int size, int weight, bool italic, FontFamily family, string face) {
|
||||||
// TODO:
|
// TODO:
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
public bool registerFont(const LOGFONTA * logfont) {
|
public bool registerFont(FontFamily family, string fontFace, const LOGFONTA * logfont) {
|
||||||
|
Log.d("registerFont(", family, ",", fontFace, ")");
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
string fromStringz(const(char[]) s) {
|
||||||
|
int i = 0;
|
||||||
|
while(s[i])
|
||||||
|
i++;
|
||||||
|
return cast(string)(s[0..i].dup);
|
||||||
|
}
|
||||||
|
|
||||||
// definition
|
// definition
|
||||||
//extern(Windows) {
|
extern(Windows) {
|
||||||
int LVWin32FontEnumFontFamExProc(
|
int LVWin32FontEnumFontFamExProc(
|
||||||
const (LOGFONTA) *lf, // logical-font data
|
const (LOGFONTA) *lf, // logical-font data
|
||||||
const (TEXTMETRICA) *lpntme, // physical-font data
|
const (TEXTMETRICA) *lpntme, // physical-font data
|
||||||
//ENUMLOGFONTEX *lpelfe, // logical-font data
|
//ENUMLOGFONTEX *lpelfe, // logical-font data
|
||||||
//NEWTEXTMETRICEX *lpntme, // physical-font data
|
//NEWTEXTMETRICEX *lpntme, // physical-font data
|
||||||
DWORD FontType, // type of font
|
DWORD fontType, // type of font
|
||||||
LPARAM lParam // application-defined data
|
LPARAM lParam // application-defined data
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
//
|
//
|
||||||
if (FontType == TRUETYPE_FONTTYPE)
|
//Log.d("LVWin32FontEnumFontFamExProc fontType=", fontType);
|
||||||
|
if (fontType == TRUETYPE_FONTTYPE)
|
||||||
{
|
{
|
||||||
void * p = cast(void*)lParam;
|
void * p = cast(void*)lParam;
|
||||||
Win32FontManager fontman = cast(Win32FontManager)p;
|
Win32FontManager fontman = cast(Win32FontManager)p;
|
||||||
Win32Font fnt;
|
string face = fromStringz(lf.lfFaceName);
|
||||||
|
Log.d("face:", face);
|
||||||
|
Win32Font fnt = new Win32Font();
|
||||||
//if (strcmp(lf->lfFaceName, "Courier New"))
|
//if (strcmp(lf->lfFaceName, "Courier New"))
|
||||||
// return 1;
|
// return 1;
|
||||||
if (fnt.create(lf))
|
if (fnt.create(lf))
|
||||||
|
@ -154,13 +175,14 @@ class Win32FontManager : FontManager {
|
||||||
//if (!fnt.getGlyphInfo( chars[i], &glyph, L' ' )) //def_char
|
//if (!fnt.getGlyphInfo( chars[i], &glyph, L' ' )) //def_char
|
||||||
// return 1;
|
// return 1;
|
||||||
}
|
}
|
||||||
fontman.registerFont(lf);
|
fontman.registerFont(fnt.family, fnt.face, lf);
|
||||||
}
|
}
|
||||||
fnt.clear();
|
fnt.clear();
|
||||||
|
destroy(fnt);
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
//}
|
}
|
||||||
|
|
||||||
extern (C) int UIAppMain();
|
extern (C) int UIAppMain();
|
||||||
|
|
||||||
|
@ -288,9 +310,12 @@ int WinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance,
|
||||||
|
|
||||||
int myWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int iCmdShow)
|
int myWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int iCmdShow)
|
||||||
{
|
{
|
||||||
|
setFileLogger(std.stdio.File("ui.log", "w"));
|
||||||
|
setLogLevel(LogLevel.Trace);
|
||||||
|
|
||||||
_cmdShow = iCmdShow;
|
_cmdShow = iCmdShow;
|
||||||
_hInstance = hInstance;
|
_hInstance = hInstance;
|
||||||
writeln("Creating window");
|
Log.d("Inside myWinMain");
|
||||||
string appName = "HelloWin";
|
string appName = "HelloWin";
|
||||||
|
|
||||||
|
|
||||||
|
@ -300,6 +325,8 @@ int myWinMain(HINSTANCE hInstance, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
Platform.setInstance(platform);
|
Platform.setInstance(platform);
|
||||||
|
Win32FontManager fontMan = new Win32FontManager();
|
||||||
|
FontManager.instance = fontMan;
|
||||||
return UIAppMain();
|
return UIAppMain();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,41 +391,41 @@ class Win32ColorDrawBuf : ColorDrawBufBase {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void drawBuf2DC(HDC dc, int x, int y, DrawBuf buf)
|
//void drawBuf2DC(HDC dc, int x, int y, DrawBuf buf)
|
||||||
{
|
//{
|
||||||
uint * drawpixels;
|
// uint * drawpixels;
|
||||||
HDC drawdc;
|
// HDC drawdc;
|
||||||
HBITMAP drawbmp;
|
// HBITMAP drawbmp;
|
||||||
|
//
|
||||||
int buf_width = buf.width();
|
// int buf_width = buf.width();
|
||||||
int bytesPerRow = buf_width * 4;
|
// int bytesPerRow = buf_width * 4;
|
||||||
BITMAPINFO bmi;
|
// BITMAPINFO bmi;
|
||||||
//memset( &bmi, 0, sizeof(bmi) );
|
// //memset( &bmi, 0, sizeof(bmi) );
|
||||||
bmi.bmiHeader.biSize = (bmi.bmiHeader.sizeof);
|
// bmi.bmiHeader.biSize = (bmi.bmiHeader.sizeof);
|
||||||
bmi.bmiHeader.biWidth = buf_width;
|
// bmi.bmiHeader.biWidth = buf_width;
|
||||||
bmi.bmiHeader.biHeight = buf.height;
|
// bmi.bmiHeader.biHeight = buf.height;
|
||||||
bmi.bmiHeader.biPlanes = 1;
|
// bmi.bmiHeader.biPlanes = 1;
|
||||||
bmi.bmiHeader.biBitCount = 32;
|
// bmi.bmiHeader.biBitCount = 32;
|
||||||
bmi.bmiHeader.biCompression = BI_RGB;
|
// bmi.bmiHeader.biCompression = BI_RGB;
|
||||||
bmi.bmiHeader.biSizeImage = 0;
|
// bmi.bmiHeader.biSizeImage = 0;
|
||||||
bmi.bmiHeader.biXPelsPerMeter = 1024;
|
// bmi.bmiHeader.biXPelsPerMeter = 1024;
|
||||||
bmi.bmiHeader.biYPelsPerMeter = 1024;
|
// bmi.bmiHeader.biYPelsPerMeter = 1024;
|
||||||
bmi.bmiHeader.biClrUsed = 0;
|
// bmi.bmiHeader.biClrUsed = 0;
|
||||||
bmi.bmiHeader.biClrImportant = 0;
|
// bmi.bmiHeader.biClrImportant = 0;
|
||||||
drawbmp = CreateDIBSection( NULL, &bmi, DIB_RGB_COLORS, cast(void**)(&drawpixels), NULL, 0 );
|
// drawbmp = CreateDIBSection( NULL, &bmi, DIB_RGB_COLORS, cast(void**)(&drawpixels), NULL, 0 );
|
||||||
drawdc = CreateCompatibleDC(NULL);
|
// drawdc = CreateCompatibleDC(NULL);
|
||||||
SelectObject(drawdc, drawbmp);
|
// SelectObject(drawdc, drawbmp);
|
||||||
for (int yy=0; yy < buf.height; yy++)
|
// for (int yy=0; yy < buf.height; yy++)
|
||||||
{
|
// {
|
||||||
uint * src = buf.scanLine(yy);
|
// uint * src = buf.scanLine(yy);
|
||||||
uint * dst = drawpixels + (buf.height - 1 - yy) * buf.width;
|
// uint * dst = drawpixels + (buf.height - 1 - yy) * buf.width;
|
||||||
for (int xx = 0; xx < buf_width; xx++)
|
// for (int xx = 0; xx < buf_width; xx++)
|
||||||
dst[xx] = src[xx];
|
// dst[xx] = src[xx];
|
||||||
}
|
// }
|
||||||
BitBlt( dc, x, y, buf_width, buf.height, drawdc, 0, 0, SRCCOPY);
|
// BitBlt( dc, x, y, buf_width, buf.height, drawdc, 0, 0, SRCCOPY);
|
||||||
DeleteObject( drawbmp );
|
// DeleteObject( drawbmp );
|
||||||
DeleteObject( drawdc );
|
// DeleteObject( drawdc );
|
||||||
}
|
//}
|
||||||
|
|
||||||
|
|
||||||
extern(Windows)
|
extern(Windows)
|
||||||
|
|
|
@ -2,9 +2,13 @@ module winmain;
|
||||||
|
|
||||||
import dlangui.platforms.common.platform;
|
import dlangui.platforms.common.platform;
|
||||||
import dlangui.widgets.widget;
|
import dlangui.widgets.widget;
|
||||||
|
import dlangui.core.logger;
|
||||||
|
import std.stdio;
|
||||||
|
|
||||||
extern (C) int UIAppMain() {
|
extern (C) int UIAppMain() {
|
||||||
|
Log.d("Some debug message");
|
||||||
|
Log.e("Sample error #", 22);
|
||||||
|
|
||||||
Window window = Platform.instance().createWindow("My Window", null);
|
Window window = Platform.instance().createWindow("My Window", null);
|
||||||
Widget myWidget = new Widget();
|
Widget myWidget = new Widget();
|
||||||
window.mainWidget = myWidget;
|
window.mainWidget = myWidget;
|
||||||
|
|
Loading…
Reference in New Issue