/////////////////////////////////////////////////////////////////////////////
-// Name: fontdlg.cpp
+// Name: src/os2/fontdlg.cpp
// Purpose: wxFontDialog class. NOTE: you can use the generic class
// if you wish, instead of implementing this.
// Author: David Webster
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
+#include "wx/fontdlg.h"
+
#ifndef WX_PRECOMP
-#include <stdio.h>
-#include "wx/defs.h"
-#include "wx/utils.h"
-#include "wx/dialog.h"
+ #include <stdio.h>
+ #include "wx/utils.h"
+ #include "wx/dialog.h"
+ #include "wx/math.h"
#endif
-#include "wx/fontdlg.h"
+#include "wx/fontutil.h"
+#include "wx/modalhook.h"
#define INCL_PM
#include <os2.h>
#include "wx/os2/private.h"
-#include "wx/cmndata.h"
-#include <math.h>
#include <stdlib.h>
#include <string.h>
-#define wxDIALOG_DEFAULT_X 300
-#define wxDIALOG_DEFAULT_Y 300
-
-#if !USE_SHARED_LIBRARY
IMPLEMENT_DYNAMIC_CLASS(wxFontDialog, wxDialog)
-#endif
-/*
- * wxFontDialog
- */
-wxFontDialog::wxFontDialog()
+int wxFontDialog::ShowModal()
{
- m_dialogParent = NULL;
-}
+ WX_HOOK_MODAL_DIALOG();
-wxFontDialog::wxFontDialog(wxWindow *parent, wxFontData *data)
-{
- Create(parent, data);
-}
+ FONTDLG vFontDlg;
+ char zCurrentFont[FACESIZE];
+ HWND hWndFontDlg;
+ FACENAMEDESC vFn;
-bool wxFontDialog::Create(wxWindow *parent, wxFontData *data)
-{
- m_dialogParent = parent;
+ memset(&vFontDlg, '\0', sizeof(FONTDLG));
+ zCurrentFont[0] = '\0';
- if (data)
- m_fontData = *data;
- return TRUE;
-}
+ //
+ // Set the fontdlg fields
+ //
+ vFontDlg.cbSize = sizeof(FONTDLG);
+ vFontDlg.hpsScreen = ::WinGetScreenPS(HWND_DESKTOP);
+ vFontDlg.hpsPrinter = NULL;
+ vFontDlg.pszFamilyname = zCurrentFont;
+ vFontDlg.fxPointSize = MAKEFIXED(12,0);
+ vFontDlg.usFamilyBufLen = FACESIZE;
+ vFontDlg.fl = FNTS_CENTER;
+ vFontDlg.clrFore = CLR_BLACK;
+ vFontDlg.clrBack = CLR_WHITE;
-int wxFontDialog::ShowModal()
-{
- // TODO: show (maybe create) the dialog
- return wxID_CANCEL;
-}
+ hWndFontDlg = WinFontDlg( HWND_DESKTOP
+ ,GetParent()->GetHWND()
+ ,&vFontDlg
+ );
+ if (hWndFontDlg && vFontDlg.lReturn == DID_OK)
+ {
+ wxColour vColour((unsigned long)0x00000000);
+ wxNativeFontInfo vInfo;
+
+ m_fontData.m_fontColour = vColour;
+
+ memset(&vFn, '\0', sizeof(FACENAMEDESC));
+ vFn.usSize = sizeof(FACENAMEDESC);
+ vFn.usWeightClass = vFontDlg.usWeight;
+ vFn.usWidthClass = vFontDlg.usWidth;
+
+ memset(&vInfo.fa, '\0', sizeof(FATTRS));
+ memcpy(&vInfo.fn, &vFn, sizeof(FACENAMEDESC));
+
+ vInfo.fa.usRecordLength = vFontDlg.fAttrs.usRecordLength;
+ strcpy(vInfo.fa.szFacename, vFontDlg.fAttrs.szFacename);
+ vInfo.fa.lMatch = vFontDlg.fAttrs.lMatch;
+ //
+ // Debugging
+ //
+ wxFont vChosenFont(vInfo);
+
+ int nPointSize = vFontDlg.fxPointSize >> 16;
+
+ vChosenFont.SetPointSize(nPointSize);
+ m_fontData.m_chosenFont = vChosenFont;
+
+ m_fontData.EncodingInfo().facename = (wxChar*)vFontDlg.fAttrs.szFacename;
+ m_fontData.EncodingInfo().charset = vFontDlg.fAttrs.usCodePage;
+
+ return wxID_OK;
+ }
+ return wxID_CANCEL;
+} // end of wxFontDialg::ShowModal