X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/bf31fa26c74df94d13f0b5ffc9842fe9bc3004be..cbffcf1117944db24ee8c196440702172dd0923f:/include/wx/fontdlg.h?ds=sidebyside diff --git a/include/wx/fontdlg.h b/include/wx/fontdlg.h index 681c6ab5c1..e0d5c8209f 100644 --- a/include/wx/fontdlg.h +++ b/include/wx/fontdlg.h @@ -1,21 +1,105 @@ +/////////////////////////////////////////////////////////////////////////////// +// Name: wx/fontdlg.h +// Purpose: common interface for different wxFontDialog classes +// Author: Vadim Zeitlin +// Modified by: +// Created: 12.05.02 +// RCS-ID: $Id$ +// Copyright: (c) 1997-2002 wxWidgets team +// Licence: wxWindows licence +/////////////////////////////////////////////////////////////////////////////// + #ifndef _WX_FONTDLG_H_BASE_ #define _WX_FONTDLG_H_BASE_ +#include "wx/defs.h" // for wxUSE_FONTDLG + #if wxUSE_FONTDLG -#if defined(__WXUNIVERSAL__) || defined(__WXMOTIF__) || defined(__WXMAC__) -# include "wx/generic/fontdlgg.h" -# define wxFontDialog wxGenericFontDialog -# define sm_classwxFontDialog sm_classwxGenericFontDialog +#include "wx/dialog.h" // the base class +#include "wx/cmndata.h" // wxFontData + +// ---------------------------------------------------------------------------- +// wxFontDialog interface +// ---------------------------------------------------------------------------- + +class WXDLLEXPORT wxFontDialogBase : public wxDialog +{ +public: + // create the font dialog + wxFontDialogBase() { } + wxFontDialogBase(wxWindow *parent) { m_parent = parent; } + wxFontDialogBase(wxWindow *parent, const wxFontData& data) + { m_parent = parent; InitFontData(&data); } + + bool Create(wxWindow *parent) + { return DoCreate(parent); } + bool Create(wxWindow *parent, const wxFontData& data) + { InitFontData(&data); return Create(parent); } + + virtual ~wxFontDialogBase(); + + // retrieve the font data + const wxFontData& GetFontData() const { return m_fontData; } + wxFontData& GetFontData() { return m_fontData; } + + // deprecated interface, for compatibility only, don't use + wxFontDialogBase(wxWindow *parent, const wxFontData *data) + { m_parent = parent; InitFontData(data); } + + bool Create(wxWindow *parent, const wxFontData *data) + { InitFontData(data); return Create(parent); } + +protected: + virtual bool DoCreate(wxWindow *parent) { m_parent = parent; return true; } + + void InitFontData(const wxFontData *data = NULL) + { if ( data ) m_fontData = *data; } + + wxFontData m_fontData; + + DECLARE_NO_COPY_CLASS(wxFontDialogBase) +}; + +// ---------------------------------------------------------------------------- +// platform-specific wxFontDialog implementation +// ---------------------------------------------------------------------------- + +#if defined( __WXMAC_OSX__ ) && ( MAC_OS_X_VERSION_MAX_ALLOWED >= MAC_OS_X_VERSION_10_2 ) +//set to 1 to use native mac font and color dialogs +#define USE_NATIVE_FONT_DIALOG_FOR_MACOSX 0 +#else +//not supported on these platforms, leave 0 +#define USE_NATIVE_FONT_DIALOG_FOR_MACOSX 0 +#endif + +#if defined(__WXUNIVERSAL__) || \ + defined(__WXMOTIF__) || \ + (defined(__WXMAC__) && !defined(__WXMAC_OSX__)) || \ + (defined(__WXMAC__) && !USE_NATIVE_FONT_DIALOG_FOR_MACOSX) || \ + (defined(__WXMAC_OSX__) && ( MAC_OS_X_VERSION_MAX_ALLOWED < MAC_OS_X_VERSION_10_2 ) ) || \ + defined(__WXCOCOA__) || \ + defined(__WXWINCE__) || \ + defined(__WXGPE__) + + #include "wx/generic/fontdlgg.h" + #define wxFontDialog wxGenericFontDialog #elif defined(__WXMSW__) -# include "wx/msw/fontdlg.h" + #include "wx/msw/fontdlg.h" #elif defined(__WXGTK__) -# include "wx/gtk/fontdlg.h" + #include "wx/gtk/fontdlg.h" #elif defined(__WXPM__) -# include "wx/os2/fontdlg.h" + #include "wx/os2/fontdlg.h" +#elif defined(__WXMAC__) + #include "wx/mac/fontdlg.h" #endif -// get the colour from user and return it +// ---------------------------------------------------------------------------- +// global public functions +// ---------------------------------------------------------------------------- + +// get the font from user and return it, returns wxNullFont if the dialog was +// cancelled wxFont WXDLLEXPORT wxGetFontFromUser(wxWindow *parent = (wxWindow *)NULL, const wxFont& fontInit = wxNullFont);