}
wxColourData::wxColourData(const wxColourData& data)
- : wxObject()
+ : wxObject()
{
(*this) = data;
}
void wxColourData::SetCustomColour(int i, const wxColour& colour)
{
- wxCHECK_RET( (i >= 0 && i < 16), _T("custom colour index out of range") );
+ wxCHECK_RET( i >= 0 && i < NUM_CUSTOM, _T("custom colour index out of range") );
m_custColours[i] = colour;
}
wxColour wxColourData::GetCustomColour(int i)
{
- wxCHECK_MSG( (i >= 0 && i < 16), wxColour(0,0,0),
+ wxCHECK_MSG( i >= 0 && i < NUM_CUSTOM, wxColour(0,0,0),
_T("custom colour index out of range") );
return m_custColours[i];
}
-void wxColourData::operator=(const wxColourData& data)
+wxColourData& wxColourData::operator=(const wxColourData& data)
{
- int i;
- for (i = 0; i < 16; i++)
+ for ( int i = 0; i < NUM_CUSTOM; i++)
m_custColours[i] = data.m_custColours[i];
- m_dataColour = (wxColour&)data.m_dataColour;
+ m_dataColour = data.m_dataColour;
m_chooseFull = data.m_chooseFull;
+
+ return *this;
+}
+
+// ----------------------------------------------------------------------------
+// [de]serialization
+// ----------------------------------------------------------------------------
+
+// separator used between different fields
+static const char wxCOL_DATA_SEP = ',';
+
+wxString wxColourData::ToString() const
+{
+ wxString str(m_chooseFull ? '1' : '0');
+
+ for ( int i = 0; i < NUM_CUSTOM; i++ )
+ {
+ str += wxCOL_DATA_SEP;
+
+ const wxColour& clr = m_custColours[i];
+ if ( clr.IsOk() )
+ str += clr.GetAsString(wxC2S_HTML_SYNTAX);
+ }
+
+ return str;
+}
+
+bool wxColourData::FromString(const wxString& str)
+{
+ wxString token;
+ int n = -1; // index of the field, -1 corresponds to m_chooseFull
+ for ( wxString::const_iterator i = str.begin(); i != str.end(); ++i )
+ {
+ if ( *i == wxCOL_DATA_SEP )
+ {
+ if ( n == -1 )
+ {
+ if ( token == '0' )
+ m_chooseFull = false;
+ else if ( token == '1' )
+ m_chooseFull = true;
+ else // only '0' and '1' are used in ToString()
+ return false;
+ }
+ else // custom colour
+ {
+ if ( n == WXSIZEOF(m_custColours) )
+ return false; // too many custom colours
+
+ // empty strings are used by ToString() for colours not used
+ if ( token.empty() )
+ m_custColours[n] = wxNullColour;
+ else if ( !m_custColours[n].Set(token) )
+ return false; // invalid colour string
+ }
+
+ token.clear();
+ n++;
+ }
+ else // continuation of the current field
+ {
+ token += *i;
+ }
+ }
+
+ return true;
}
// ----------------------------------------------------------------------------
wxPrintData::wxPrintData()
{
m_bin = wxPRINTBIN_DEFAULT;
+ m_media = wxPRINTMEDIA_DEFAULT;
m_printMode = wxPRINT_MODE_PRINTER;
m_printOrientation = wxPORTRAIT;
+ m_printOrientationReversed = false;
m_printNoCopies = 1;
m_printCollate = false;
m_colour = true;
m_duplexMode = wxDUPLEX_SIMPLEX;
m_printQuality = wxPRINT_QUALITY_HIGH;
- m_paperId = wxPAPER_A4;
- m_paperSize = wxSize(210, 297);
+
+ // we intentionally don't initialize paper id and size at all, like this
+ // the default system settings will be used for them
+ m_paperId = wxPAPER_NONE;
+ m_paperSize = wxDefaultSize;
m_privData = NULL;
m_privDataLen = 0;
m_printNoCopies = data.m_printNoCopies;
m_printCollate = data.m_printCollate;
m_printOrientation = data.m_printOrientation;
+ m_printOrientationReversed = data.m_printOrientationReversed;
m_printerName = data.m_printerName;
m_colour = data.m_colour;
m_duplexMode = data.m_duplexMode;
m_paperId = data.m_paperId;
m_paperSize = data.m_paperSize;
m_bin = data.m_bin;
+ m_media = data.m_media;
m_printMode = data.m_printMode;
m_filename = data.m_filename;
}
// Is this data OK for showing the print dialog?
-bool wxPrintData::Ok() const
+bool wxPrintData::IsOk() const
{
m_nativeData->TransferFrom( *this );
return m_nativeData->Ok();
}
-// What should happen here? wxPostScriptPrintNativeData is not
-// defined unless all this is true on MSW.
-#if WXWIN_COMPATIBILITY_2_4 && wxUSE_PRINTING_ARCHITECTURE && (!defined(__WXMSW__) || wxUSE_POSTSCRIPT_ARCHITECTURE_IN_MSW)
-
-#include "wx/generic/prntdlgg.h"
-
-#if wxUSE_POSTSCRIPT
- #define WXUNUSED_WITHOUT_PS(name) name
-#else
- #define WXUNUSED_WITHOUT_PS(name) WXUNUSED(name)
-#endif
-
-wxString wxPrintData::GetPrinterCommand() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterCommand();
-#endif
- return wxEmptyString;
-}
-
-wxString wxPrintData::GetPrinterOptions() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterOptions();
-#endif
- return wxEmptyString;
-}
-
-wxString wxPrintData::GetPreviewCommand() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPreviewCommand();
-#endif
- return wxEmptyString;
-}
-
-wxString wxPrintData::GetFontMetricPath() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetFontMetricPath();
-#endif
- return wxEmptyString;
-}
-
-double wxPrintData::GetPrinterScaleX() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterScaleX();
-#endif
- return 1.0;
-}
-
-double wxPrintData::GetPrinterScaleY() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterScaleY();
-#endif
- return 1.0;
-}
-
-long wxPrintData::GetPrinterTranslateX() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterTranslateX();
-#endif
- return 0;
-}
-
-long wxPrintData::GetPrinterTranslateY() const
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- return ((wxPostScriptPrintNativeData*)m_nativeData)->GetPrinterTranslateY();
-#endif
- return 0;
-}
-
-void wxPrintData::SetPrinterCommand(const wxString& WXUNUSED_WITHOUT_PS(command))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterCommand( command );
-#endif
-}
-
-void wxPrintData::SetPrinterOptions(const wxString& WXUNUSED_WITHOUT_PS(options))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterOptions( options );
-#endif
-}
-
-void wxPrintData::SetPreviewCommand(const wxString& WXUNUSED_WITHOUT_PS(command))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPreviewCommand( command );
-#endif
-}
-
-void wxPrintData::SetFontMetricPath(const wxString& WXUNUSED_WITHOUT_PS(path))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetFontMetricPath( path );
-#endif
-}
-
-void wxPrintData::SetPrinterScaleX(double WXUNUSED_WITHOUT_PS(x))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterScaleX( x );
-#endif
-}
-
-void wxPrintData::SetPrinterScaleY(double WXUNUSED_WITHOUT_PS(y))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterScaleY( y );
-#endif
-}
-
-void wxPrintData::SetPrinterScaling(double WXUNUSED_WITHOUT_PS(x), double WXUNUSED_WITHOUT_PS(y))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterScaling( x, y );
-#endif
-}
-
-void wxPrintData::SetPrinterTranslateX(long WXUNUSED_WITHOUT_PS(x))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterTranslateX( x );
-#endif
-}
-
-void wxPrintData::SetPrinterTranslateY(long WXUNUSED_WITHOUT_PS(y))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterTranslateY( y );
-#endif
-}
-
-void wxPrintData::SetPrinterTranslation(long WXUNUSED_WITHOUT_PS(x), long WXUNUSED_WITHOUT_PS(y))
-{
-#if wxUSE_POSTSCRIPT
- if (m_nativeData && wxIsKindOf(m_nativeData,wxPostScriptPrintNativeData))
- ((wxPostScriptPrintNativeData*)m_nativeData)->SetPrinterTranslation( x, y );
-#endif
-}
-#endif
-
// ----------------------------------------------------------------------------
// Print dialog data
// ----------------------------------------------------------------------------
m_printEnablePrintToFile = ! factory->HasOwnPrintToFile();
m_printEnableHelp = false;
-#if WXWIN_COMPATIBILITY_2_4
- m_printSetupDialog = false;
-#endif
}
wxPrintDialogData::wxPrintDialogData(const wxPrintDialogData& dialogData)
m_printEnablePageNumbers = true;
m_printEnablePrintToFile = true;
m_printEnableHelp = false;
-#if WXWIN_COMPATIBILITY_2_4
- m_printSetupDialog = false;
-#endif
m_printData = printData;
}
m_printEnablePageNumbers = data.m_printEnablePageNumbers;
m_printEnableHelp = data.m_printEnableHelp;
m_printEnablePrintToFile = data.m_printEnablePrintToFile;
-#if WXWIN_COMPATIBILITY_2_4
- m_printSetupDialog = data.m_printSetupDialog;
-#endif
m_printData = data.m_printData;
}