diff options
author | Tor Lillqvist <tml@iki.fi> | 1999-10-31 21:35:39 +0000 |
---|---|---|
committer | Tor Lillqvist <tml@src.gnome.org> | 1999-10-31 21:35:39 +0000 |
commit | 00c5e838710a01ed97a46d96910b6f118d240b99 (patch) | |
tree | 2d8a8d72f6e39231ed9fa72a09069025ff559f64 /gdk/win32/gdkdrawable-win32.c | |
parent | 241f9c9dabdd3f021adb139b25a455260dc473ae (diff) | |
download | gtk+-00c5e838710a01ed97a46d96910b6f118d240b99.tar.gz |
Add new keysyms from X11R6.4 (including EuroSign).
1999-10-31 Tor Lillqvist <tml@iki.fi>
* gdk/gdkkeysyms.h: Add new keysyms from X11R6.4 (including
EuroSign).
* gdk/gdktypes.h: Add note about wchar_t not necessarily being the
same type as GdkWChar, especially on Win32.
* gdk/win32/*.c: Change gdk_root_parent to be a pointer.
* gdk/win32/*.c: Assume all strings are UTF-8. Convert to Unicode
before passing to Windows GDI for drawing etc. Convert to the
system default codepage before passing to Windows as window
titles.
* gdk/win32/gdkprivate.h: Add more fields to GdkWindowPrivate to
support changing input locale on the fly.
* gdk/win32/gdkevent.c: Support input language (keyboard locale)
on-the-fly changes. Convert incoming characters from the current
codepage to Unicode (and then to a UTF-8 multi-byte string) based
on the current input language. Use keysym<->Unicode mapping tables
and functions borrowed from xterm sources.
Support IMEs (Input Method Editors) for CJK languages. On non-CJK
editions of Win9x, use the ActiveX-based Active IMM (Input Method
Manager) if available. IMEs and the Active IMM are available under
the disguise of Chinese, Korean and Japanese support for IE and
Outlook Express from "Windows Update" for Win98. On Win2k, the CJK
support is present in all editions (as long as you install it).
Call DispatchMessage from gdk_events_queue() (and thus
gdk_WindowProc()), instead of duplicating the code in
gdk_WindowProc().
Reworked the grab handling and propagation code, factored out
duplicated code snippets into separate functions. Other cleanups,
too.
* gdk/win32/surrogate-dimm.h: Provide just the bits we need from
the <dimm.h> header describing the Active IMM.
* gdk/win32/gdkfont.c: Pretend to support fontsets, but so far
just do the same as for "single" fonts.
* gdk/win32/gdk.c: Call CoInitialize() (COM initialisation) from
gdk_init_check, and CoUninitialize() from gdk_exit_func. Handle
the new keysyms from gdkkeysyms.h.
* gtk/gtkfontsel.c (Win32): Load the font for the preview as a
fontset, so that gtkentry uses wide characters.
* gtk/gtkrc.c (Win32): Get the locale with gwin_getlocale(). Call
GTk+'s system directory "gtk+", not "gtk".
Diffstat (limited to 'gdk/win32/gdkdrawable-win32.c')
-rw-r--r-- | gdk/win32/gdkdrawable-win32.c | 138 |
1 files changed, 50 insertions, 88 deletions
diff --git a/gdk/win32/gdkdrawable-win32.c b/gdk/win32/gdkdrawable-win32.c index 593c98cd80..85ca076cce 100644 --- a/gdk/win32/gdkdrawable-win32.c +++ b/gdk/win32/gdkdrawable-win32.c @@ -469,47 +469,35 @@ gdk_draw_text (GdkDrawable *drawable, if (text_length == 0) return; + g_assert (font->type == GDK_FONT_FONT || font->type == GDK_FONT_FONTSET); + drawable_private = (GdkDrawablePrivate*) drawable; gc_private = (GdkGCPrivate*) gc; font_private = (GdkFontPrivate*) font; - if (font->type == GDK_FONT_FONT) - { - hdc = gdk_gc_predraw (drawable_private, gc_private); - xfont = (HFONT) font_private->xfont; - - GDK_NOTE (MISC, g_print ("gdk_draw_text: %#x (%d) %#x " - "+%d+%d font: %#x \"%.*s\" length: %d\n", - drawable_private->xwindow, - gc_private, gc_private->xgc, - x, y, xfont, - (text_length > 10 ? 10 : text_length), - text, text_length)); - - if ((oldfont = SelectObject (hdc, xfont)) == NULL) - g_warning ("gdk_draw_text: SelectObject failed"); - if (font_private->cpinfo.MaxCharSize > 1) - { - wcstr = g_new (wchar_t, text_length); - if ((wlen = MultiByteToWideChar (font_private->codepage, 0, - text, text_length, - wcstr, text_length)) == 0) - g_warning ("gdk_draw_text: MultiByteToWideChar failed"); - else if (!TextOutW (hdc, x, y, wcstr, wlen)) - g_warning ("gdk_draw_text: TextOutW failed"); - g_free (wcstr); - } - else - { - if (!TextOutA (hdc, x, y, text, text_length)) - g_warning ("gdk_draw_text: TextOutA failed"); - } - if (oldfont != NULL) - SelectObject (hdc, oldfont); - gdk_gc_postdraw (drawable_private, gc_private); - } - else - g_error ("undefined font type"); + hdc = gdk_gc_predraw (drawable_private, gc_private); + xfont = (HFONT) font_private->xfont; + + GDK_NOTE (MISC, g_print ("gdk_draw_text: %#x (%d) %#x " + "+%d+%d font: %#x \"%.*s\" length: %d\n", + drawable_private->xwindow, + gc_private, gc_private->xgc, + x, y, xfont, + (text_length > 10 ? 10 : text_length), + text, text_length)); + + if ((oldfont = SelectObject (hdc, xfont)) == NULL) + g_warning ("gdk_draw_text: SelectObject failed"); + + wcstr = g_new (wchar_t, text_length); + if ((wlen = gdk_nmbstowchar_ts (wcstr, text, text_length, text_length)) == -1) + g_warning ("gdk_draw_text: gdk_nmbstowchar_ts failed"); + else if (!TextOutW (hdc, x, y, wcstr, wlen)) + g_warning ("gdk_draw_text: TextOutW failed"); + g_free (wcstr); + if (oldfont != NULL) + SelectObject (hdc, oldfont); + gdk_gc_postdraw (drawable_private, gc_private); } void @@ -521,6 +509,8 @@ gdk_draw_text_wc (GdkDrawable *drawable, const GdkWChar *text, gint text_length) { + HDC hdc; + HGDIOBJ oldfont; GdkDrawablePrivate *drawable_private; GdkFontPrivate *font_private; GdkGCPrivate *gc_private; @@ -539,68 +529,40 @@ gdk_draw_text_wc (GdkDrawable *drawable, if (text_length == 0) return; + g_assert (font->type == GDK_FONT_FONT || font->type == GDK_FONT_FONTSET); + drawable_private = (GdkDrawablePrivate*) drawable; gc_private = (GdkGCPrivate*) gc; font_private = (GdkFontPrivate*) font; - if (font->type == GDK_FONT_FONT) - { - HDC hdc; - HFONT xfont; - HGDIOBJ oldfont; + hdc = gdk_gc_predraw (drawable_private, gc_private); - hdc = gdk_gc_predraw (drawable_private, gc_private); - xfont = (HFONT) font_private->xfont; - - GDK_NOTE (MISC, g_print ("gdk_draw_text_wc: %#x (%d) %#x " - "+%d+%d font: %#x length: %d\n", - drawable_private->xwindow, - gc_private, gc_private->xgc, - x, y, xfont, - text_length)); + GDK_NOTE (MISC, g_print ("gdk_draw_text_wc: %#x (%d) %#x " + "+%d+%d font: %#x length: %d\n", + drawable_private->xwindow, + gc_private, gc_private->xgc, + x, y, font_private->xfont, + text_length)); - if ((oldfont = SelectObject (hdc, xfont)) == NULL) - g_warning ("gdk_draw_text_wc: SelectObject failed"); -#if 0 /* No. Don't use TextOutW directly. Compare to the X11 version, - * it uses plain XDrawString for GDK_FONT_FONT fonts, too. - * TextOutW by definition interprets the string as Unicode. - * We don't have that, but either chars from some single-byte codepage - * or from a DBCS. - */ + if ((oldfont = SelectObject (hdc, font_private->xfont)) == NULL) + g_warning ("gdk_draw_text_wc: SelectObject failed"); + if (sizeof (wchar_t) != sizeof (GdkWChar)) + { wcstr = g_new (wchar_t, text_length); for (i = 0; i < text_length; i++) wcstr[i] = text[i]; - if (!TextOutW (hdc, x, y, wcstr, text_length)) - g_warning ("gdk_draw_text_wc: TextOutW failed"); - g_free (wcstr); -#else - str = g_new (guchar, text_length); - for (i = 0; i < text_length; i++) - str[i] = text[i]; - if (font_private->cpinfo.MaxCharSize > 1) - { - wcstr = g_new (wchar_t, text_length); - if ((wlen = MultiByteToWideChar (font_private->codepage, 0, - str, text_length, - wcstr, text_length)) == 0) - g_warning ("gdk_draw_text: MultiByteToWideChar failed"); - else if (!TextOutW (hdc, x, y, wcstr, wlen)) - g_warning ("gdk_draw_text_wc: TextOutW failed"); - g_free (wcstr); - } - else - { - if (!TextOutA (hdc, x, y, str, text_length)) - g_warning ("gdk_draw_text_wc: TextOutA failed"); - } - g_free (str); -#endif - if (oldfont != NULL) - SelectObject (hdc, oldfont); - gdk_gc_postdraw (drawable_private, gc_private); } else - g_error ("undefined font type"); + wcstr = (wchar_t *) text; + + if (!TextOutW (hdc, x, y, wcstr, text_length)) + g_warning ("gdk_draw_text_wc: TextOutW failed"); + + if (sizeof (wchar_t) != sizeof (GdkWChar)) + g_free (wcstr); + if (oldfont != NULL) + SelectObject (hdc, oldfont); + gdk_gc_postdraw (drawable_private, gc_private); } void |