X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0e320a79f187558effb04d92020b470372bbe456..6359fa0e03f9954d6ee5d52bbc6d663ccffda9fc:/src/os2/dcmemory.cpp diff --git a/src/os2/dcmemory.cpp b/src/os2/dcmemory.cpp index 7cbd330821..d303b5aa02 100644 --- a/src/os2/dcmemory.cpp +++ b/src/os2/dcmemory.cpp @@ -1,64 +1,214 @@ ///////////////////////////////////////////////////////////////////////////// // Name: dcmemory.cpp // Purpose: wxMemoryDC class -// Author: AUTHOR +// Author: David Webster // Modified by: -// Created: 01/02/97 +// Created: 10/14/99 // RCS-ID: $Id$ -// Copyright: (c) AUTHOR -// Licence: wxWindows licence +// Copyright: (c) David Webster +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ -#pragma implementation "dcmemory.h" +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + +#ifndef WX_PRECOMP +#include "wx/utils.h" #endif +#include "wx/os2/private.h" + #include "wx/dcmemory.h" -//----------------------------------------------------------------------------- -// wxMemoryDC -//----------------------------------------------------------------------------- +IMPLEMENT_DYNAMIC_CLASS(wxMemoryDC, wxDC) -IMPLEMENT_DYNAMIC_CLASS(wxMemoryDC,wxPaintDC) +///////////////////////////////////////////////////////////////////////////// +// Memory DC +///////////////////////////////////////////////////////////////////////////// wxMemoryDC::wxMemoryDC(void) { - m_ok = FALSE; -}; + ERRORID vError; + wxString sError; + HDC hDC; + HPS hPS; + DEVOPENSTRUC vDOP = {0L, "DISPLAY", NULL, 0L, 0L, 0L, 0L, 0L, 0L}; + SIZEL vSize = {0, 0}; -wxMemoryDC::wxMemoryDC( wxDC *WXUNUSED(dc) ) + // + // Create a memory device context + // + hDC = ::DevOpenDC(vHabmain, OD_MEMORY, "*", 5L, (PDEVOPENDATA)&vDOP, NULLHANDLE); + if (hDC != DEV_ERROR) + { + hPS = ::GpiCreatePS(vHabmain, hDC, &vSize, PU_PELS | GPIT_MICRO | GPIA_ASSOC); + if (hPS != GPI_ERROR) + { + m_hPS = hPS; + m_hDC = hDC; + m_ok = TRUE; + m_bOwnsDC = TRUE; + SetBrush(*wxWHITE_BRUSH); + SetPen(*wxBLACK_PEN); + if (!::GpiCreateLogColorTable( m_hPS + ,0L + ,LCOLF_CONSECRGB + ,0L + ,(LONG)wxTheColourDatabase->m_nSize + ,(PLONG)wxTheColourDatabase->m_palTable + )) + { + vError = ::WinGetLastError(vHabmain); + sError = wxPMErrorToStr(vError); + wxLogError("Unable to set current color table. Error: %s\n", sError); + } + // + // Set the color table to RGB mode + // + if (!::GpiCreateLogColorTable( m_hPS + ,0L + ,LCOLF_RGB + ,0L + ,0L + ,NULL + )) + { + vError = ::WinGetLastError(vHabmain); + sError = wxPMErrorToStr(vError); + wxLogError("Unable to set current color table. Error: %s\n", sError); + } + } + else + { + m_hPS = NULLHANDLE; + m_hDC = NULLHANDLE; + m_ok = FALSE; + m_bOwnsDC = FALSE; + } + } + else + { + m_hPS = NULLHANDLE; + m_hDC = NULLHANDLE; + m_ok = FALSE; + m_bOwnsDC = FALSE; + } +} // end of wxMemoryDC::wxMemoryDC + +wxMemoryDC::wxMemoryDC( + wxDC* pOldDC +) { - m_ok = FALSE; -}; + HDC hDC; + HPS hPS; + DEVOPENSTRUC vDOP = {0L, "DISPLAY", NULL, 0L, 0L, 0L, 0L, 0L, 0L}; + SIZEL vSize = {0, 0}; + + pOldDC->BeginDrawing(); + + // + // Create a memory device context + // + hDC = ::DevOpenDC(vHabmain, OD_MEMORY, "*", 5L, (PDEVOPENDATA)&vDOP, GetHdcOf(*pOldDC)); + if (hDC != DEV_ERROR) + { + hPS = ::GpiCreatePS(vHabmain, hDC, &vSize, PU_PELS | GPIT_MICRO | GPIA_ASSOC); + if (hPS != GPI_ERROR) + { + m_hPS = hPS; + m_hDC = hDC; + m_ok = TRUE; + m_bOwnsDC = TRUE; + pOldDC->EndDrawing(); + SetBrush(*wxWHITE_BRUSH); + SetPen(*wxBLACK_PEN); + } + else + { + pOldDC->EndDrawing(); + m_hPS = NULLHANDLE; + m_hDC = NULLHANDLE; + m_ok = FALSE; + m_bOwnsDC = FALSE; + } + } + else + { + pOldDC->EndDrawing(); + m_hPS = NULLHANDLE; + m_hDC = NULLHANDLE; + m_ok = FALSE; + m_bOwnsDC = FALSE; + } +} // end of wxMemoryDC::wxMemoryDC -wxMemoryDC::~wxMemoryDC(void) +wxMemoryDC::~wxMemoryDC() { -}; + m_vSelectedBitmap.SetSelectedInto(NULL); + if (m_hPS != NULLHANDLE) + ::GpiDestroyPS(m_hPS); + if (m_hDC != NULLHANDLE) + ::DevCloseDC(m_hDC); +} // end of wxMemoryDC::~wxMemoryDC -void wxMemoryDC::SelectObject( const wxBitmap& bitmap ) +void wxMemoryDC::SelectObject( + const wxBitmap& rBitmap +) { - m_selected = bitmap; - if (m_selected.Ok()) - { - } - else - { - m_ok = FALSE; - }; -}; - -void wxMemoryDC::GetSize( int *width, int *height ) const + // + // Select old bitmap out of the device context + // + if (m_hOldBitmap) + { + ::GpiSetBitmap(m_hPS, NULLHANDLE); + if (m_vSelectedBitmap.Ok()) + { + m_vSelectedBitmap.SetSelectedInto(NULL); + m_vSelectedBitmap = wxNullBitmap; + } + } + + // + // Check for whether the bitmap is already selected into a device context + // + wxCHECK_RET( !rBitmap.GetSelectedInto() || + (rBitmap.GetSelectedInto() == this), + wxT("Bitmap is selected in another wxMemoryDC, delete the first wxMemoryDC or use SelectObject(NULL)") ); + + m_vSelectedBitmap = rBitmap; + + WXHBITMAP hBmp = m_vSelectedBitmap.GetHBITMAP(); + + if (!hBmp) + return; + + m_vSelectedBitmap.SetSelectedInto(this); + hBmp = (WXHBITMAP)::GpiSetBitmap(m_hPS, (HBITMAP)hBmp); + + if (hBmp == HBM_ERROR) + { + wxLogLastError(wxT("SelectObject(memDC, bitmap)")); + wxFAIL_MSG(wxT("Couldn't select a bitmap into wxMemoryDC")); + } + else if (!m_hOldBitmap) + { + m_hOldBitmap = hBmp; + } +} // end of wxMemoryDC::SelectObject + +void wxMemoryDC::DoGetSize( + int* pWidth +, int* pHeight +) const { - if (m_selected.Ok()) - { - if (width) (*width) = m_selected.GetWidth(); - if (height) (*height) = m_selected.GetHeight(); - } - else - { - if (width) (*width) = 0; - if (height) (*height) = 0; - }; -}; + if (!m_vSelectedBitmap.Ok()) + { + *pWidth = 0; + *pHeight = 0; + return; + } + *pWidth = m_vSelectedBitmap.GetWidth(); + *pHeight = m_vSelectedBitmap.GetHeight(); +} // end of wxMemoryDC::DoGetSize