splitting methods
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@64344 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -131,7 +131,7 @@ void wxOSXPrintData::UpdateToPMState()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
void wxOSXPrintData::TransferPrinterNameFrom( const wxPrintData &data )
|
||||||
{
|
{
|
||||||
CFArrayRef printerList;
|
CFArrayRef printerList;
|
||||||
CFIndex index, count;
|
CFIndex index, count;
|
||||||
@@ -158,7 +158,10 @@ bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
|||||||
PMSessionSetCurrentPMPrinter(m_macPrintSession, printer);
|
PMSessionSetCurrentPMPrinter(m_macPrintSession, printer);
|
||||||
CFRelease(printerList);
|
CFRelease(printerList);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxOSXPrintData::TransferPaperInfoFrom( const wxPrintData &data )
|
||||||
|
{
|
||||||
PMPrinter printer;
|
PMPrinter printer;
|
||||||
PMSessionGetCurrentPrinter(m_macPrintSession, &printer);
|
PMSessionGetCurrentPrinter(m_macPrintSession, &printer);
|
||||||
|
|
||||||
@@ -220,14 +223,14 @@ bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
|||||||
if ( PMPaperCreateCustom != NULL)
|
if ( PMPaperCreateCustom != NULL)
|
||||||
{
|
{
|
||||||
PMPaperCreateCustom(printer, wxCFStringRef( id, wxFont::GetDefaultEncoding() ), wxCFStringRef( name, wxFont::GetDefaultEncoding() ),
|
PMPaperCreateCustom(printer, wxCFStringRef( id, wxFont::GetDefaultEncoding() ), wxCFStringRef( name, wxFont::GetDefaultEncoding() ),
|
||||||
papersize.x, papersize.y, &margins, &paper);
|
papersize.x, papersize.y, &margins, &paper);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#if MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_5
|
#if MAC_OS_X_VERSION_MIN_REQUIRED < MAC_OS_X_VERSION_10_5
|
||||||
if ( paper == kPMNoData )
|
if ( paper == kPMNoData )
|
||||||
{
|
{
|
||||||
PMPaperCreate(printer, wxCFStringRef( id, wxFont::GetDefaultEncoding() ), wxCFStringRef( name, wxFont::GetDefaultEncoding() ),
|
PMPaperCreate(printer, wxCFStringRef( id, wxFont::GetDefaultEncoding() ), wxCFStringRef( name, wxFont::GetDefaultEncoding() ),
|
||||||
papersize.x, papersize.y, &margins, &paper);
|
papersize.x, papersize.y, &margins, &paper);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
@@ -248,10 +251,10 @@ bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
|||||||
PMSetCollate(m_macPrintSettings, data.GetCollate());
|
PMSetCollate(m_macPrintSettings, data.GetCollate());
|
||||||
if ( data.IsOrientationReversed() )
|
if ( data.IsOrientationReversed() )
|
||||||
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
||||||
kPMReverseLandscape : kPMReversePortrait , false ) ;
|
kPMReverseLandscape : kPMReversePortrait , false ) ;
|
||||||
else
|
else
|
||||||
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
||||||
kPMLandscape : kPMPortrait , false ) ;
|
kPMLandscape : kPMPortrait , false ) ;
|
||||||
|
|
||||||
PMDuplexMode mode = 0 ;
|
PMDuplexMode mode = 0 ;
|
||||||
switch( data.GetDuplex() )
|
switch( data.GetDuplex() )
|
||||||
@@ -272,10 +275,16 @@ bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
|||||||
|
|
||||||
if ( data.IsOrientationReversed() )
|
if ( data.IsOrientationReversed() )
|
||||||
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
||||||
kPMReverseLandscape : kPMReversePortrait , false ) ;
|
kPMReverseLandscape : kPMReversePortrait , false ) ;
|
||||||
else
|
else
|
||||||
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
PMSetOrientation( m_macPageFormat , ( data.GetOrientation() == wxLANDSCAPE ) ?
|
||||||
kPMLandscape : kPMPortrait , false ) ;
|
kPMLandscape : kPMPortrait , false ) ;
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxOSXPrintData::TransferResolutionFrom( const wxPrintData &data )
|
||||||
|
{
|
||||||
|
PMPrinter printer;
|
||||||
|
PMSessionGetCurrentPrinter(m_macPrintSession, &printer);
|
||||||
|
|
||||||
UInt32 resCount;
|
UInt32 resCount;
|
||||||
PMResolution *resolutions = GetSupportedResolutions(printer, &resCount);
|
PMResolution *resolutions = GetSupportedResolutions(printer, &resCount);
|
||||||
@@ -299,13 +308,22 @@ bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
|||||||
|
|
||||||
free(resolutions);
|
free(resolutions);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
||||||
|
{
|
||||||
|
TransferPrinterNameFrom(data);
|
||||||
|
TransferPaperInfoFrom(data);
|
||||||
|
TransferResolutionFrom(data);
|
||||||
|
|
||||||
// after setting the new resolution the format has to be updated, otherwise the page rect remains
|
// after setting the new resolution the format has to be updated, otherwise the page rect remains
|
||||||
// at the 'old' scaling
|
// at the 'old' scaling
|
||||||
|
|
||||||
PMSessionValidatePageFormat(m_macPrintSession,
|
PMSessionValidatePageFormat(m_macPrintSession,
|
||||||
m_macPageFormat, kPMDontWantBoolean);
|
m_macPageFormat, kPMDontWantBoolean);
|
||||||
PMSessionValidatePrintSettings(m_macPrintSession,
|
PMSessionValidatePrintSettings(m_macPrintSession,
|
||||||
m_macPrintSettings, kPMDontWantBoolean);
|
m_macPrintSettings, kPMDontWantBoolean);
|
||||||
|
|
||||||
#if wxOSX_USE_COCOA
|
#if wxOSX_USE_COCOA
|
||||||
UpdateFromPMState();
|
UpdateFromPMState();
|
||||||
#endif
|
#endif
|
||||||
@@ -313,12 +331,26 @@ bool wxOSXPrintData::TransferFrom( const wxPrintData &data )
|
|||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool wxOSXPrintData::TransferTo( wxPrintData &data )
|
void wxOSXPrintData::TransferPrinterNameTo( wxPrintData &data )
|
||||||
{
|
{
|
||||||
|
CFStringRef name;
|
||||||
|
PMPrinter printer ;
|
||||||
|
PMSessionGetCurrentPrinter( m_macPrintSession, &printer );
|
||||||
|
if (PMPrinterIsDefault(printer))
|
||||||
|
data.SetPrinterName(wxEmptyString);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
name = PMPrinterGetName(printer);
|
||||||
|
CFRetain(name);
|
||||||
|
data.SetPrinterName(wxCFStringRef(name).AsString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxOSXPrintData::TransferPaperInfoTo( wxPrintData &data )
|
||||||
|
{
|
||||||
|
PMPrinter printer ;
|
||||||
|
PMSessionGetCurrentPrinter( m_macPrintSession, &printer );
|
||||||
OSStatus err = noErr ;
|
OSStatus err = noErr ;
|
||||||
#if wxOSX_USE_COCOA
|
|
||||||
UpdateToPMState();
|
|
||||||
#endif
|
|
||||||
UInt32 copies ;
|
UInt32 copies ;
|
||||||
err = PMGetCopies( m_macPrintSettings , &copies ) ;
|
err = PMGetCopies( m_macPrintSettings , &copies ) ;
|
||||||
if ( err == noErr )
|
if ( err == noErr )
|
||||||
@@ -344,17 +376,6 @@ bool wxOSXPrintData::TransferTo( wxPrintData &data )
|
|||||||
if (PMGetCollate(m_macPrintSettings, &collate) == noErr)
|
if (PMGetCollate(m_macPrintSettings, &collate) == noErr)
|
||||||
data.SetCollate(collate);
|
data.SetCollate(collate);
|
||||||
|
|
||||||
CFStringRef name;
|
|
||||||
PMPrinter printer ;
|
|
||||||
PMSessionGetCurrentPrinter( m_macPrintSession, &printer );
|
|
||||||
if (PMPrinterIsDefault(printer))
|
|
||||||
data.SetPrinterName(wxEmptyString);
|
|
||||||
else
|
|
||||||
{
|
|
||||||
name = PMPrinterGetName(printer);
|
|
||||||
CFRetain(name);
|
|
||||||
data.SetPrinterName(wxCFStringRef(name).AsString());
|
|
||||||
}
|
|
||||||
|
|
||||||
PMDuplexMode mode = 0 ;
|
PMDuplexMode mode = 0 ;
|
||||||
PMGetDuplex( m_macPrintSettings, &mode ) ;
|
PMGetDuplex( m_macPrintSettings, &mode ) ;
|
||||||
@@ -372,6 +393,25 @@ bool wxOSXPrintData::TransferTo( wxPrintData &data )
|
|||||||
break ;
|
break ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
double height, width;
|
||||||
|
PMPaperGetHeight(m_macPaper, &height);
|
||||||
|
PMPaperGetWidth(m_macPaper, &width);
|
||||||
|
|
||||||
|
wxSize sz((int)(width * pt2mm + 0.5 ) ,
|
||||||
|
(int)(height * pt2mm + 0.5 ));
|
||||||
|
data.SetPaperSize(sz);
|
||||||
|
wxPaperSize id = wxThePrintPaperDatabase->GetSize(wxSize(sz.x* 10, sz.y * 10));
|
||||||
|
if (id != wxPAPER_NONE)
|
||||||
|
{
|
||||||
|
data.SetPaperId(id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxOSXPrintData::TransferResolutionTo( wxPrintData &data )
|
||||||
|
{
|
||||||
|
PMPrinter printer ;
|
||||||
|
PMSessionGetCurrentPrinter( m_macPrintSession, &printer );
|
||||||
|
|
||||||
/* assume high quality, will change below if we are able to */
|
/* assume high quality, will change below if we are able to */
|
||||||
data.SetQuality(wxPRINT_QUALITY_HIGH);
|
data.SetQuality(wxPRINT_QUALITY_HIGH);
|
||||||
|
|
||||||
@@ -406,19 +446,17 @@ bool wxOSXPrintData::TransferTo( wxPrintData &data )
|
|||||||
}
|
}
|
||||||
free(resolutions);
|
free(resolutions);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
double height, width;
|
bool wxOSXPrintData::TransferTo( wxPrintData &data )
|
||||||
PMPaperGetHeight(m_macPaper, &height);
|
{
|
||||||
PMPaperGetWidth(m_macPaper, &width);
|
#if wxOSX_USE_COCOA
|
||||||
|
UpdateToPMState();
|
||||||
|
#endif
|
||||||
|
|
||||||
wxSize sz((int)(width * pt2mm + 0.5 ) ,
|
TransferPrinterNameTo(data);
|
||||||
(int)(height * pt2mm + 0.5 ));
|
TransferPaperInfoTo(data);
|
||||||
data.SetPaperSize(sz);
|
TransferResolutionTo(data);
|
||||||
wxPaperSize id = wxThePrintPaperDatabase->GetSize(wxSize(sz.x* 10, sz.y * 10));
|
|
||||||
if (id != wxPAPER_NONE)
|
|
||||||
{
|
|
||||||
data.SetPaperId(id);
|
|
||||||
}
|
|
||||||
return true ;
|
return true ;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user