1. applied (heavily modified) patch for reading CUR files by Chris

2. fixed MIME types (changed to image/x-{bmp,ico,cur})
3. (hopefully) reduced excessive amount of spaces used in code formatting
4. made error messages human readable


git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@13305 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Václav Slavík
2002-01-01 23:13:02 +00:00
parent a103111bae
commit 05813ada9a
4 changed files with 582 additions and 477 deletions

View File

@@ -72,6 +72,8 @@ wxBase:
All (GUI): All (GUI):
- fixed using custom renderers in wxGrid which was broken in 2.3.2 - fixed using custom renderers in wxGrid which was broken in 2.3.2
- support for multiple images in one file added to wxImage (TIFF and ICO formats)
- support for CUR files in wxImage added (Chris Elliott)
wxMSW: wxMSW:

View File

@@ -1,9 +1,9 @@
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
// Name: imagbmp.h // Name: imagbmp.h
// Purpose: wxImage BMP handler // Purpose: wxImage BMP, ICO and CUR handlers
// Author: Robert Roebling // Author: Robert Roebling, Chris Elliott
// RCS-ID: $Id$ // RCS-ID: $Id$
// Copyright: (c) Robert Roebling // Copyright: (c) Robert Roebling, Chris Elliott
// Licence: wxWindows licence // Licence: wxWindows licence
///////////////////////////////////////////////////////////////////////////// /////////////////////////////////////////////////////////////////////////////
@@ -43,25 +43,24 @@ class WXDLLEXPORT wxBMPHandler : public wxImageHandler
public: public:
wxBMPHandler() wxBMPHandler()
{ {
m_name = _T("BMP file"); m_name = _T("Windows bitmap file");
m_extension = _T("bmp"); m_extension = _T("bmp");
m_type = wxBITMAP_TYPE_BMP; m_type = wxBITMAP_TYPE_BMP;
m_mime = _T("image/bmp"); m_mime = _T("image/x-bmp");
}; };
#if wxUSE_STREAMS #if wxUSE_STREAMS
virtual bool SaveFile( wxImage *image, wxOutputStream& stream, bool verbose=TRUE );
virtual bool SaveFile( wxImage *image, wxOutputStream& stream, bool verbose=TRUE ); virtual bool LoadFile( wxImage *image, wxInputStream& stream, bool verbose=TRUE, int index=0 );
virtual bool LoadFile( wxImage *image, wxInputStream& stream, bool verbose=TRUE, int index=0 ); virtual bool DoCanRead( wxInputStream& stream );
virtual bool DoCanRead( wxInputStream& stream );
protected: protected:
bool SaveDib(wxImage *image, wxOutputStream& stream, bool verbose, bool IsBmp, bool IsMask); bool SaveDib(wxImage *image, wxOutputStream& stream, bool verbose,
bool DoLoadDib (wxImage * image, int width, int height, int bpp, int ncolors, int comp, bool IsBmp, bool IsMask);
off_t bmpOffset, wxInputStream& stream, bool DoLoadDib(wxImage *image, int width, int height, int bpp, int ncolors,
bool verbose, bool IsBmp, bool hasPalette ) ; int comp, off_t bmpOffset, wxInputStream& stream,
bool LoadDib( wxImage *image, wxInputStream& stream, bool verbose, bool IsBmp ) ; bool verbose, bool IsBmp, bool hasPalette);
bool LoadDib(wxImage *image, wxInputStream& stream, bool verbose, bool IsBmp);
#endif // wxUSE_STREAMS #endif // wxUSE_STREAMS
private: private:
@@ -78,25 +77,54 @@ class WXDLLEXPORT wxICOHandler : public wxBMPHandler
public: public:
wxICOHandler() wxICOHandler()
{ {
m_name = _T("ICO file"); m_name = _T("Windows icon file");
m_extension = _T("ico"); m_extension = _T("ico");
m_type = wxBITMAP_TYPE_ICO; m_type = wxBITMAP_TYPE_ICO;
m_mime = _T("image/icon"); m_mime = _T("image/x-ico");
}; };
#if wxUSE_STREAMS #if wxUSE_STREAMS
virtual bool SaveFile( wxImage *image, wxOutputStream& stream, bool verbose=TRUE );
virtual bool SaveFile( wxImage *image, wxOutputStream& stream, bool verbose=TRUE ); virtual bool LoadFile( wxImage *image, wxInputStream& stream, bool verbose=TRUE, int index=0 );
virtual bool LoadFile( wxImage *image, wxInputStream& stream, bool verbose=TRUE, int index=0 ); virtual bool DoCanRead( wxInputStream& stream );
virtual bool DoCanRead( wxInputStream& stream ); virtual int GetImagesCount( wxInputStream& stream );
#endif // wxUSE_STREAMS #endif // wxUSE_STREAMS
private: private:
DECLARE_DYNAMIC_CLASS(wxBMPHandler) DECLARE_DYNAMIC_CLASS(wxICOHandler)
}; };
#endif // ----------------------------------------------------------------------------
// _WX_IMAGBMP_H_ // wxCURHandler
// ----------------------------------------------------------------------------
// These two options are filled in upon reading CUR file and can (should) be
// specified when saving a CUR file - they define the hotspot of the cursor:
#define wxCUR_HOTSPOT_X wxT("HotSpotX")
#define wxCUR_HOTSPOT_Y wxT("HotSpotY")
class WXDLLEXPORT wxCURHandler : public wxICOHandler
{
public:
wxCURHandler()
{
m_name = _T("Windows cursor file");
m_extension = _T("cur");
m_type = wxBITMAP_TYPE_CUR;
m_mime = _T("image/x-cur");
};
// VS: This handler's meat is implemented inside wxICOHandler (the two
// formats are almost identical), but we hide this fact at
// the API level, since it is a mere implementation detail.
#if wxUSE_STREAMS
virtual bool DoCanRead( wxInputStream& stream );
#endif // wxUSE_STREAMS
private:
DECLARE_DYNAMIC_CLASS(wxCURHandler)
};
#endif // _WX_IMAGBMP_H_

View File

@@ -56,6 +56,7 @@ void wxInitAllImageHandlers()
wxImage::AddHandler( new wxXPMHandler ); wxImage::AddHandler( new wxXPMHandler );
#endif #endif
wxImage::AddHandler( new wxICOHandler ); wxImage::AddHandler( new wxICOHandler );
wxImage::AddHandler( new wxCURHandler );
} }
#endif // wxUSE_IMAGE #endif // wxUSE_IMAGE

File diff suppressed because it is too large Load Diff