X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/7bcb11d30764df47144189e164f53d8171ed4a63..81b6ccf12026b9e5447c1a8725c1bca3bfd14150:/include/wx/cmndata.h?ds=inline diff --git a/include/wx/cmndata.h b/include/wx/cmndata.h index 9a1c0c5da9..d2d1a2a4b2 100644 --- a/include/wx/cmndata.h +++ b/include/wx/cmndata.h @@ -6,7 +6,7 @@ // Created: 01/02/97 // RCS-ID: $Id$ // Copyright: (c) -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifndef _WX_CMNDATA_H_BASE_ @@ -16,10 +16,12 @@ #pragma interface "cmndata.h" #endif +#include "wx/window.h" #include "wx/font.h" #include "wx/colour.h" +#include "wx/gdicmn.h" -#if (defined(__WXMOTIF__) || defined(__WXGTK__)) && wxUSE_POSTSCRIPT +#if (defined(__WXMOTIF__) || defined(__WXX11__) || defined(__WXGTK__) || defined(__WXPM__) || defined(__WXMAC__)) && wxUSE_POSTSCRIPT class WXDLLEXPORT wxPrintSetupData; #endif @@ -30,16 +32,17 @@ public: wxColourData(); wxColourData(const wxColourData& data); ~wxColourData(); - - inline void SetChooseFull(bool flag) { chooseFull = flag; } - inline bool GetChooseFull() const { return chooseFull; } - inline void SetColour(wxColour& colour) { dataColour = colour; } - inline wxColour &GetColour() { return dataColour; } + + void SetChooseFull(bool flag) { chooseFull = flag; } + bool GetChooseFull() const { return chooseFull; } + void SetColour(const wxColour& colour) { dataColour = colour; } + const wxColour& GetColour() const { return dataColour; } + wxColour& GetColour() { return dataColour; } // Array of 16 custom colours - void SetCustomColour(int i, wxColour& colour); + void SetCustomColour(int i, const wxColour& colour); wxColour GetCustomColour(int i); - + void operator=(const wxColourData& data); public: @@ -53,30 +56,56 @@ class WXDLLEXPORT wxFontData: public wxObject DECLARE_DYNAMIC_CLASS(wxFontData) public: wxFontData(); - wxFontData(const wxFontData& fontData); ~wxFontData(); - inline void SetAllowSymbols(bool flag) { allowSymbols = flag; } - inline bool GetAllowSymbols() const { return allowSymbols; } - - inline void SetColour(const wxColour& colour) { fontColour = colour; } - inline wxColour &GetColour() { return fontColour; } - - inline void SetShowHelp(bool flag) { showHelp = flag; } - inline bool GetShowHelp() const { return showHelp; } - - inline void EnableEffects(bool flag) { enableEffects = flag; } - inline bool GetEnableEffects() const { return enableEffects; } - - inline void SetInitialFont(const wxFont& font) { initialFont = font; } - inline wxFont GetInitialFont() const { return initialFont; } - - inline void SetChosenFont(const wxFont& font) { chosenFont = font; } - inline wxFont GetChosenFont() const { return chosenFont; } - - inline void SetRange(int minRange, int maxRange) { minSize = minRange; maxSize = maxRange; } - - void operator=(const wxFontData& data); + wxFontData(const wxFontData& data) + : wxObject() + , fontColour(data.fontColour) + , showHelp(data.showHelp) + , allowSymbols(data.allowSymbols) + , enableEffects(data.enableEffects) + , initialFont(data.initialFont) + , chosenFont(data.chosenFont) + , minSize(data.minSize) + , maxSize(data.maxSize) + , m_encoding(data.m_encoding) + , m_encodingInfo(data.m_encodingInfo) + { + } + + wxFontData& operator=(const wxFontData& data) + { + (*this) = data; + return *this; + } + + void SetAllowSymbols(bool flag) { allowSymbols = flag; } + bool GetAllowSymbols() const { return allowSymbols; } + + void SetColour(const wxColour& colour) { fontColour = colour; } + wxColour &GetColour() { return fontColour; } + + void SetShowHelp(bool flag) { showHelp = flag; } + bool GetShowHelp() const { return showHelp; } + + void EnableEffects(bool flag) { enableEffects = flag; } + bool GetEnableEffects() const { return enableEffects; } + + void SetInitialFont(const wxFont& font) { initialFont = font; } + wxFont GetInitialFont() const { return initialFont; } + + void SetChosenFont(const wxFont& font) { chosenFont = font; } + wxFont GetChosenFont() const { return chosenFont; } + + void SetRange(int minRange, int maxRange) { minSize = minRange; maxSize = maxRange; } + + // encoding info is split into 2 parts: the logical wxWin encoding + // (wxFontEncoding) and a structure containing the native parameters for + // it (wxNativeEncodingInfo) + wxFontEncoding GetEncoding() const { return m_encoding; } + void SetEncoding(wxFontEncoding encoding) { m_encoding = encoding; } + + wxNativeEncodingInfo& EncodingInfo() { return m_encodingInfo; } public: wxColour fontColour; @@ -87,8 +116,13 @@ public: wxFont chosenFont; int minSize; int maxSize; + +private: + wxFontEncoding m_encoding; + wxNativeEncodingInfo m_encodingInfo; }; +#if wxUSE_PRINTING_ARCHITECTURE /* * wxPrintData * Encapsulates printer information (not printer dialog information) @@ -97,77 +131,89 @@ public: class WXDLLEXPORT wxPrintData: public wxObject { DECLARE_DYNAMIC_CLASS(wxPrintData) - + wxPrintData(); wxPrintData(const wxPrintData& printData); ~wxPrintData(); - - inline int GetNoCopies() const { return m_printNoCopies; }; - inline bool GetCollate() const { return m_printCollate; }; - inline int GetOrientation() const { return m_printOrientation; }; - - inline const wxString& GetPrinterName() const { return m_printerName; } - inline bool GetColour() const { return m_colour; } - inline wxDuplexMode GetDuplex() const { return m_duplexMode; } - inline wxPaperSize GetPaperId() const { return m_paperId; } - inline const wxSize& GetPaperSize() const { return m_paperSize; } // Not used yet: confusable with paper size + + int GetNoCopies() const { return m_printNoCopies; }; + bool GetCollate() const { return m_printCollate; }; + int GetOrientation() const { return m_printOrientation; }; + + // Is this data OK for showing the print dialog? + bool Ok() const ; + + const wxString& GetPrinterName() const { return m_printerName; } + bool GetColour() const { return m_colour; } + wxDuplexMode GetDuplex() const { return m_duplexMode; } + wxPaperSize GetPaperId() const { return m_paperId; } + const wxSize& GetPaperSize() const { return m_paperSize; } // Not used yet: confusable with paper size // in wxPageSetupDialogData - inline wxPrintQuality GetQuality() const { return m_printQuality; } + wxPrintQuality GetQuality() const { return m_printQuality; } - inline void SetNoCopies(int v) { m_printNoCopies = v; }; - inline void SetCollate(bool flag) { m_printCollate = flag; }; - inline void SetOrientation(int orient) { m_printOrientation = orient; }; + void SetNoCopies(int v) { m_printNoCopies = v; }; + void SetCollate(bool flag) { m_printCollate = flag; }; + void SetOrientation(int orient) { m_printOrientation = orient; }; - inline void SetPrinterName(const wxString& name) { m_printerName = name; } - inline void SetColour(bool colour) { m_colour = colour; } - inline void SetDuplex(wxDuplexMode duplex) { m_duplexMode = duplex; } - inline void SetPaperId(wxPaperSize sizeId) { m_paperId = sizeId; } - inline void SetPaperSize(const wxSize& sz) { m_paperSize = sz; } - inline void SetQuality(wxPrintQuality quality) { m_printQuality = quality; } + void SetPrinterName(const wxString& name) { m_printerName = name; } + void SetColour(bool colour) { m_colour = colour; } + void SetDuplex(wxDuplexMode duplex) { m_duplexMode = duplex; } + void SetPaperId(wxPaperSize sizeId) { m_paperId = sizeId; } + void SetPaperSize(const wxSize& sz) { m_paperSize = sz; } + void SetQuality(wxPrintQuality quality) { m_printQuality = quality; } // PostScript-specific data - inline const wxString& GetPrinterCommand() const { return m_printerCommand; } - inline const wxString& GetPrinterOptions() const { return m_printerOptions; } - inline const wxString& GetPreviewCommand() const { return m_previewCommand; } - inline const wxString& GetFilename() const { return m_filename; } - inline const wxString& GetFontMetricPath() const { return m_afmPath; } - inline double GetPrinterScaleX() const { return m_printerScaleX; } - inline double GetPrinterScaleY() const { return m_printerScaleY; } - inline long GetPrinterTranslateX() const { return m_printerTranslateX; } - inline long GetPrinterTranslateY() const { return m_printerTranslateY; } - inline wxPrintMode GetPrintMode() const { return m_printMode; } - - inline void SetPrinterCommand(const wxString& command) { m_printerCommand = command; } - inline void SetPrinterOptions(const wxString& options) { m_printerOptions = options; } - inline void SetPreviewCommand(const wxString& command) { m_previewCommand = command; } - inline void SetFilename(const wxString& filename) { m_filename = filename; } - inline void SetFontMetricPath(const wxString& path) { m_afmPath = path; } - inline void SetPrinterScaleX(double x) { m_printerScaleX = x; } - inline void SetPrinterScaleY(double y) { m_printerScaleY = y; } - inline void SetPrinterScaling(double x, double y) { m_printerScaleX = x; m_printerScaleY = y; } - inline void SetPrinterTranslateX(long x) { m_printerTranslateX = x; } - inline void SetPrinterTranslateY(long y) { m_printerTranslateY = y; } - inline void SetPrinterTranslation(long x, long y) { m_printerTranslateX = x; m_printerTranslateY = y; } - inline void SetPrintMode(wxPrintMode printMode) { m_printMode = printMode; } + const wxString& GetPrinterCommand() const { return m_printerCommand; } + const wxString& GetPrinterOptions() const { return m_printerOptions; } + const wxString& GetPreviewCommand() const { return m_previewCommand; } + const wxString& GetFilename() const { return m_filename; } + const wxString& GetFontMetricPath() const { return m_afmPath; } + double GetPrinterScaleX() const { return m_printerScaleX; } + double GetPrinterScaleY() const { return m_printerScaleY; } + long GetPrinterTranslateX() const { return m_printerTranslateX; } + long GetPrinterTranslateY() const { return m_printerTranslateY; } + wxPrintMode GetPrintMode() const { return m_printMode; } + + void SetPrinterCommand(const wxString& command) { m_printerCommand = command; } + void SetPrinterOptions(const wxString& options) { m_printerOptions = options; } + void SetPreviewCommand(const wxString& command) { m_previewCommand = command; } + void SetFilename(const wxString& filename) { m_filename = filename; } + void SetFontMetricPath(const wxString& path) { m_afmPath = path; } + void SetPrinterScaleX(double x) { m_printerScaleX = x; } + void SetPrinterScaleY(double y) { m_printerScaleY = y; } + void SetPrinterScaling(double x, double y) { m_printerScaleX = x; m_printerScaleY = y; } + void SetPrinterTranslateX(long x) { m_printerTranslateX = x; } + void SetPrinterTranslateY(long y) { m_printerTranslateY = y; } + void SetPrinterTranslation(long x, long y) { m_printerTranslateX = x; m_printerTranslateY = y; } + void SetPrintMode(wxPrintMode printMode) { m_printMode = printMode; } void operator=(const wxPrintData& data); // For compatibility -#if (defined(__WXMOTIF__) || defined(__WXGTK__)) && wxUSE_POSTSCRIPT +#if (defined(__WXMOTIF__) || defined(__WXX11__) || defined(__WXGTK__) || defined(__WXPM__) || defined(__WXMAC__)) && wxUSE_POSTSCRIPT void operator=(const wxPrintSetupData& setupData); #endif - -#ifdef __WXMSW__ + +#if defined(__WXMSW__) // Convert to/from the DEVMODE structure void ConvertToNative(); void ConvertFromNative(); - inline void* GetNativeData() const { return m_devMode; } - inline void SetNativeData(void* data) { m_devMode = data; } + void* GetNativeData() const { return m_devMode; } + void SetNativeData(void* data) { m_devMode = data; } + void* GetNativeDataDevNames() const { return m_devNames; } + void SetNativeDataDevNames(void* data) { m_devNames = data; } +#elif defined(__WXMAC__) + void ConvertToNative(); + void ConvertFromNative(); #endif - + public: -#ifdef __WXMSW__ +#if defined(__WXMSW__) void* m_devMode; + void* m_devNames; +#elif defined(__WXMAC__) + void* m_macPageFormat ; + void* m_macPrintSettings ; #endif private: @@ -207,56 +253,64 @@ private: class WXDLLEXPORT wxPrintDialogData: public wxObject { DECLARE_DYNAMIC_CLASS(wxPrintDialogData) - + wxPrintDialogData(); wxPrintDialogData(const wxPrintDialogData& dialogData); wxPrintDialogData(const wxPrintData& printData); ~wxPrintDialogData(); - - inline int GetFromPage() const { return m_printFromPage; }; - inline int GetToPage() const { return m_printToPage; }; - inline int GetMinPage() const { return m_printMinPage; }; - inline int GetMaxPage() const { return m_printMaxPage; }; - inline int GetNoCopies() const { return m_printNoCopies; }; - inline bool GetAllPages() const { return m_printAllPages; }; - inline bool GetCollate() const { return m_printCollate; }; - inline bool GetPrintToFile() const { return m_printToFile; }; - inline bool GetSetupDialog() const { return m_printSetupDialog; }; - - inline void SetFromPage(int v) { m_printFromPage = v; }; - inline void SetToPage(int v) { m_printToPage = v; }; - inline void SetMinPage(int v) { m_printMinPage = v; }; - inline void SetMaxPage(int v) { m_printMaxPage = v; }; - inline void SetNoCopies(int v) { m_printNoCopies = v; }; - inline void SetAllPages(bool flag) { m_printAllPages = flag; }; - inline void SetCollate(bool flag) { m_printCollate = flag; }; - inline void SetPrintToFile(bool flag) { m_printToFile = flag; }; - inline void SetSetupDialog(bool flag) { m_printSetupDialog = flag; }; - - inline void EnablePrintToFile(bool flag) { m_printEnablePrintToFile = flag; }; - inline void EnableSelection(bool flag) { m_printEnableSelection = flag; }; - inline void EnablePageNumbers(bool flag) { m_printEnablePageNumbers = flag; }; - inline void EnableHelp(bool flag) { m_printEnableHelp = flag; }; - - inline bool GetEnablePrintToFile() const { return m_printEnablePrintToFile; }; - inline bool GetEnableSelection() const { return m_printEnableSelection; }; - inline bool GetEnablePageNumbers() const { return m_printEnablePageNumbers; }; - inline bool GetEnableHelp() const { return m_printEnableHelp; }; - - inline wxPrintData& GetPrintData() { return m_printData; } - inline void SetPrintData(const wxPrintData& printData) { m_printData = printData; } + + int GetFromPage() const { return m_printFromPage; }; + int GetToPage() const { return m_printToPage; }; + int GetMinPage() const { return m_printMinPage; }; + int GetMaxPage() const { return m_printMaxPage; }; + int GetNoCopies() const { return m_printNoCopies; }; + bool GetAllPages() const { return m_printAllPages; }; + bool GetSelection() const { return m_printSelection; }; + bool GetCollate() const { return m_printCollate; }; + bool GetPrintToFile() const { return m_printToFile; }; + bool GetSetupDialog() const { return m_printSetupDialog; }; + + void SetFromPage(int v) { m_printFromPage = v; }; + void SetToPage(int v) { m_printToPage = v; }; + void SetMinPage(int v) { m_printMinPage = v; }; + void SetMaxPage(int v) { m_printMaxPage = v; }; + void SetNoCopies(int v) { m_printNoCopies = v; }; + void SetAllPages(bool flag) { m_printAllPages = flag; }; + void SetSelection(bool flag) { m_printSelection = flag; }; + void SetCollate(bool flag) { m_printCollate = flag; }; + void SetPrintToFile(bool flag) { m_printToFile = flag; }; + void SetSetupDialog(bool flag) { m_printSetupDialog = flag; }; + + void EnablePrintToFile(bool flag) { m_printEnablePrintToFile = flag; }; + void EnableSelection(bool flag) { m_printEnableSelection = flag; }; + void EnablePageNumbers(bool flag) { m_printEnablePageNumbers = flag; }; + void EnableHelp(bool flag) { m_printEnableHelp = flag; }; + + bool GetEnablePrintToFile() const { return m_printEnablePrintToFile; }; + bool GetEnableSelection() const { return m_printEnableSelection; }; + bool GetEnablePageNumbers() const { return m_printEnablePageNumbers; }; + bool GetEnableHelp() const { return m_printEnableHelp; }; + + // Is this data OK for showing the print dialog? + bool Ok() const { return m_printData.Ok() ; } + + wxPrintData& GetPrintData() { return m_printData; } + void SetPrintData(const wxPrintData& printData) { m_printData = printData; } void operator=(const wxPrintDialogData& data); void operator=(const wxPrintData& data); // Sets internal m_printData member - + #ifdef __WXMSW__ // Convert to/from the PRINTDLG structure void ConvertToNative(); void ConvertFromNative(); void SetOwnerWindow(wxWindow* win); - inline void* GetNativeData() const { return m_printDlgData; } + void* GetNativeData() const { return m_printDlgData; } +#elif defined(__WXMAC__) + void ConvertToNative(); + void ConvertFromNative(); #endif - + #ifdef __WXMSW__ void* m_printDlgData; #endif @@ -271,6 +325,7 @@ private: bool m_printAllPages; bool m_printCollate; bool m_printToFile; + bool m_printSelection; bool m_printEnableSelection; bool m_printEnablePageNumbers; bool m_printEnableHelp; @@ -290,68 +345,76 @@ private: class WXDLLEXPORT wxPageSetupDialogData: public wxObject { DECLARE_DYNAMIC_CLASS(wxPageSetupDialogData) - + public: wxPageSetupDialogData(); wxPageSetupDialogData(const wxPageSetupDialogData& dialogData); wxPageSetupDialogData(const wxPrintData& printData); ~wxPageSetupDialogData(); - inline wxSize GetPaperSize() const { return m_paperSize; }; - inline wxPaperSize GetPaperId() const { return m_printData.GetPaperId(); }; - inline wxPoint GetMinMarginTopLeft() const { return m_minMarginTopLeft; }; - inline wxPoint GetMinMarginBottomRight() const { return m_minMarginBottomRight; }; - inline wxPoint GetMarginTopLeft() const { return m_marginTopLeft; }; - inline wxPoint GetMarginBottomRight() const { return m_marginBottomRight; }; - - inline bool GetDefaultMinMargins() const { return m_defaultMinMargins; }; - inline bool GetEnableMargins() const { return m_enableMargins; }; - inline bool GetEnableOrientation() const { return m_enableOrientation; }; - inline bool GetEnablePaper() const { return m_enablePaper; }; - inline bool GetEnablePrinter() const { return m_enablePrinter; }; - inline bool GetDefaultInfo() const { return m_getDefaultInfo; }; - inline bool GetEnableHelp() const { return m_enableHelp; }; + wxSize GetPaperSize() const { return m_paperSize; }; + wxPaperSize GetPaperId() const { return m_printData.GetPaperId(); }; + wxPoint GetMinMarginTopLeft() const { return m_minMarginTopLeft; }; + wxPoint GetMinMarginBottomRight() const { return m_minMarginBottomRight; }; + wxPoint GetMarginTopLeft() const { return m_marginTopLeft; }; + wxPoint GetMarginBottomRight() const { return m_marginBottomRight; }; + + bool GetDefaultMinMargins() const { return m_defaultMinMargins; }; + bool GetEnableMargins() const { return m_enableMargins; }; + bool GetEnableOrientation() const { return m_enableOrientation; }; + bool GetEnablePaper() const { return m_enablePaper; }; + bool GetEnablePrinter() const { return m_enablePrinter; }; + bool GetDefaultInfo() const { return m_getDefaultInfo; }; + bool GetEnableHelp() const { return m_enableHelp; }; + + // Is this data OK for showing the page setup dialog? + bool Ok() const { return m_printData.Ok() ; } // If a corresponding paper type is found in the paper database, will set the m_printData // paper size id member as well. void SetPaperSize(const wxSize& sz); + void SetPaperId(wxPaperSize id) { m_printData.SetPaperId(id); }; + // Sets the wxPrintData id, plus the paper width/height if found in the paper database. void SetPaperSize(wxPaperSize id); - inline void SetMinMarginTopLeft(const wxPoint& pt) { m_minMarginTopLeft = pt; }; - inline void SetMinMarginBottomRight(const wxPoint& pt) { m_minMarginBottomRight = pt; }; - inline void SetMarginTopLeft(const wxPoint& pt) { m_marginTopLeft = pt; }; - inline void SetMarginBottomRight(const wxPoint& pt) { m_marginBottomRight = pt; }; - inline void SetDefaultMinMargins(bool flag) { m_defaultMinMargins = flag; }; - inline void SetDefaultInfo(bool flag) { m_getDefaultInfo = flag; }; - - inline void EnableMargins(bool flag) { m_enableMargins = flag; }; - inline void EnableOrientation(bool flag) { m_enableOrientation = flag; }; - inline void EnablePaper(bool flag) { m_enablePaper = flag; }; - inline void EnablePrinter(bool flag) { m_enablePrinter = flag; }; - inline void EnableHelp(bool flag) { m_enableHelp = flag; }; - + void SetMinMarginTopLeft(const wxPoint& pt) { m_minMarginTopLeft = pt; }; + void SetMinMarginBottomRight(const wxPoint& pt) { m_minMarginBottomRight = pt; }; + void SetMarginTopLeft(const wxPoint& pt) { m_marginTopLeft = pt; }; + void SetMarginBottomRight(const wxPoint& pt) { m_marginBottomRight = pt; }; + void SetDefaultMinMargins(bool flag) { m_defaultMinMargins = flag; }; + void SetDefaultInfo(bool flag) { m_getDefaultInfo = flag; }; + + void EnableMargins(bool flag) { m_enableMargins = flag; }; + void EnableOrientation(bool flag) { m_enableOrientation = flag; }; + void EnablePaper(bool flag) { m_enablePaper = flag; }; + void EnablePrinter(bool flag) { m_enablePrinter = flag; }; + void EnableHelp(bool flag) { m_enableHelp = flag; }; + #if defined(__WIN95__) // Convert to/from the PAGESETUPDLG structure void ConvertToNative(); void ConvertFromNative(); void SetOwnerWindow(wxWindow* win); - inline void* GetNativeData() const { return m_pageSetupData; } + void* GetNativeData() const { return m_pageSetupData; } +#elif defined(__WXMAC__) + void ConvertToNative(); + void ConvertFromNative(); #endif // Use paper size defined in this object to set the wxPrintData // paper id void CalculateIdFromPaperSize(); - + // Use paper id in wxPrintData to set this object's paper size void CalculatePaperSizeFromId(); - - void operator=(const wxPageSetupData& data); - void operator=(const wxPrintData& data); - inline wxPrintData& GetPrintData() { return m_printData; } - inline void SetPrintData(const wxPrintData& printData) { m_printData = printData; } + wxPageSetupDialogData& operator=(const wxPageSetupData& data); + wxPageSetupDialogData& operator=(const wxPrintData& data); + + wxPrintData& GetPrintData() { return m_printData; } + void SetPrintData(const wxPrintData& printData) { m_printData = printData; } #if defined(__WIN95__) void* m_pageSetupData; @@ -377,5 +440,7 @@ private: wxPrintData m_printData; }; +#endif // wxUSE_PRINTING_ARCHITECTURE + #endif // _WX_CMNDATA_H_BASE_