1415 lines
45 KiB
C
1415 lines
45 KiB
C
/*
|
|
* COMMDLG - Font Dialog
|
|
*
|
|
* Copyright 1994 Martin Ayotte
|
|
* Copyright 1996 Albrecht Kleine
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library; if not, write to the Free Software
|
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*/
|
|
|
|
#include <ctype.h>
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include "windef.h"
|
|
#include "winnls.h"
|
|
#include "winbase.h"
|
|
#include "wingdi.h"
|
|
#include "wine/winbase16.h"
|
|
#include "wine/winuser16.h"
|
|
#include "heap.h"
|
|
#include "commdlg.h"
|
|
#include "dlgs.h"
|
|
#include "wine/debug.h"
|
|
#include "cderr.h"
|
|
|
|
WINE_DEFAULT_DEBUG_CHANNEL(commdlg);
|
|
|
|
#include "cdlg.h"
|
|
|
|
static HBITMAP hBitmapTT = 0;
|
|
|
|
|
|
INT_PTR CALLBACK FormatCharDlgProcA(HWND hDlg, UINT uMsg, WPARAM wParam,
|
|
LPARAM lParam);
|
|
INT_PTR CALLBACK FormatCharDlgProcW(HWND hDlg, UINT uMsg, WPARAM wParam,
|
|
LPARAM lParam);
|
|
BOOL16 CALLBACK FormatCharDlgProc16(HWND16 hDlg, UINT16 message, WPARAM16 wParam,
|
|
LPARAM lParam);
|
|
|
|
/* There is a table here of all charsets, and the sample text for each.
|
|
* There is a second table that translates a charset into an index into
|
|
* the first table.
|
|
*/
|
|
|
|
#define CI(cs) ((IDS_CHARSET_##cs)-IDS_CHARSET_ANSI)
|
|
#define SAMPLE_EXTLEN 10
|
|
|
|
static const WCHAR SAMPLE_LANG_TEXT[][SAMPLE_EXTLEN]={
|
|
{'Y','y','Z','z',0}, /* Western and default */
|
|
{0}, /* Symbol */
|
|
{0}, /* Shift JIS */
|
|
{0}, /* Hangul */
|
|
{0}, /* GB2312 */
|
|
{0}, /* BIG5 */
|
|
{0}, /* Greek */
|
|
{0}, /* Turkish */
|
|
{0x05e0, 0x05e1, 0x05e9, 0x05ea, 0}, /* Hebrew */
|
|
{0}, /* Arabic */
|
|
{0}, /* Baltic */
|
|
{0}, /* Vietnamese */
|
|
{0}, /* Russian */
|
|
{0}, /* East European */
|
|
{0}, /* Thai */
|
|
{0}, /* Johab */
|
|
{0}, /* Mac */
|
|
{0}, /* OEM */
|
|
{0}, /* VISCII */
|
|
{0}, /* TCVN */
|
|
{0}, /* KOI-8 */
|
|
{0}, /* ISO-8859-3 */
|
|
{0}, /* ISO-8859-4 */
|
|
{0}, /* ISO-8859-10 */
|
|
{0} /* Celtic */
|
|
};
|
|
|
|
static const int CHARSET_ORDER[256]={
|
|
CI(ANSI), 0, CI(SYMBOL), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, CI(MAC), 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
CI(JIS), CI(HANGUL), CI(JOHAB), 0, 0, 0, CI(GB2312), 0, CI(BIG5), 0, 0, 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, CI(GREEK), CI(TURKISH), CI(VIETNAMESE), 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
|
|
0, CI(HEBREW), CI(ARABIC), 0, 0, 0, 0, 0, 0, 0, CI(BALTIC), 0, 0, 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, CI(RUSSIAN), 0, 0, 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, CI(THAI), 0,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, CI(EE), 0,
|
|
CI(VISCII), CI(TCVN), CI(KOI8), CI(ISO3), CI(ISO4), CI(ISO10), CI(CELTIC), 0, 0, 0, 0, 0, 0, 0, 0, CI(OEM),
|
|
};
|
|
|
|
static void FONT_LogFont16To32A( const LPLOGFONT16 font16, LPLOGFONTA font32 )
|
|
{
|
|
font32->lfHeight = font16->lfHeight;
|
|
font32->lfWidth = font16->lfWidth;
|
|
font32->lfEscapement = font16->lfEscapement;
|
|
font32->lfOrientation = font16->lfOrientation;
|
|
font32->lfWeight = font16->lfWeight;
|
|
font32->lfItalic = font16->lfItalic;
|
|
font32->lfUnderline = font16->lfUnderline;
|
|
font32->lfStrikeOut = font16->lfStrikeOut;
|
|
font32->lfCharSet = font16->lfCharSet;
|
|
font32->lfOutPrecision = font16->lfOutPrecision;
|
|
font32->lfClipPrecision = font16->lfClipPrecision;
|
|
font32->lfQuality = font16->lfQuality;
|
|
font32->lfPitchAndFamily = font16->lfPitchAndFamily;
|
|
lstrcpynA( font32->lfFaceName, font16->lfFaceName, LF_FACESIZE );
|
|
}
|
|
|
|
static void CFn_CHOOSEFONT16to32A(LPCHOOSEFONT16 chf16, LPCHOOSEFONTA chf32a)
|
|
{
|
|
chf32a->lStructSize=sizeof(CHOOSEFONTA);
|
|
chf32a->hwndOwner=HWND_32(chf16->hwndOwner);
|
|
chf32a->hDC=HDC_32(chf16->hDC);
|
|
chf32a->iPointSize=chf16->iPointSize;
|
|
chf32a->Flags=chf16->Flags;
|
|
chf32a->rgbColors=chf16->rgbColors;
|
|
chf32a->lCustData=chf16->lCustData;
|
|
chf32a->lpfnHook=NULL;
|
|
chf32a->lpTemplateName=MapSL(chf16->lpTemplateName);
|
|
chf32a->hInstance=HINSTANCE_32(chf16->hInstance);
|
|
chf32a->lpszStyle=MapSL(chf16->lpszStyle);
|
|
chf32a->nFontType=chf16->nFontType;
|
|
chf32a->nSizeMax=chf16->nSizeMax;
|
|
chf32a->nSizeMin=chf16->nSizeMin;
|
|
FONT_LogFont16To32A(MapSL(chf16->lpLogFont), chf32a->lpLogFont);
|
|
}
|
|
|
|
struct {
|
|
int mask;
|
|
char *name;
|
|
} cfflags[] = {
|
|
#define XX(x) { x, #x },
|
|
XX(CF_SCREENFONTS)
|
|
XX(CF_PRINTERFONTS)
|
|
XX(CF_SHOWHELP)
|
|
XX(CF_ENABLEHOOK)
|
|
XX(CF_ENABLETEMPLATE)
|
|
XX(CF_ENABLETEMPLATEHANDLE)
|
|
XX(CF_INITTOLOGFONTSTRUCT)
|
|
XX(CF_USESTYLE)
|
|
XX(CF_EFFECTS)
|
|
XX(CF_APPLY)
|
|
XX(CF_ANSIONLY)
|
|
XX(CF_NOVECTORFONTS)
|
|
XX(CF_NOSIMULATIONS)
|
|
XX(CF_LIMITSIZE)
|
|
XX(CF_FIXEDPITCHONLY)
|
|
XX(CF_WYSIWYG)
|
|
XX(CF_FORCEFONTEXIST)
|
|
XX(CF_SCALABLEONLY)
|
|
XX(CF_TTONLY)
|
|
XX(CF_NOFACESEL)
|
|
XX(CF_NOSTYLESEL)
|
|
XX(CF_NOSIZESEL)
|
|
XX(CF_SELECTSCRIPT)
|
|
XX(CF_NOSCRIPTSEL)
|
|
XX(CF_NOVERTFONTS)
|
|
#undef XX
|
|
{0,NULL},
|
|
};
|
|
|
|
static void
|
|
_dump_cf_flags(DWORD cflags) {
|
|
int i;
|
|
|
|
for (i=0;cfflags[i].name;i++)
|
|
if (cfflags[i].mask & cflags)
|
|
MESSAGE("%s|",cfflags[i].name);
|
|
MESSAGE("\n");
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* ChooseFont (COMMDLG.15)
|
|
*/
|
|
BOOL16 WINAPI ChooseFont16(LPCHOOSEFONT16 lpChFont)
|
|
{
|
|
HINSTANCE16 hInst;
|
|
HANDLE16 hDlgTmpl16 = 0, hResource16 = 0;
|
|
HGLOBAL16 hGlobal16 = 0;
|
|
BOOL16 bRet = FALSE;
|
|
LPCVOID template;
|
|
FARPROC16 ptr;
|
|
CHOOSEFONTA cf32a;
|
|
LOGFONTA lf32a;
|
|
LOGFONT16 *font16;
|
|
SEGPTR lpTemplateName;
|
|
|
|
cf32a.lpLogFont=&lf32a;
|
|
CFn_CHOOSEFONT16to32A(lpChFont, &cf32a);
|
|
|
|
TRACE("ChooseFont\n");
|
|
if (!lpChFont) return FALSE;
|
|
|
|
if (TRACE_ON(commdlg))
|
|
_dump_cf_flags(lpChFont->Flags);
|
|
|
|
if (lpChFont->Flags & CF_ENABLETEMPLATEHANDLE)
|
|
{
|
|
if (!(template = LockResource16( lpChFont->hInstance )))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
}
|
|
else if (lpChFont->Flags & CF_ENABLETEMPLATE)
|
|
{
|
|
HANDLE16 hResInfo;
|
|
if (!(hResInfo = FindResource16( lpChFont->hInstance,
|
|
MapSL(lpChFont->lpTemplateName),
|
|
RT_DIALOGA)))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
if (!(hDlgTmpl16 = LoadResource16( lpChFont->hInstance, hResInfo )) ||
|
|
!(template = LockResource16( hDlgTmpl16 )))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
HRSRC hResInfo;
|
|
HGLOBAL hDlgTmpl32;
|
|
LPCVOID template32;
|
|
DWORD size;
|
|
if (!(hResInfo = FindResourceA(COMMDLG_hInstance32, "CHOOSE_FONT", RT_DIALOGA)))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
if (!(hDlgTmpl32 = LoadResource(COMMDLG_hInstance32, hResInfo)) ||
|
|
!(template32 = LockResource(hDlgTmpl32)))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
size = SizeofResource(GetModuleHandleA("COMDLG32"), hResInfo);
|
|
hGlobal16 = GlobalAlloc16(0, size);
|
|
if (!hGlobal16)
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_MEMALLOCFAILURE);
|
|
ERR("alloc failure for %ld bytes\n", size);
|
|
return FALSE;
|
|
}
|
|
template = GlobalLock16(hGlobal16);
|
|
if (!template)
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_MEMLOCKFAILURE);
|
|
ERR("global lock failure for %x handle\n", hGlobal16);
|
|
GlobalFree16(hGlobal16);
|
|
return FALSE;
|
|
}
|
|
ConvertDialog32To16((LPVOID)template32, size, (LPVOID)template);
|
|
hDlgTmpl16 = hGlobal16;
|
|
|
|
}
|
|
|
|
/* lpTemplateName is not used in the dialog */
|
|
lpTemplateName=lpChFont->lpTemplateName;
|
|
lpChFont->lpTemplateName=(SEGPTR)&cf32a;
|
|
|
|
ptr = GetProcAddress16(GetModuleHandle16("COMMDLG"), (LPCSTR) 16);
|
|
hInst = GetWindowLongA(HWND_32(lpChFont->hwndOwner), GWL_HINSTANCE);
|
|
bRet = DialogBoxIndirectParam16(hInst, hDlgTmpl16, lpChFont->hwndOwner,
|
|
(DLGPROC16) ptr, (DWORD)lpChFont);
|
|
if (hResource16) FreeResource16(hDlgTmpl16);
|
|
if (hGlobal16)
|
|
{
|
|
GlobalUnlock16(hGlobal16);
|
|
GlobalFree16(hGlobal16);
|
|
}
|
|
lpChFont->lpTemplateName=lpTemplateName;
|
|
|
|
|
|
font16 = MapSL(lpChFont->lpLogFont);
|
|
font16->lfHeight = cf32a.lpLogFont->lfHeight;
|
|
font16->lfWidth = cf32a.lpLogFont->lfWidth;
|
|
font16->lfEscapement = cf32a.lpLogFont->lfEscapement;
|
|
font16->lfOrientation = cf32a.lpLogFont->lfOrientation;
|
|
font16->lfWeight = cf32a.lpLogFont->lfWeight;
|
|
font16->lfItalic = cf32a.lpLogFont->lfItalic;
|
|
font16->lfUnderline = cf32a.lpLogFont->lfUnderline;
|
|
font16->lfStrikeOut = cf32a.lpLogFont->lfStrikeOut;
|
|
font16->lfCharSet = cf32a.lpLogFont->lfCharSet;
|
|
font16->lfOutPrecision = cf32a.lpLogFont->lfOutPrecision;
|
|
font16->lfClipPrecision = cf32a.lpLogFont->lfClipPrecision;
|
|
font16->lfQuality = cf32a.lpLogFont->lfQuality;
|
|
font16->lfPitchAndFamily = cf32a.lpLogFont->lfPitchAndFamily;
|
|
lstrcpynA( font16->lfFaceName, cf32a.lpLogFont->lfFaceName, LF_FACESIZE );
|
|
return bRet;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* ChooseFontA (COMDLG32.@)
|
|
*/
|
|
BOOL WINAPI ChooseFontA(LPCHOOSEFONTA lpChFont)
|
|
{
|
|
LPCVOID template;
|
|
HRSRC hResInfo;
|
|
HINSTANCE hDlginst;
|
|
HGLOBAL hDlgTmpl;
|
|
|
|
if ( (lpChFont->Flags&CF_ENABLETEMPLATEHANDLE)!=0 )
|
|
{
|
|
template=(LPCVOID)lpChFont->hInstance;
|
|
} else
|
|
{
|
|
if ( (lpChFont->Flags&CF_ENABLETEMPLATE)!=0 )
|
|
{
|
|
hDlginst=lpChFont->hInstance;
|
|
if( !(hResInfo = FindResourceA(hDlginst, lpChFont->lpTemplateName,
|
|
RT_DIALOGA)))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
} else
|
|
{
|
|
hDlginst=COMMDLG_hInstance32;
|
|
if (!(hResInfo = FindResourceA(hDlginst, "CHOOSE_FONT", RT_DIALOGA)))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
}
|
|
if (!(hDlgTmpl = LoadResource(hDlginst, hResInfo )) ||
|
|
!(template = LockResource( hDlgTmpl )))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
}
|
|
if (TRACE_ON(commdlg))
|
|
_dump_cf_flags(lpChFont->Flags);
|
|
|
|
if (lpChFont->Flags & (CF_SELECTSCRIPT | CF_NOVERTFONTS ))
|
|
FIXME(": unimplemented flag (ignored)\n");
|
|
|
|
return DialogBoxIndirectParamA(COMMDLG_hInstance32, template,
|
|
lpChFont->hwndOwner, FormatCharDlgProcA, (LPARAM)lpChFont );
|
|
}
|
|
|
|
/***********************************************************************
|
|
* ChooseFontW (COMDLG32.@)
|
|
*
|
|
* NOTES:
|
|
*
|
|
* The LOGFONT conversion functions will break if the structure ever
|
|
* grows beyond the lfFaceName element.
|
|
*
|
|
* The CHOOSEFONT conversion functions assume that both versions of
|
|
* lpLogFont and lpszStyle (if used) point to pre-allocated objects.
|
|
*
|
|
* The ASCII version of lpTemplateName is created by ChooseFontAtoW
|
|
* and freed by ChooseFontWtoA.
|
|
*/
|
|
inline static VOID LogFontWtoA(const LOGFONTW *lfw, LOGFONTA *lfa)
|
|
{
|
|
memcpy(lfa, lfw, sizeof(LOGFONTA));
|
|
WideCharToMultiByte(CP_ACP, 0, lfw->lfFaceName, -1, lfa->lfFaceName,
|
|
LF_FACESIZE, NULL, NULL);
|
|
lfa->lfFaceName[LF_FACESIZE - 1] = '\0';
|
|
}
|
|
|
|
inline static VOID LogFontAtoW(const LOGFONTA *lfa, LOGFONTW *lfw)
|
|
{
|
|
memcpy(lfw, lfa, sizeof(LOGFONTA));
|
|
MultiByteToWideChar(CP_ACP, 0, lfa->lfFaceName, -1, lfw->lfFaceName,
|
|
LF_FACESIZE);
|
|
lfw->lfFaceName[LF_FACESIZE - 1] = 0;
|
|
}
|
|
|
|
static BOOL ChooseFontWtoA(const CHOOSEFONTW *cfw, CHOOSEFONTA *cfa)
|
|
{
|
|
LOGFONTA *lpLogFont = cfa->lpLogFont;
|
|
LPSTR lpszStyle = cfa->lpszStyle;
|
|
|
|
memcpy(cfa, cfw, sizeof(CHOOSEFONTA));
|
|
cfa->lpLogFont = lpLogFont;
|
|
cfa->lpszStyle = lpszStyle;
|
|
|
|
LogFontWtoA(cfw->lpLogFont, lpLogFont);
|
|
|
|
if ((cfw->Flags&CF_ENABLETEMPLATE)!=0 && HIWORD(cfw->lpTemplateName)!=0)
|
|
{
|
|
cfa->lpTemplateName = HEAP_strdupWtoA(GetProcessHeap(), 0,
|
|
cfw->lpTemplateName);
|
|
if (cfa->lpTemplateName == NULL)
|
|
return FALSE;
|
|
}
|
|
|
|
if ((cfw->Flags & CF_USESTYLE) != 0 && cfw->lpszStyle != NULL)
|
|
{
|
|
WideCharToMultiByte(CP_ACP, 0, cfw->lpszStyle, -1, cfa->lpszStyle,
|
|
LF_FACESIZE, NULL, NULL);
|
|
cfa->lpszStyle[LF_FACESIZE - 1] = '\0';
|
|
}
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
static VOID ChooseFontAtoW(const CHOOSEFONTA *cfa, CHOOSEFONTW *cfw)
|
|
{
|
|
LOGFONTW *lpLogFont = cfw->lpLogFont;
|
|
LPWSTR lpszStyle = cfw->lpszStyle;
|
|
LPCWSTR lpTemplateName = cfw->lpTemplateName;
|
|
|
|
memcpy(cfw, cfa, sizeof(CHOOSEFONTA));
|
|
cfw->lpLogFont = lpLogFont;
|
|
cfw->lpszStyle = lpszStyle;
|
|
cfw->lpTemplateName = lpTemplateName;
|
|
|
|
LogFontAtoW(cfa->lpLogFont, lpLogFont);
|
|
|
|
if ((cfa->Flags&CF_ENABLETEMPLATE)!=0 && HIWORD(cfa->lpTemplateName) != 0)
|
|
HeapFree(GetProcessHeap(), 0, (LPSTR)(cfa->lpTemplateName));
|
|
|
|
if ((cfa->Flags & CF_USESTYLE) != 0 && cfa->lpszStyle != NULL)
|
|
{
|
|
MultiByteToWideChar(CP_ACP, 0, cfa->lpszStyle, -1, cfw->lpszStyle,
|
|
LF_FACESIZE);
|
|
cfw->lpszStyle[LF_FACESIZE - 1] = 0;
|
|
}
|
|
}
|
|
|
|
BOOL WINAPI ChooseFontW(LPCHOOSEFONTW lpChFont)
|
|
{
|
|
CHOOSEFONTA cf_a;
|
|
LOGFONTA lf_a;
|
|
CHAR style_a[LF_FACESIZE];
|
|
|
|
cf_a.lpLogFont = &lf_a;
|
|
cf_a.lpszStyle = style_a;
|
|
|
|
if (ChooseFontWtoA(lpChFont, &cf_a) == FALSE)
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_MEMALLOCFAILURE);
|
|
return FALSE;
|
|
}
|
|
|
|
if (ChooseFontA(&cf_a) == FALSE)
|
|
{
|
|
if (cf_a.lpTemplateName != NULL)
|
|
HeapFree(GetProcessHeap(), 0, (LPSTR)(cf_a.lpTemplateName));
|
|
return FALSE;
|
|
}
|
|
|
|
ChooseFontAtoW(&cf_a, lpChFont);
|
|
|
|
return TRUE;
|
|
}
|
|
|
|
#if 0
|
|
/***********************************************************************
|
|
* ChooseFontW (COMDLG32.@)
|
|
*/
|
|
BOOL WINAPI ChooseFontW(LPCHOOSEFONTW lpChFont)
|
|
{
|
|
BOOL bRet=FALSE;
|
|
CHOOSEFONTA cf32a;
|
|
LOGFONTA lf32a;
|
|
LPCVOID template;
|
|
HANDLE hResInfo, hDlgTmpl;
|
|
|
|
if (TRACE_ON(commdlg))
|
|
_dump_cf_flags(lpChFont->Flags);
|
|
|
|
if (!(hResInfo = FindResourceA(COMMDLG_hInstance32, "CHOOSE_FONT", RT_DIALOGA)))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_FINDRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
if (!(hDlgTmpl = LoadResource(COMMDLG_hInstance32, hResInfo )) ||
|
|
!(template = LockResource( hDlgTmpl )))
|
|
{
|
|
COMDLG32_SetCommDlgExtendedError(CDERR_LOADRESFAILURE);
|
|
return FALSE;
|
|
}
|
|
|
|
if (lpChFont->Flags & (CF_SELECTSCRIPT | CF_NOVERTFONTS | CF_ENABLETEMPLATE |
|
|
CF_ENABLETEMPLATEHANDLE)) FIXME(": unimplemented flag (ignored)\n");
|
|
memcpy(&cf32a, lpChFont, sizeof(cf32a));
|
|
memcpy(&lf32a, lpChFont->lpLogFont, sizeof(LOGFONTA));
|
|
|
|
WideCharToMultiByte( CP_ACP, 0, lpChFont->lpLogFont->lfFaceName, -1,
|
|
lf32a.lfFaceName, LF_FACESIZE, NULL, NULL );
|
|
lf32a.lfFaceName[LF_FACESIZE-1] = 0;
|
|
cf32a.lpLogFont=&lf32a;
|
|
cf32a.lpszStyle=HEAP_strdupWtoA(GetProcessHeap(), 0, lpChFont->lpszStyle);
|
|
lpChFont->lpTemplateName=(LPWSTR)&cf32a;
|
|
bRet = DialogBoxIndirectParamW(COMMDLG_hInstance32, template,
|
|
lpChFont->hwndOwner, FormatCharDlgProcW, (LPARAM)lpChFont );
|
|
HeapFree(GetProcessHeap(), 0, cf32a.lpszStyle);
|
|
lpChFont->lpTemplateName=(LPWSTR)cf32a.lpTemplateName;
|
|
memcpy(lpChFont->lpLogFont, &lf32a, sizeof(CHOOSEFONTA));
|
|
MultiByteToWideChar( CP_ACP, 0, lf32a.lfFaceName, -1,
|
|
lpChFont->lpLogFont->lfFaceName, LF_FACESIZE );
|
|
lpChFont->lpLogFont->lfFaceName[LF_FACESIZE-1] = 0;
|
|
return bRet;
|
|
}
|
|
#endif
|
|
|
|
#define TEXT_EXTRAS 4
|
|
#define TEXT_COLORS 16
|
|
|
|
static const COLORREF textcolors[TEXT_COLORS]=
|
|
{
|
|
0x00000000L,0x00000080L,0x00008000L,0x00008080L,
|
|
0x00800000L,0x00800080L,0x00808000L,0x00808080L,
|
|
0x00c0c0c0L,0x000000ffL,0x0000ff00L,0x0000ffffL,
|
|
0x00ff0000L,0x00ff00ffL,0x00ffff00L,0x00FFFFFFL
|
|
};
|
|
|
|
/***********************************************************************
|
|
* CFn_HookCallChk [internal]
|
|
*/
|
|
static BOOL CFn_HookCallChk(LPCHOOSEFONT16 lpcf)
|
|
{
|
|
if (lpcf)
|
|
if(lpcf->Flags & CF_ENABLEHOOK)
|
|
if (lpcf->lpfnHook)
|
|
return TRUE;
|
|
return FALSE;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* CFn_HookCallChk32 [internal]
|
|
*/
|
|
static BOOL CFn_HookCallChk32(LPCHOOSEFONTA lpcf)
|
|
{
|
|
if (lpcf)
|
|
if(lpcf->Flags & CF_ENABLEHOOK)
|
|
if (lpcf->lpfnHook)
|
|
return TRUE;
|
|
return FALSE;
|
|
}
|
|
|
|
typedef struct
|
|
{
|
|
HWND hWnd1;
|
|
HWND hWnd2;
|
|
LPCHOOSEFONTA lpcf32a;
|
|
int added;
|
|
} CFn_ENUMSTRUCT, *LPCFn_ENUMSTRUCT;
|
|
|
|
/*************************************************************************
|
|
* AddFontFamily [internal]
|
|
*/
|
|
static INT AddFontFamily(const LOGFONTA *lplf, UINT nFontType,
|
|
LPCHOOSEFONTA lpcf, HWND hwnd, LPCFn_ENUMSTRUCT e)
|
|
{
|
|
int i;
|
|
WORD w;
|
|
|
|
TRACE("font=%s (nFontType=%d)\n", lplf->lfFaceName,nFontType);
|
|
|
|
if (lpcf->Flags & CF_FIXEDPITCHONLY)
|
|
if (!(lplf->lfPitchAndFamily & FIXED_PITCH))
|
|
return 1;
|
|
if (lpcf->Flags & CF_ANSIONLY)
|
|
if (lplf->lfCharSet != ANSI_CHARSET)
|
|
return 1;
|
|
if (lpcf->Flags & CF_TTONLY)
|
|
if (!(nFontType & TRUETYPE_FONTTYPE))
|
|
return 1;
|
|
|
|
if (e) e->added++;
|
|
|
|
i=SendMessageA(hwnd, CB_ADDSTRING, 0, (LPARAM)lplf->lfFaceName);
|
|
if (i!=CB_ERR)
|
|
{
|
|
w=(lplf->lfCharSet << 8) | lplf->lfPitchAndFamily;
|
|
SendMessageA(hwnd, CB_SETITEMDATA, i, MAKELONG(nFontType,w));
|
|
return 1 ; /* store some important font information */
|
|
}
|
|
else
|
|
return 0;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* FontFamilyEnumProc32 [internal]
|
|
*/
|
|
static INT WINAPI FontFamilyEnumProc(const LOGFONTA *lpLogFont,
|
|
const TEXTMETRICA *metrics, DWORD dwFontType, LPARAM lParam)
|
|
{
|
|
LPCFn_ENUMSTRUCT e;
|
|
e=(LPCFn_ENUMSTRUCT)lParam;
|
|
return AddFontFamily(lpLogFont, dwFontType, e->lpcf32a, e->hWnd1, e);
|
|
}
|
|
|
|
/***********************************************************************
|
|
* FontFamilyEnumProc (COMMDLG.19)
|
|
*/
|
|
INT16 WINAPI FontFamilyEnumProc16( SEGPTR logfont, SEGPTR metrics,
|
|
UINT16 nFontType, LPARAM lParam )
|
|
{
|
|
HWND hwnd=HWND_32(LOWORD(lParam));
|
|
HWND hDlg=GetParent(hwnd);
|
|
LPCHOOSEFONT16 lpcf=(LPCHOOSEFONT16)GetWindowLongA(hDlg, DWL_USER);
|
|
LOGFONT16 *lplf = MapSL( logfont );
|
|
LOGFONTA lf32a;
|
|
FONT_LogFont16To32A(lplf, &lf32a);
|
|
return AddFontFamily(&lf32a, nFontType, (LPCHOOSEFONTA)lpcf->lpTemplateName,
|
|
hwnd,NULL);
|
|
}
|
|
|
|
/*************************************************************************
|
|
* SetFontStylesToCombo2 [internal]
|
|
*
|
|
* Fill font style information into combobox (without using font.c directly)
|
|
*/
|
|
static int SetFontStylesToCombo2(HWND hwnd, HDC hdc, const LOGFONTA *lplf)
|
|
{
|
|
#define FSTYLES 4
|
|
struct FONTSTYLE
|
|
{ int italic;
|
|
int weight;
|
|
char stname[20]; };
|
|
static struct FONTSTYLE fontstyles[FSTYLES]={
|
|
{ 0,FW_NORMAL,"Regular"},{0,FW_BOLD,"Bold"},
|
|
{ 1,FW_NORMAL,"Italic"}, {1,FW_BOLD,"Bold Italic"}};
|
|
HFONT hf;
|
|
TEXTMETRICA tm;
|
|
int i,j;
|
|
LOGFONTA lf;
|
|
|
|
memcpy(&lf, lplf, sizeof(LOGFONTA));
|
|
|
|
for (i=0;i<FSTYLES;i++)
|
|
{
|
|
lf.lfItalic=fontstyles[i].italic;
|
|
lf.lfWeight=fontstyles[i].weight;
|
|
hf=CreateFontIndirectA(&lf);
|
|
hf=SelectObject(hdc,hf);
|
|
GetTextMetricsA(hdc,&tm);
|
|
hf=SelectObject(hdc,hf);
|
|
DeleteObject(hf);
|
|
|
|
if (tm.tmWeight==fontstyles[i].weight &&
|
|
tm.tmItalic==fontstyles[i].italic) /* font successful created ? */
|
|
{
|
|
j=SendMessageA(hwnd,CB_ADDSTRING,0,(LPARAM)fontstyles[i].stname );
|
|
if (j==CB_ERR) return 1;
|
|
j=SendMessageA(hwnd, CB_SETITEMDATA, j,
|
|
MAKELONG(fontstyles[i].weight,fontstyles[i].italic));
|
|
if (j==CB_ERR) return 1;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* AddFontSizeToCombo3 [internal]
|
|
*/
|
|
static int AddFontSizeToCombo3(HWND hwnd, UINT h, LPCHOOSEFONTA lpcf)
|
|
{
|
|
int j;
|
|
char buffer[20];
|
|
|
|
if ( (!(lpcf->Flags & CF_LIMITSIZE)) ||
|
|
((lpcf->Flags & CF_LIMITSIZE) && (h >= lpcf->nSizeMin) && (h <= lpcf->nSizeMax)))
|
|
{
|
|
sprintf(buffer, "%2d", h);
|
|
j=SendMessageA(hwnd, CB_FINDSTRINGEXACT, -1, (LPARAM)buffer);
|
|
if (j==CB_ERR)
|
|
{
|
|
j=SendMessageA(hwnd, CB_ADDSTRING, 0, (LPARAM)buffer);
|
|
if (j!=CB_ERR) j = SendMessageA(hwnd, CB_SETITEMDATA, j, h);
|
|
if (j==CB_ERR) return 1;
|
|
}
|
|
}
|
|
return 0;
|
|
}
|
|
|
|
/*************************************************************************
|
|
* SetFontSizesToCombo3 [internal]
|
|
*/
|
|
static int SetFontSizesToCombo3(HWND hwnd, LPCHOOSEFONTA lpcf)
|
|
{
|
|
static const int sizes[]={8,9,10,11,12,14,16,18,20,22,24,26,28,36,48,72,0};
|
|
int i;
|
|
|
|
for (i=0; sizes[i]; i++)
|
|
if (AddFontSizeToCombo3(hwnd, sizes[i], lpcf)) return 1;
|
|
return 0;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* AddFontStyle [internal]
|
|
*/
|
|
static INT AddFontStyle(const LOGFONTA *lplf, UINT nFontType,
|
|
LPCHOOSEFONTA lpcf, HWND hcmb2, HWND hcmb3, HWND hDlg)
|
|
{
|
|
int i;
|
|
|
|
TRACE("(nFontType=%d)\n",nFontType);
|
|
TRACE(" %s h=%ld w=%ld e=%ld o=%ld wg=%ld i=%d u=%d s=%d"
|
|
" ch=%d op=%d cp=%d q=%d pf=%xh\n",
|
|
lplf->lfFaceName,lplf->lfHeight,lplf->lfWidth,
|
|
lplf->lfEscapement,lplf->lfOrientation,
|
|
lplf->lfWeight,lplf->lfItalic,lplf->lfUnderline,
|
|
lplf->lfStrikeOut,lplf->lfCharSet, lplf->lfOutPrecision,
|
|
lplf->lfClipPrecision,lplf->lfQuality, lplf->lfPitchAndFamily);
|
|
if (nFontType & RASTER_FONTTYPE)
|
|
{
|
|
if (AddFontSizeToCombo3(hcmb3, lplf->lfHeight, lpcf)) return 0;
|
|
} else if (SetFontSizesToCombo3(hcmb3, lpcf)) return 0;
|
|
|
|
if (!SendMessageA(hcmb2, CB_GETCOUNT, 0, 0))
|
|
{
|
|
HDC hdc= ((lpcf->Flags & CF_PRINTERFONTS) && lpcf->hDC) ? lpcf->hDC : GetDC(hDlg);
|
|
i=SetFontStylesToCombo2(hcmb2,hdc,lplf);
|
|
if (!((lpcf->Flags & CF_PRINTERFONTS) && lpcf->hDC))
|
|
ReleaseDC(hDlg,hdc);
|
|
if (i)
|
|
return 0;
|
|
}
|
|
return 1 ;
|
|
|
|
}
|
|
|
|
/***********************************************************************
|
|
* FontStyleEnumProc (COMMDLG.18)
|
|
*/
|
|
INT16 WINAPI FontStyleEnumProc16( SEGPTR logfont, SEGPTR metrics,
|
|
UINT16 nFontType, LPARAM lParam )
|
|
{
|
|
HWND hcmb2=HWND_32(LOWORD(lParam));
|
|
HWND hcmb3=HWND_32(HIWORD(lParam));
|
|
HWND hDlg=GetParent(hcmb3);
|
|
LPCHOOSEFONT16 lpcf=(LPCHOOSEFONT16)GetWindowLongA(hDlg, DWL_USER);
|
|
LOGFONT16 *lplf = MapSL(logfont);
|
|
LOGFONTA lf32a;
|
|
FONT_LogFont16To32A(lplf, &lf32a);
|
|
return AddFontStyle(&lf32a, nFontType, (LPCHOOSEFONTA)lpcf->lpTemplateName,
|
|
hcmb2, hcmb3, hDlg);
|
|
}
|
|
|
|
/***********************************************************************
|
|
* FontStyleEnumProc32 [internal]
|
|
*/
|
|
static INT WINAPI FontStyleEnumProc( const LOGFONTA *lpFont,
|
|
const TEXTMETRICA *metrics, DWORD dwFontType, LPARAM lParam )
|
|
{
|
|
LPCFn_ENUMSTRUCT s=(LPCFn_ENUMSTRUCT)lParam;
|
|
HWND hcmb2=s->hWnd1;
|
|
HWND hcmb3=s->hWnd2;
|
|
HWND hDlg=GetParent(hcmb3);
|
|
return AddFontStyle(lpFont, dwFontType, s->lpcf32a, hcmb2,
|
|
hcmb3, hDlg);
|
|
}
|
|
|
|
/***********************************************************************
|
|
* CFn_WMInitDialog [internal]
|
|
*/
|
|
static LRESULT CFn_WMInitDialog(HWND hDlg, WPARAM wParam, LPARAM lParam,
|
|
LPCHOOSEFONTA lpcf)
|
|
{
|
|
HDC hdc;
|
|
int i,j,init=0;
|
|
long l;
|
|
LPLOGFONTA lpxx;
|
|
HCURSOR hcursor=SetCursor(LoadCursorA(0,IDC_WAITA));
|
|
|
|
SetWindowLongA(hDlg, DWL_USER, lParam);
|
|
lpxx=lpcf->lpLogFont;
|
|
TRACE("WM_INITDIALOG lParam=%08lX\n", lParam);
|
|
|
|
if (lpcf->lStructSize != sizeof(CHOOSEFONTA))
|
|
{
|
|
ERR("structure size failure !!!\n");
|
|
EndDialog (hDlg, 0);
|
|
return FALSE;
|
|
}
|
|
if (!hBitmapTT)
|
|
hBitmapTT = LoadBitmapA(0, MAKEINTRESOURCEA(OBM_TRTYPE));
|
|
|
|
if (!(lpcf->Flags & CF_SHOWHELP) || !IsWindow(lpcf->hwndOwner))
|
|
ShowWindow(GetDlgItem(hDlg,pshHelp),SW_HIDE);
|
|
if (!(lpcf->Flags & CF_APPLY))
|
|
ShowWindow(GetDlgItem(hDlg,psh3),SW_HIDE);
|
|
if (lpcf->Flags & CF_EFFECTS)
|
|
{
|
|
for (i=0;i<TEXT_COLORS;i++)
|
|
{
|
|
char name[30];
|
|
|
|
if( LoadStringA(COMMDLG_hInstance32, IDS_COLOR_BLACK+i, name,
|
|
sizeof(name)/sizeof(*name) )==0 )
|
|
{
|
|
strcpy( name, "[color name]" );
|
|
}
|
|
j=SendDlgItemMessageA(hDlg, cmb4, CB_ADDSTRING, 0, (LPARAM)name);
|
|
SendDlgItemMessageA(hDlg, cmb4, CB_SETITEMDATA16, j, textcolors[j]);
|
|
/* look for a fitting value in color combobox */
|
|
if (textcolors[j]==lpcf->rgbColors)
|
|
SendDlgItemMessageA(hDlg,cmb4, CB_SETCURSEL,j,0);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
ShowWindow(GetDlgItem(hDlg,cmb4),SW_HIDE);
|
|
ShowWindow(GetDlgItem(hDlg,chx1),SW_HIDE);
|
|
ShowWindow(GetDlgItem(hDlg,chx2),SW_HIDE);
|
|
ShowWindow(GetDlgItem(hDlg,grp1),SW_HIDE);
|
|
ShowWindow(GetDlgItem(hDlg,stc4),SW_HIDE);
|
|
}
|
|
hdc= ((lpcf->Flags & CF_PRINTERFONTS) && lpcf->hDC) ? lpcf->hDC : GetDC(hDlg);
|
|
if (hdc)
|
|
{
|
|
CFn_ENUMSTRUCT s;
|
|
s.hWnd1=GetDlgItem(hDlg,cmb1);
|
|
s.lpcf32a=lpcf;
|
|
do {
|
|
s.added = 0;
|
|
if (!EnumFontFamiliesA(hdc, NULL, FontFamilyEnumProc, (LPARAM)&s)) {
|
|
TRACE("EnumFontFamilies returns 0\n");
|
|
break;
|
|
}
|
|
if (s.added) break;
|
|
if (lpcf->Flags & CF_FIXEDPITCHONLY) {
|
|
FIXME("No founds found with fixed pitch only, dropping flag.\n");
|
|
lpcf->Flags &= ~CF_FIXEDPITCHONLY;
|
|
continue;
|
|
}
|
|
if (lpcf->Flags & CF_TTONLY) {
|
|
FIXME("No founds found with truetype only, dropping flag.\n");
|
|
lpcf->Flags &= ~CF_TTONLY;
|
|
continue;
|
|
}
|
|
break;
|
|
} while (1);
|
|
|
|
|
|
if (lpcf->Flags & CF_INITTOLOGFONTSTRUCT)
|
|
{
|
|
/* look for fitting font name in combobox1 */
|
|
j=SendDlgItemMessageA(hDlg,cmb1,CB_FINDSTRING,-1,(LONG)lpxx->lfFaceName);
|
|
if (j!=CB_ERR)
|
|
{
|
|
SendDlgItemMessageA(hDlg, cmb1, CB_SETCURSEL, j, 0);
|
|
SendMessageA(hDlg, WM_COMMAND, MAKEWPARAM(cmb1, CBN_SELCHANGE),
|
|
(LPARAM)GetDlgItem(hDlg,cmb1));
|
|
init=1;
|
|
/* look for fitting font style in combobox2 */
|
|
l=MAKELONG(lpxx->lfWeight > FW_MEDIUM ? FW_BOLD:FW_NORMAL,lpxx->lfItalic !=0);
|
|
for (i=0;i<TEXT_EXTRAS;i++)
|
|
{
|
|
if (l==SendDlgItemMessageA(hDlg, cmb2, CB_GETITEMDATA, i, 0))
|
|
SendDlgItemMessageA(hDlg, cmb2, CB_SETCURSEL, i, 0);
|
|
}
|
|
|
|
/* look for fitting font size in combobox3 */
|
|
j=SendDlgItemMessageA(hDlg, cmb3, CB_GETCOUNT, 0, 0);
|
|
for (i=0;i<j;i++)
|
|
{
|
|
if (lpxx->lfHeight==(int)SendDlgItemMessageA(hDlg,cmb3, CB_GETITEMDATA,i,0))
|
|
SendDlgItemMessageA(hDlg,cmb3,CB_SETCURSEL,i,0);
|
|
}
|
|
}
|
|
}
|
|
if (!init)
|
|
{
|
|
SendDlgItemMessageA(hDlg,cmb1,CB_SETCURSEL,0,0);
|
|
SendMessageA(hDlg, WM_COMMAND, MAKEWPARAM(cmb1, CBN_SELCHANGE),
|
|
(LPARAM)GetDlgItem(hDlg,cmb1));
|
|
}
|
|
if (lpcf->Flags & CF_USESTYLE && lpcf->lpszStyle)
|
|
{
|
|
j=SendDlgItemMessageA(hDlg,cmb2,CB_FINDSTRING,-1,(LONG)lpcf->lpszStyle);
|
|
if (j!=CB_ERR)
|
|
{
|
|
j=SendDlgItemMessageA(hDlg,cmb2,CB_SETCURSEL,j,0);
|
|
SendMessageA(hDlg,WM_COMMAND,cmb2,
|
|
MAKELONG(HWND_16(GetDlgItem(hDlg,cmb2)),CBN_SELCHANGE));
|
|
}
|
|
}
|
|
}
|
|
else
|
|
{
|
|
WARN("HDC failure !!!\n");
|
|
EndDialog (hDlg, 0);
|
|
return FALSE;
|
|
}
|
|
|
|
if (!((lpcf->Flags & CF_PRINTERFONTS) && lpcf->hDC))
|
|
ReleaseDC(hDlg,hdc);
|
|
SetCursor(hcursor);
|
|
return TRUE;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* CFn_WMMeasureItem [internal]
|
|
*/
|
|
static LRESULT CFn_WMMeasureItem(HWND hDlg, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
BITMAP bm;
|
|
LPMEASUREITEMSTRUCT lpmi=(LPMEASUREITEMSTRUCT)lParam;
|
|
if (!hBitmapTT)
|
|
hBitmapTT = LoadBitmapA(0, MAKEINTRESOURCEA(OBM_TRTYPE));
|
|
GetObjectA( hBitmapTT, sizeof(bm), &bm );
|
|
lpmi->itemHeight=bm.bmHeight;
|
|
/* FIXME: use MAX of bm.bmHeight and tm.tmHeight .*/
|
|
return 0;
|
|
}
|
|
|
|
|
|
/***********************************************************************
|
|
* CFn_WMDrawItem [internal]
|
|
*/
|
|
static LRESULT CFn_WMDrawItem(HWND hDlg, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
HBRUSH hBrush;
|
|
char buffer[40];
|
|
BITMAP bm;
|
|
COLORREF cr, oldText=0, oldBk=0;
|
|
RECT rect;
|
|
#if 0
|
|
HDC hMemDC;
|
|
int nFontType;
|
|
HBITMAP hBitmap; /* for later TT usage */
|
|
#endif
|
|
LPDRAWITEMSTRUCT lpdi = (LPDRAWITEMSTRUCT)lParam;
|
|
|
|
if (lpdi->itemID == (UINT)-1) /* got no items */
|
|
DrawFocusRect(lpdi->hDC, &lpdi->rcItem);
|
|
else
|
|
{
|
|
if (lpdi->CtlType == ODT_COMBOBOX)
|
|
{
|
|
if (lpdi->itemState ==ODS_SELECTED)
|
|
{
|
|
hBrush=GetSysColorBrush(COLOR_HIGHLIGHT);
|
|
oldText=SetTextColor(lpdi->hDC, GetSysColor(COLOR_HIGHLIGHTTEXT));
|
|
oldBk=SetBkColor(lpdi->hDC, GetSysColor(COLOR_HIGHLIGHT));
|
|
} else
|
|
{
|
|
hBrush = SelectObject(lpdi->hDC, GetStockObject(LTGRAY_BRUSH));
|
|
SelectObject(lpdi->hDC, hBrush);
|
|
}
|
|
FillRect(lpdi->hDC, &lpdi->rcItem, hBrush);
|
|
}
|
|
else
|
|
return TRUE; /* this should never happen */
|
|
|
|
rect=lpdi->rcItem;
|
|
switch (lpdi->CtlID)
|
|
{
|
|
case cmb1: /* TRACE(commdlg,"WM_Drawitem cmb1\n"); */
|
|
SendMessageA(lpdi->hwndItem, CB_GETLBTEXT, lpdi->itemID,
|
|
(LPARAM)buffer);
|
|
GetObjectA( hBitmapTT, sizeof(bm), &bm );
|
|
TextOutA(lpdi->hDC, lpdi->rcItem.left + bm.bmWidth + 10,
|
|
lpdi->rcItem.top, buffer, strlen(buffer));
|
|
#if 0
|
|
nFontType = SendMessageA(lpdi->hwndItem, CB_GETITEMDATA, lpdi->itemID,0L);
|
|
/* FIXME: draw bitmap if truetype usage */
|
|
if (nFontType&TRUETYPE_FONTTYPE)
|
|
{
|
|
hMemDC = CreateCompatibleDC(lpdi->hDC);
|
|
hBitmap = SelectObject(hMemDC, hBitmapTT);
|
|
BitBlt(lpdi->hDC, lpdi->rcItem.left, lpdi->rcItem.top,
|
|
bm.bmWidth, bm.bmHeight, hMemDC, 0, 0, SRCCOPY);
|
|
SelectObject(hMemDC, hBitmap);
|
|
DeleteDC(hMemDC);
|
|
}
|
|
#endif
|
|
break;
|
|
case cmb2:
|
|
case cmb3: /* TRACE(commdlg,"WM_DRAWITEN cmb2,cmb3\n"); */
|
|
SendMessageA(lpdi->hwndItem, CB_GETLBTEXT, lpdi->itemID,
|
|
(LPARAM)buffer);
|
|
TextOutA(lpdi->hDC, lpdi->rcItem.left,
|
|
lpdi->rcItem.top, buffer, strlen(buffer));
|
|
break;
|
|
|
|
case cmb4: /* TRACE(commdlg,"WM_DRAWITEM cmb4 (=COLOR)\n"); */
|
|
SendMessageA(lpdi->hwndItem, CB_GETLBTEXT, lpdi->itemID,
|
|
(LPARAM)buffer);
|
|
TextOutA(lpdi->hDC, lpdi->rcItem.left + 25+5,
|
|
lpdi->rcItem.top, buffer, strlen(buffer));
|
|
cr = SendMessageA(lpdi->hwndItem, CB_GETITEMDATA, lpdi->itemID,0L);
|
|
hBrush = CreateSolidBrush(cr);
|
|
if (hBrush)
|
|
{
|
|
hBrush = SelectObject (lpdi->hDC, hBrush) ;
|
|
rect.right=rect.left+25;
|
|
rect.top++;
|
|
rect.left+=5;
|
|
rect.bottom--;
|
|
Rectangle( lpdi->hDC, rect.left, rect.top,
|
|
rect.right, rect.bottom );
|
|
DeleteObject( SelectObject (lpdi->hDC, hBrush)) ;
|
|
}
|
|
rect=lpdi->rcItem;
|
|
rect.left+=25+5;
|
|
break;
|
|
|
|
default: return TRUE; /* this should never happen */
|
|
}
|
|
if (lpdi->itemState == ODS_SELECTED)
|
|
{
|
|
SetTextColor(lpdi->hDC, oldText);
|
|
SetBkColor(lpdi->hDC, oldBk);
|
|
}
|
|
}
|
|
return TRUE;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* CFn_WMCommand [internal]
|
|
*/
|
|
static LRESULT CFn_WMCommand(HWND hDlg, WPARAM wParam, LPARAM lParam,
|
|
LPCHOOSEFONTA lpcf)
|
|
{
|
|
int i,j;
|
|
long l;
|
|
HDC hdc;
|
|
LPLOGFONTA lpxx=lpcf->lpLogFont;
|
|
|
|
TRACE("WM_COMMAND wParam=%08lX lParam=%08lX\n", (LONG)wParam, lParam);
|
|
switch (LOWORD(wParam))
|
|
{
|
|
case cmb1:if (HIWORD(wParam)==CBN_SELCHANGE)
|
|
{
|
|
hdc=((lpcf->Flags & CF_PRINTERFONTS) && lpcf->hDC) ? lpcf->hDC : GetDC(hDlg);
|
|
if (hdc)
|
|
{
|
|
SendDlgItemMessageA(hDlg, cmb2, CB_RESETCONTENT16, 0, 0);
|
|
SendDlgItemMessageA(hDlg, cmb3, CB_RESETCONTENT16, 0, 0);
|
|
i=SendDlgItemMessageA(hDlg, cmb1, CB_GETCURSEL16, 0, 0);
|
|
if (i!=CB_ERR)
|
|
{
|
|
HCURSOR hcursor=SetCursor(LoadCursorA(0,IDC_WAITA));
|
|
CFn_ENUMSTRUCT s;
|
|
char str[256];
|
|
SendDlgItemMessageA(hDlg, cmb1, CB_GETLBTEXT, i,
|
|
(LPARAM)str);
|
|
TRACE("WM_COMMAND/cmb1 =>%s\n",str);
|
|
s.hWnd1=GetDlgItem(hDlg, cmb2);
|
|
s.hWnd2=GetDlgItem(hDlg, cmb3);
|
|
s.lpcf32a=lpcf;
|
|
EnumFontFamiliesA(hdc, str, FontStyleEnumProc, (LPARAM)&s);
|
|
SendDlgItemMessageA(hDlg,cmb2, CB_SETCURSEL, 0, 0);
|
|
SendDlgItemMessageA(hDlg,cmb3, CB_SETCURSEL, 0, 0);
|
|
SetCursor(hcursor);
|
|
}
|
|
if (!((lpcf->Flags & CF_PRINTERFONTS) && lpcf->hDC))
|
|
ReleaseDC(hDlg,hdc);
|
|
}
|
|
else
|
|
{
|
|
WARN("HDC failure !!!\n");
|
|
EndDialog (hDlg, 0);
|
|
return TRUE;
|
|
}
|
|
}
|
|
case chx1:
|
|
case chx2:
|
|
case cmb2:
|
|
case cmb3:if (HIWORD(wParam)==CBN_SELCHANGE || HIWORD(wParam)== BN_CLICKED )
|
|
{
|
|
char str[256];
|
|
WINDOWINFO wininfo;
|
|
|
|
TRACE("WM_COMMAND/cmb2,3 =%08lX\n", lParam);
|
|
i=SendDlgItemMessageA(hDlg,cmb1,CB_GETCURSEL,0,0);
|
|
if (i==CB_ERR)
|
|
i=GetDlgItemTextA( hDlg, cmb1, str, 256 );
|
|
else
|
|
{
|
|
SendDlgItemMessageA(hDlg,cmb1,CB_GETLBTEXT,i,
|
|
(LPARAM)str);
|
|
l=SendDlgItemMessageA(hDlg,cmb1,CB_GETITEMDATA,i,0);
|
|
j=HIWORD(l);
|
|
lpcf->nFontType = LOWORD(l);
|
|
/* FIXME: lpcf->nFontType |= .... SIMULATED_FONTTYPE and so */
|
|
/* same value reported to the EnumFonts
|
|
call back with the extra FONTTYPE_... bits added */
|
|
lpxx->lfPitchAndFamily=j&0xff;
|
|
lpxx->lfCharSet=j>>8;
|
|
}
|
|
strcpy(lpxx->lfFaceName,str);
|
|
i=SendDlgItemMessageA(hDlg, cmb2, CB_GETCURSEL, 0, 0);
|
|
if (i!=CB_ERR)
|
|
{
|
|
l=SendDlgItemMessageA(hDlg, cmb2, CB_GETITEMDATA, i, 0);
|
|
if (0!=(lpxx->lfItalic=HIWORD(l)))
|
|
lpcf->nFontType |= ITALIC_FONTTYPE;
|
|
if ((lpxx->lfWeight=LOWORD(l)) > FW_MEDIUM)
|
|
lpcf->nFontType |= BOLD_FONTTYPE;
|
|
}
|
|
i=SendDlgItemMessageA(hDlg, cmb3, CB_GETCURSEL, 0, 0);
|
|
if (i!=CB_ERR)
|
|
lpxx->lfHeight=-LOWORD(SendDlgItemMessageA(hDlg, cmb3, CB_GETITEMDATA, i, 0));
|
|
else
|
|
lpxx->lfHeight=0;
|
|
lpxx->lfStrikeOut=IsDlgButtonChecked(hDlg,chx1);
|
|
lpxx->lfUnderline=IsDlgButtonChecked(hDlg,chx2);
|
|
lpxx->lfWidth=lpxx->lfOrientation=lpxx->lfEscapement=0;
|
|
lpxx->lfOutPrecision=OUT_DEFAULT_PRECIS;
|
|
lpxx->lfClipPrecision=CLIP_DEFAULT_PRECIS;
|
|
lpxx->lfQuality=DEFAULT_QUALITY;
|
|
lpcf->iPointSize= -10*lpxx->lfHeight;
|
|
|
|
wininfo.cbSize=sizeof(wininfo);
|
|
|
|
if( GetWindowInfo( GetDlgItem( hDlg, stc5), &wininfo ) )
|
|
{
|
|
InvalidateRect( hDlg, &wininfo.rcWindow, TRUE );
|
|
}
|
|
}
|
|
break;
|
|
|
|
case cmb4:
|
|
i=SendDlgItemMessageA(hDlg, cmb4, CB_GETCURSEL, 0, 0);
|
|
if (i!=CB_ERR)
|
|
{
|
|
WINDOWINFO wininfo;
|
|
|
|
lpcf->rgbColors=textcolors[i];
|
|
wininfo.cbSize=sizeof(wininfo);
|
|
|
|
if( GetWindowInfo( GetDlgItem( hDlg, stc5), &wininfo ) )
|
|
{
|
|
InvalidateRect( hDlg, &wininfo.rcWindow, TRUE );
|
|
}
|
|
}
|
|
break;
|
|
|
|
case psh15:i=RegisterWindowMessageA( HELPMSGSTRINGA );
|
|
if (lpcf->hwndOwner)
|
|
SendMessageA(lpcf->hwndOwner, i, 0, (LPARAM)GetWindowLongA(hDlg, DWL_USER));
|
|
/* if (CFn_HookCallChk(lpcf))
|
|
CallWindowProc16(lpcf->lpfnHook,hDlg,WM_COMMAND,psh15,(LPARAM)lpcf);*/
|
|
break;
|
|
|
|
case IDOK:if ( (!(lpcf->Flags & CF_LIMITSIZE)) ||
|
|
( (lpcf->Flags & CF_LIMITSIZE) &&
|
|
(-lpxx->lfHeight >= lpcf->nSizeMin) &&
|
|
(-lpxx->lfHeight <= lpcf->nSizeMax)))
|
|
EndDialog(hDlg, TRUE);
|
|
else
|
|
{
|
|
char buffer[80];
|
|
sprintf(buffer,"Select a font size between %d and %d points.",
|
|
lpcf->nSizeMin,lpcf->nSizeMax);
|
|
MessageBoxA(hDlg, buffer, NULL, MB_OK);
|
|
}
|
|
return(TRUE);
|
|
case IDCANCEL:EndDialog(hDlg, FALSE);
|
|
return(TRUE);
|
|
}
|
|
return(FALSE);
|
|
}
|
|
|
|
static LRESULT CFn_WMDestroy(HWND hwnd, WPARAM wParam, LPARAM lParam)
|
|
{
|
|
return TRUE;
|
|
}
|
|
|
|
static LRESULT CFn_WMPaint(HWND hDlg, WPARAM wParam, LPARAM lParam,
|
|
LPCHOOSEFONTA lpcf )
|
|
{
|
|
WINDOWINFO info;
|
|
|
|
info.cbSize=sizeof(info);
|
|
|
|
if( GetWindowInfo( GetDlgItem( hDlg, stc5), &info ) )
|
|
{
|
|
PAINTSTRUCT ps;
|
|
HDC hdc;
|
|
HPEN hOrigPen;
|
|
HFONT hOrigFont;
|
|
COLORREF rgbPrev;
|
|
WCHAR sample[SAMPLE_EXTLEN+5]={'A','a','B','b'};
|
|
/* Always start with this basic sample */
|
|
|
|
hdc=BeginPaint( hDlg, &ps );
|
|
|
|
/* Paint frame */
|
|
MoveToEx( hdc, info.rcWindow.left, info.rcWindow.bottom, NULL );
|
|
hOrigPen=SelectObject( hdc, CreatePen( PS_SOLID, 2,
|
|
GetSysColor( COLOR_3DSHADOW ) ));
|
|
LineTo( hdc, info.rcWindow.left, info.rcWindow.top );
|
|
LineTo( hdc, info.rcWindow.right, info.rcWindow.top );
|
|
DeleteObject(SelectObject( hdc, CreatePen( PS_SOLID, 2,
|
|
GetSysColor( COLOR_3DLIGHT ) )));
|
|
LineTo( hdc, info.rcWindow.right, info.rcWindow.bottom );
|
|
LineTo( hdc, info.rcWindow.left, info.rcWindow.bottom );
|
|
DeleteObject(SelectObject( hdc, hOrigPen ));
|
|
|
|
/* Draw the sample text itself */
|
|
lstrcatW(sample, SAMPLE_LANG_TEXT[CHARSET_ORDER[lpcf->lpLogFont->lfCharSet]] );
|
|
|
|
info.rcWindow.right--;
|
|
info.rcWindow.bottom--;
|
|
info.rcWindow.top++;
|
|
info.rcWindow.left++;
|
|
hOrigFont=SelectObject( hdc, CreateFontIndirectA( lpcf->lpLogFont ) );
|
|
rgbPrev=SetTextColor( hdc, lpcf->rgbColors );
|
|
|
|
DrawTextW( hdc, sample, -1, &info.rcWindow, DT_CENTER|DT_VCENTER|DT_SINGLELINE );
|
|
|
|
EndPaint( hDlg, &ps );
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* FormatCharDlgProc (COMMDLG.16)
|
|
FIXME: 1. some strings are "hardcoded", but it's better load from sysres
|
|
2. some CF_.. flags are not supported
|
|
3. some TType extensions
|
|
*/
|
|
BOOL16 CALLBACK FormatCharDlgProc16(HWND16 hDlg16, UINT16 message,
|
|
WPARAM16 wParam, LPARAM lParam)
|
|
{
|
|
HWND hDlg = HWND_32(hDlg16);
|
|
LPCHOOSEFONT16 lpcf;
|
|
LPCHOOSEFONTA lpcf32a;
|
|
BOOL16 res=0;
|
|
if (message!=WM_INITDIALOG)
|
|
{
|
|
lpcf=(LPCHOOSEFONT16)GetWindowLongA(hDlg, DWL_USER);
|
|
if (!lpcf)
|
|
return FALSE;
|
|
if (CFn_HookCallChk(lpcf))
|
|
res=CallWindowProc16((WNDPROC16)lpcf->lpfnHook,hDlg16,message,wParam,lParam);
|
|
if (res)
|
|
return res;
|
|
}
|
|
else
|
|
{
|
|
lpcf=(LPCHOOSEFONT16)lParam;
|
|
lpcf32a=(LPCHOOSEFONTA)lpcf->lpTemplateName;
|
|
if (!CFn_WMInitDialog(hDlg, wParam, lParam, lpcf32a))
|
|
{
|
|
TRACE("CFn_WMInitDialog returned FALSE\n");
|
|
return FALSE;
|
|
}
|
|
if (CFn_HookCallChk(lpcf))
|
|
return CallWindowProc16((WNDPROC16)lpcf->lpfnHook,hDlg16,WM_INITDIALOG,wParam,lParam);
|
|
}
|
|
lpcf32a=(LPCHOOSEFONTA)lpcf->lpTemplateName;
|
|
switch (message)
|
|
{
|
|
case WM_MEASUREITEM:
|
|
{
|
|
MEASUREITEMSTRUCT16* mis16 = MapSL(lParam);
|
|
MEASUREITEMSTRUCT mis;
|
|
mis.CtlType = mis16->CtlType;
|
|
mis.CtlID = mis16->CtlID;
|
|
mis.itemID = mis16->itemID;
|
|
mis.itemWidth = mis16->itemWidth;
|
|
mis.itemHeight = mis16->itemHeight;
|
|
mis.itemData = mis16->itemData;
|
|
res = CFn_WMMeasureItem(hDlg, wParam, (LPARAM)&mis);
|
|
mis16->itemWidth = (UINT16)mis.itemWidth;
|
|
mis16->itemHeight = (UINT16)mis.itemHeight;
|
|
}
|
|
break;
|
|
case WM_DRAWITEM:
|
|
{
|
|
DRAWITEMSTRUCT16* dis16 = MapSL(lParam);
|
|
DRAWITEMSTRUCT dis;
|
|
dis.CtlType = dis16->CtlType;
|
|
dis.CtlID = dis16->CtlID;
|
|
dis.itemID = dis16->itemID;
|
|
dis.itemAction = dis16->itemAction;
|
|
dis.itemState = dis16->itemState;
|
|
dis.hwndItem = HWND_32(dis16->hwndItem);
|
|
dis.hDC = HDC_32(dis16->hDC);
|
|
dis.itemData = dis16->itemData;
|
|
CONV_RECT16TO32( &dis16->rcItem, &dis.rcItem );
|
|
res = CFn_WMDrawItem(hDlg, wParam, (LPARAM)&dis);
|
|
}
|
|
break;
|
|
case WM_COMMAND:
|
|
res=CFn_WMCommand(hDlg, MAKEWPARAM( wParam, HIWORD(lParam) ), LOWORD(lParam), lpcf32a);
|
|
break;
|
|
case WM_DESTROY:
|
|
res=CFn_WMDestroy(hDlg, wParam, lParam);
|
|
break;
|
|
case WM_CHOOSEFONT_GETLOGFONT:
|
|
TRACE("WM_CHOOSEFONT_GETLOGFONT lParam=%08lX\n", lParam);
|
|
FIXME("current logfont back to caller\n");
|
|
break;
|
|
}
|
|
return res;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* FormatCharDlgProcA [internal]
|
|
*/
|
|
INT_PTR CALLBACK FormatCharDlgProcA(HWND hDlg, UINT uMsg, WPARAM wParam,
|
|
LPARAM lParam)
|
|
{
|
|
LPCHOOSEFONTA lpcf;
|
|
INT_PTR res = FALSE;
|
|
if (uMsg!=WM_INITDIALOG)
|
|
{
|
|
lpcf=(LPCHOOSEFONTA)GetWindowLongA(hDlg, DWL_USER);
|
|
if (!lpcf)
|
|
return FALSE;
|
|
if (CFn_HookCallChk32(lpcf))
|
|
res=CallWindowProcA((WNDPROC)lpcf->lpfnHook, hDlg, uMsg, wParam, lParam);
|
|
if (res)
|
|
return res;
|
|
}
|
|
else
|
|
{
|
|
lpcf=(LPCHOOSEFONTA)lParam;
|
|
if (!CFn_WMInitDialog(hDlg, wParam, lParam, lpcf))
|
|
{
|
|
TRACE("CFn_WMInitDialog returned FALSE\n");
|
|
return FALSE;
|
|
}
|
|
if (CFn_HookCallChk32(lpcf))
|
|
return CallWindowProcA((WNDPROC)lpcf->lpfnHook,hDlg,WM_INITDIALOG,wParam,lParam);
|
|
}
|
|
switch (uMsg)
|
|
{
|
|
case WM_MEASUREITEM:
|
|
return CFn_WMMeasureItem(hDlg, wParam, lParam);
|
|
case WM_DRAWITEM:
|
|
return CFn_WMDrawItem(hDlg, wParam, lParam);
|
|
case WM_COMMAND:
|
|
return CFn_WMCommand(hDlg, wParam, lParam, lpcf);
|
|
case WM_DESTROY:
|
|
return CFn_WMDestroy(hDlg, wParam, lParam);
|
|
case WM_CHOOSEFONT_GETLOGFONT:
|
|
TRACE("WM_CHOOSEFONT_GETLOGFONT lParam=%08lX\n",
|
|
lParam);
|
|
FIXME("current logfont back to caller\n");
|
|
break;
|
|
case WM_PAINT:
|
|
return CFn_WMPaint(hDlg, wParam, lParam, lpcf);
|
|
}
|
|
return res;
|
|
}
|
|
|
|
/***********************************************************************
|
|
* FormatCharDlgProcW [internal]
|
|
*/
|
|
INT_PTR CALLBACK FormatCharDlgProcW(HWND hDlg, UINT uMsg, WPARAM wParam,
|
|
LPARAM lParam)
|
|
{
|
|
LPCHOOSEFONTW lpcf32w;
|
|
LPCHOOSEFONTA lpcf32a;
|
|
INT_PTR res = FALSE;
|
|
if (uMsg!=WM_INITDIALOG)
|
|
{
|
|
lpcf32w=(LPCHOOSEFONTW)GetWindowLongA(hDlg, DWL_USER);
|
|
if (!lpcf32w)
|
|
return FALSE;
|
|
if (CFn_HookCallChk32((LPCHOOSEFONTA)lpcf32w))
|
|
res=CallWindowProcW((WNDPROC)lpcf32w->lpfnHook, hDlg, uMsg, wParam, lParam);
|
|
if (res)
|
|
return res;
|
|
}
|
|
else
|
|
{
|
|
lpcf32w=(LPCHOOSEFONTW)lParam;
|
|
lpcf32a=(LPCHOOSEFONTA)lpcf32w->lpTemplateName;
|
|
if (!CFn_WMInitDialog(hDlg, wParam, lParam, lpcf32a))
|
|
{
|
|
TRACE("CFn_WMInitDialog returned FALSE\n");
|
|
return FALSE;
|
|
}
|
|
if (CFn_HookCallChk32((LPCHOOSEFONTA)lpcf32w))
|
|
return CallWindowProcW((WNDPROC)lpcf32w->lpfnHook,hDlg,WM_INITDIALOG,wParam,lParam);
|
|
}
|
|
lpcf32a=(LPCHOOSEFONTA)lpcf32w->lpTemplateName;
|
|
switch (uMsg)
|
|
{
|
|
case WM_MEASUREITEM:
|
|
return CFn_WMMeasureItem(hDlg, wParam, lParam);
|
|
case WM_DRAWITEM:
|
|
return CFn_WMDrawItem(hDlg, wParam, lParam);
|
|
case WM_COMMAND:
|
|
return CFn_WMCommand(hDlg, wParam, lParam, lpcf32a);
|
|
case WM_DESTROY:
|
|
return CFn_WMDestroy(hDlg, wParam, lParam);
|
|
case WM_CHOOSEFONT_GETLOGFONT:
|
|
TRACE("WM_CHOOSEFONT_GETLOGFONT lParam=%08lX\n",
|
|
lParam);
|
|
FIXME("current logfont back to caller\n");
|
|
break;
|
|
}
|
|
return res;
|
|
}
|