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:
@@ -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:
|
||||||
|
|
||||||
|
@@ -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_
|
||||||
|
@@ -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
Reference in New Issue
Block a user