From: Stefan Csomor Date: Fri, 30 Jun 2006 08:44:12 +0000 (+0000) Subject: fixing PPI bugs in printer dcs X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/db49000e6c3340297e14c8659612bbd5f9004bce?ds=inline fixing PPI bugs in printer dcs git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@39898 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/include/wx/mac/carbon/dcprint.h b/include/wx/mac/carbon/dcprint.h index b5641d8624..2cfdd1a814 100644 --- a/include/wx/mac/carbon/dcprint.h +++ b/include/wx/mac/carbon/dcprint.h @@ -32,6 +32,7 @@ class WXDLLEXPORT wxPrinterDC: public wxDC virtual void StartPage(void) ; virtual void EndPage(void) ; wxPrintData& GetPrintData() { return m_printData; } + virtual wxSize GetPPI() const; #if wxMAC_USE_CORE_GRAPHICS void MacSetCGContext( void * cg ) ; #endif diff --git a/src/mac/carbon/dcprint.cpp b/src/mac/carbon/dcprint.cpp index 2acdaf2199..cabdd0d9b1 100644 --- a/src/mac/carbon/dcprint.cpp +++ b/src/mac/carbon/dcprint.cpp @@ -39,8 +39,9 @@ public : virtual void EndDoc( wxPrinterDC* dc ) = 0; virtual void StartPage( wxPrinterDC* dc ) = 0; virtual void EndPage( wxPrinterDC* dc ) = 0; - virtual wxCoord GetMaxX() const = 0 ; - virtual wxCoord GetMaxY() const = 0 ; + virtual void GetSize( int *w , int *h) const = 0 ; + virtual wxSize GetPPI() const = 0 ; + // returns 0 in case of no Error, otherwise platform specific error codes virtual wxUint32 GetStatus() const = 0 ; bool Ok() { return GetStatus() == 0 ; } @@ -57,13 +58,14 @@ public : virtual void EndDoc( wxPrinterDC* dc ) ; virtual void StartPage( wxPrinterDC* dc ) ; virtual void EndPage( wxPrinterDC* dc ) ; - virtual wxCoord GetMaxX() const { return m_maxX ; } - virtual wxCoord GetMaxY() const { return m_maxY ; } virtual wxUint32 GetStatus() const { return m_err ; } + virtual void GetSize( int *w , int *h) const ; + virtual wxSize GetPPI() const ; private : GrafPtr m_macPrintFormerPort ; wxCoord m_maxX ; wxCoord m_maxY ; + wxSize m_ppi ; OSStatus m_err ; } ; @@ -81,6 +83,10 @@ wxMacCarbonPrinterDC::wxMacCarbonPrinterDC( wxPrintData* data ) m_maxX = wxCoord(rPage.right - rPage.left) ; m_maxY = wxCoord(rPage.bottom - rPage.top); + + PMResolution res; + m_err = PMGetResolution((PMPageFormat) (native->m_macPageFormat), &res); + m_ppi = wxSize(int(res.hRes), int(res.vRes)); } wxMacCarbonPrinterDC::~wxMacCarbonPrinterDC() @@ -119,10 +125,14 @@ bool wxMacCarbonPrinterDC::StartDoc( wxPrinterDC* dc , const wxString& WXUNUSED PMRect rPage; m_err = PMGetAdjustedPageRect(native->m_macPageFormat, &rPage); if ( m_err != noErr ) - return false; + return; + + m_maxX = wxCoord(rPage.right - rPage.left) ; + m_maxY = wxCoord(rPage.bottom - rPage.top); - m_maxX = (wxCoord)(rPage.right - rPage.left); - m_maxY = (wxCoord)(rPage.bottom - rPage.top); + PMResolution res; + m_err = PMGetResolution((PMPageFormat) (native->m_macPageFormat), &res); + m_ppi = wxSize(int(res.hRes), int(res.vRes)); return true ; } @@ -206,6 +216,23 @@ void wxMacCarbonPrinterDC::EndPage( wxPrinterDC* dc ) } } +void wxMacCarbonPrinterDC::GetSize( int *w , int *h) const +{ + if ( w ) + *w = m_maxX ; + if ( h ) + *h = m_maxY ; +} + +wxSize wxMacCarbonPrinterDC::GetPPI() const +{ + return m_ppi ; +}; + +// +// +// + wxPrinterDC::wxPrinterDC(const wxPrintData& printdata) { m_ok = false ; @@ -222,6 +249,12 @@ wxPrinterDC::wxPrinterDC(const wxPrintData& printdata) wxMessageDialog dialog( NULL , message , wxEmptyString, wxICON_HAND | wxOK) ; dialog.ShowModal(); } + else + { + wxSize sz = GetPPI(); + m_mm_to_pix_x = mm2inches * sz.x; + m_mm_to_pix_y = mm2inches * sz.y; + } #if wxMAC_USE_CORE_GRAPHICS // the cgContext will only be handed over page by page m_graphicContext = new wxMacCGContext() ; @@ -229,6 +262,11 @@ wxPrinterDC::wxPrinterDC(const wxPrintData& printdata) } } +wxSize wxPrinterDC::GetPPI() const +{ + return m_nativePrinterDC->GetPPI() ; +} + wxPrinterDC::~wxPrinterDC(void) { #if wxMAC_USE_CORE_GRAPHICS @@ -324,11 +362,7 @@ void wxPrinterDC::EndPage(void) void wxPrinterDC::DoGetSize(int *width, int *height) const { wxCHECK_RET( m_ok , _T("GetSize() doesn't work without a valid wxPrinterDC") ); - - if ( width ) - * width = m_nativePrinterDC->GetMaxX() ; - if ( height ) - * height = m_nativePrinterDC->GetMaxY() ; + m_nativePrinterDC->GetSize(width, height ) ; } #endif