X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e78c4d503ecd57835502fb1bbd13a71cb99019d0..a336f999c2c432b1fc6c6324a70bdaab02c0886e:/src/os2/statbmp.cpp diff --git a/src/os2/statbmp.cpp b/src/os2/statbmp.cpp index bc19e866fe..5d523be4ff 100644 --- a/src/os2/statbmp.cpp +++ b/src/os2/statbmp.cpp @@ -3,12 +3,16 @@ // Purpose: wxStaticBitmap // Author: David Webster // Modified by: -// Created: ??/??/98 +// Created: 11/27/99 // RCS-ID: $Id$ // Copyright: (c) David Webster // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// +#ifdef __GNUG__ +#pragma implementation "statbmp.h" +#endif + // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" @@ -26,103 +30,164 @@ // macors // --------------------------------------------------------------------------- -#if !USE_SHARED_LIBRARY IMPLEMENT_DYNAMIC_CLASS(wxStaticBitmap, wxControl) -#endif + +static wxGDIImage* ConvertImage( + const wxGDIImage& rBitmap +) +{ + bool bIsIcon = rBitmap.IsKindOf( CLASSINFO(wxIcon) ); + + if(!bIsIcon ) + { + wxASSERT_MSG( wxDynamicCast(&rBitmap, wxBitmap), + _T("not an icon and not a bitmap?") ); + + const wxBitmap& rBmp = (const wxBitmap&)rBitmap; + wxMask* pMask = rBmp.GetMask(); + + if (pMask && pMask->GetMaskBitmap()) + { + wxIcon* pIcon = new wxIcon; + + pIcon->CopyFromBitmap(rBmp); + return pIcon; + } + return new wxBitmap(rBmp); + } + + // copying a bitmap is a cheap operation + return new wxIcon( (const wxIcon&)rBitmap ); +} // end of ConvertImage // --------------------------------------------------------------------------- // wxStaticBitmap // --------------------------------------------------------------------------- -bool wxStaticBitmap::Create(wxWindow *parent, wxWindowID id, - const wxBitmap& bitmap, - const wxPoint& pos, - const wxSize& size, - long style, - const wxString& name) +bool wxStaticBitmap::Create( + wxWindow* pParent +, wxWindowID nId +, const wxGDIImage& rBitmap +, const wxPoint& rPos +, const wxSize& rSize +, long lStyle +, const wxString& rName +) { - Init(); + ERRORID vError; + wxString sError; - SetName(name); - if (parent) parent->AddChild(this); + Init(); - m_backgroundColour = parent->GetBackgroundColour() ; - m_foregroundColour = parent->GetForegroundColour() ; + SetName(rName); + if (pParent) + pParent->AddChild(this); - if ( id == -1 ) + if (nId == -1) m_windowId = (int)NewControlId(); else - m_windowId = id; - - m_windowStyle = style; - - int x = pos.x; - int y = pos.y; - int width = size.x; - int height = size.y; - - m_windowStyle = style; - - m_isIcon = bitmap.IsKindOf(CLASSINFO(wxIcon)); - - // TODO: create static bitmap control + m_windowId = nId; + + m_windowStyle = lStyle; + + int nX= rPos.x; + int nY = rPos.y; + int nWidth = rSize.x; + int nHeight = rSize.y; + char zId[16]; + + m_windowStyle = lStyle; + + m_bIsIcon = rBitmap.IsKindOf(CLASSINFO(wxIcon)); + + // + // For now we only support an ICON + // + int nWinstyle = SS_ICON; + + sprintf(zId, "#%d", rBitmap.GetId()); + m_hWnd = (WXHWND)::WinCreateWindow( pParent->GetHWND() + ,WC_STATIC + ,zId + ,nWinstyle | WS_VISIBLE + ,0,0,0,0 + ,pParent->GetHWND() + ,HWND_TOP + ,m_windowId + ,NULL + ,NULL + ); + if (!m_hWnd) + { + vError = ::WinGetLastError(wxGetInstance()); + sError = wxPMErrorToStr(vError); + return FALSE; + } wxCHECK_MSG( m_hWnd, FALSE, wxT("Failed to create static bitmap") ); - - SetBitmap(bitmap); + m_pImage = ConvertImage(rBitmap); + m_pImage->SetHandle((WXHWND)::WinSendMsg(m_hWnd, SM_QUERYHANDLE, (MPARAM)0, (MPARAM)0)); // Subclass again for purposes of dialog editing mode SubclassWin(m_hWnd); - - SetFont(GetParent()->GetFont()); - - SetSize(x, y, width, height); - - return FALSE; -} + return(TRUE); +} // end of wxStaticBitmap::Create bool wxStaticBitmap::ImageIsOk() const { - if ( m_isIcon && m_image.icon ) - return m_image.icon->Ok(); - else if ( m_image.bitmap ) - return m_image.bitmap->Ok(); - else - return FALSE; + return(m_pImage && m_pImage->Ok()); } void wxStaticBitmap::Free() { - if ( m_isIcon ) - delete m_image.icon; - else - delete m_image.bitmap; - - m_image.icon = NULL; -} + if (m_pImage) + delete m_pImage; + m_pImage = NULL; +} // end of wxStaticBitmap::Free wxSize wxStaticBitmap::DoGetBestSize() const { - // reuse the current size (as wxWindow does) instead of using some + // + // Reuse the current size (as wxWindow does) instead of using some // arbitrary default size (as wxControl, our immediate base class, does) + // return wxWindow::DoGetBestSize(); } -void wxStaticBitmap::SetBitmap(const wxBitmap& bitmap) +void wxStaticBitmap::SetImage( + const wxGDIImage& rBitmap +) { + int nX = 0; + int nY = 0; + int nWidth = 0; + int nHeight = 0; + Free(); + ::WinSendMsg( GetHwnd() + ,SM_SETHANDLE + ,MPFROMHWND(rBitmap.GetHandle()) + ,NULL + ); + m_pImage = ConvertImage(rBitmap); - m_isIcon = bitmap.IsKindOf(CLASSINFO(wxIcon)); - if ( m_isIcon ) - m_image.icon = new wxIcon((const wxIcon&)bitmap); - else - m_image.bitmap = new wxBitmap(bitmap); + GetPosition(&nX, &nY); + GetSize(&nWidth, &nHeight); - int x, y; - int w, h; - GetPosition(&x, &y); - GetSize(&w, &h); + RECTL vRect; - // TODO: redraw bitmap -} + vRect.xLeft = nX; + vRect.yTop = nY; + vRect.xRight = nX + nWidth; + vRect.yBottom = nY + nHeight; + ::WinInvalidateRect(GetHwndOf(GetParent()), &vRect, TRUE); +} +MRESULT wxStaticBitmap::OS2WindowProc( + WXUINT uMsg +, WXWPARAM wParam +, WXLPARAM lParam +) +{ + return wxWindow::OS2WindowProc(uMsg, wParam, lParam); +} // end of wxStaticBitmap::OS2WindowProc