/////////////////////////////////////////////////////////////////////////////
-// Name: fontdlgg.h
+// Name: wx/generic/fontdlgg.h
// Purpose: wxGenericFontDialog
// Author: Julian Smart
// Modified by:
// Created: 01/02/97
// RCS-ID: $Id$
-// Copyright: (c)
-// Licence: wxWindows licence
+// Copyright: (c) Julian Smart
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
-#ifndef __FONTDLGH_G__
-#define __FONTDLGH_G__
+#ifndef _WX_GENERIC_FONTDLGG_H
+#define _WX_GENERIC_FONTDLGG_H
-#ifdef __GNUG__
-#pragma interface "fontdlgg.h"
-#endif
-
-#include "wx/setup.h"
+#include "wx/defs.h"
#include "wx/gdicmn.h"
#include "wx/font.h"
#include "wx/dialog.h"
/*
* FONT DIALOG
*/
-
+
class WXDLLEXPORT wxChoice;
class WXDLLEXPORT wxText;
class WXDLLEXPORT wxCheckBox;
+class WXDLLEXPORT wxFontPreviewer;
-#define wxID_FONT_UNDERLINE 3000
-#define wxID_FONT_STYLE 3001
-#define wxID_FONT_WEIGHT 3002
-#define wxID_FONT_FAMILY 3003
-#define wxID_FONT_COLOUR 3004
-#define wxID_FONT_SIZE 3005
+enum
+{
+ wxID_FONT_UNDERLINE = 3000,
+ wxID_FONT_STYLE,
+ wxID_FONT_WEIGHT,
+ wxID_FONT_FAMILY,
+ wxID_FONT_COLOUR,
+ wxID_FONT_SIZE
+};
-class WXDLLEXPORT wxGenericFontDialog: public wxDialog
+class WXDLLEXPORT wxGenericFontDialog : public wxFontDialogBase
{
- DECLARE_DYNAMIC_CLASS(wxGenericFontDialog)
- protected:
- wxFontData fontData;
- wxFont dialogFont;
- wxWindow *dialogParent;
+public:
+ wxGenericFontDialog() { Init(); }
+ wxGenericFontDialog(wxWindow *parent, const wxFontData& data)
+ : wxFontDialogBase(parent, data) { Init(); }
+ virtual ~wxGenericFontDialog();
- // Area reserved for font display
- wxRect fontRect;
+ virtual int ShowModal();
- wxChoice *familyChoice;
- wxChoice *styleChoice;
- wxChoice *weightChoice;
- wxChoice *colourChoice;
- wxCheckBox *underLineCheckBox;
- wxChoice *pointSizeChoice;
- bool m_useEvents;
+ // deprecated, for backwards compatibility only
+ wxGenericFontDialog(wxWindow *parent, const wxFontData *data)
+ : wxFontDialogBase(parent, data) { Init(); }
-// static bool fontDialogCancelled;
- public:
-
- wxGenericFontDialog(void);
- wxGenericFontDialog(wxWindow *parent, wxFontData *data = (wxFontData *) NULL);
- ~wxGenericFontDialog(void);
+ // Internal functions
+ void OnCloseWindow(wxCloseEvent& event);
- bool Create(wxWindow *parent, wxFontData *data = (wxFontData *) NULL);
+ virtual void CreateWidgets();
+ virtual void InitializeFont();
- int ShowModal(void);
+ void OnChangeFont(wxCommandEvent& event);
- inline wxFontData& GetFontData(void) { return fontData; }
+protected:
+ // common part of all ctors
+ void Init();
- // Internal functions
- void OnPaint(wxPaintEvent& event);
+ virtual bool DoCreate(wxWindow *parent);
- void OnCloseWindow(wxCloseEvent& event);
+ wxFont dialogFont;
- virtual void CreateWidgets(void);
- virtual void InitializeFont(void);
-
- virtual void PaintFontBackground(wxDC& dc);
- virtual void PaintFont(wxDC& dc);
+ wxChoice *familyChoice;
+ wxChoice *styleChoice;
+ wxChoice *weightChoice;
+ wxChoice *colourChoice;
+ wxCheckBox *underLineCheckBox;
+ wxChoice *pointSizeChoice;
- void OnChangeFont(wxCommandEvent& event);
+ wxFontPreviewer *m_previewer;
+ bool m_useEvents;
-DECLARE_EVENT_TABLE()
+ // static bool fontDialogCancelled;
+ DECLARE_EVENT_TABLE()
+ DECLARE_DYNAMIC_CLASS(wxGenericFontDialog)
};
-wxChar WXDLLEXPORT *wxFontFamilyIntToString(int family);
-wxChar WXDLLEXPORT *wxFontWeightIntToString(int weight);
-wxChar WXDLLEXPORT *wxFontStyleIntToString(int style);
-int WXDLLEXPORT wxFontFamilyStringToInt(wxChar *family);
-int WXDLLEXPORT wxFontWeightStringToInt(wxChar *weight);
-int WXDLLEXPORT wxFontStyleStringToInt(wxChar *style);
+WXDLLEXPORT const wxChar *wxFontFamilyIntToString(int family);
+WXDLLEXPORT const wxChar *wxFontWeightIntToString(int weight);
+WXDLLEXPORT const wxChar *wxFontStyleIntToString(int style);
+WXDLLEXPORT int wxFontFamilyStringToInt(wxChar *family);
+WXDLLEXPORT int wxFontWeightStringToInt(wxChar *weight);
+WXDLLEXPORT int wxFontStyleStringToInt(wxChar *style);
-#endif
+#endif // _WX_GENERIC_FONTDLGG_H