X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/47f797bd30a434bcf7a0e5241891e928fe62a35b..61c213fe224da24ce33c9187263e75a17ca83a04:/samples/image/image.cpp diff --git a/samples/image/image.cpp b/samples/image/image.cpp index dd69ad6a45..7bfe2db778 100644 --- a/samples/image/image.cpp +++ b/samples/image/image.cpp @@ -1,11 +1,13 @@ -/* - * Program: image - * - * Author: Robert Roebling - * - * Copyright: (C) 1998, Robert Roebling - * - */ +/////////////////////////////////////////////////////////////////////////////// +// Name: samples/image/image.cpp +// Purpose: sample showing operations with wxImage +// Author: Robert Roebling +// Modified by: +// Created: 1998 +// RCS-ID: $Id$ +// Copyright: (c) 1998-2005 Robert Roebling +// License: wxWindows licence +/////////////////////////////////////////////////////////////////////////////// // For compilers that support precompilation, includes "wx/wx.h". #include "wx/wxprec.h" @@ -20,6 +22,7 @@ #include "wx/image.h" #include "wx/file.h" +#include "wx/filename.h" #include "wx/mstream.h" #include "wx/wfstream.h" #include "wx/quantize.h" @@ -32,12 +35,17 @@ #include "smile.xbm" #include "smile.xpm" -#if defined(__WXMSW__) || defined(__WXMAC__) +#if defined(__WXMSW__) #ifdef wxHAVE_RAW_BITMAP #include "wx/rawbmp.h" #endif #endif +#if defined(__WXMAC__) || defined(__WXGTK__) + #define wxHAVE_RAW_BITMAP + #include "wx/rawbmp.h" +#endif + // derived classes class MyFrame; @@ -86,31 +94,6 @@ private: }; -const int nChoices = 8 ; -static const wxString bppchoices[nChoices] = -{ - _T("1 bpp color"), - _T("1 bpp B&W"), - _T("4 bpp color"), - _T("8 bpp color"), - _T("8 bpp greyscale"), - _T("8 bpp red"), - _T("8 bpp own palette"), - _T("24 bpp") -}; - -static const int bppvalues[nChoices] = -{ - wxBMP_1BPP, - wxBMP_1BPP_BW, - wxBMP_4BPP, - wxBMP_8BPP, - wxBMP_8BPP_GREY, - wxBMP_8BPP_RED, - wxBMP_8BPP_PALETTE, - wxBMP_24BPP -}; - // MyFrame @@ -165,25 +148,9 @@ public: { wxImage image = m_bitmap.ConvertToImage(); - int bppselection = wxGetSingleChoiceIndex(_T("Set BMP BPP"), - _T("Set BMP BPP"), - nChoices, - bppchoices, - this); - if ( bppselection == -1 ) - { - // cancelled - return; - } - - image.SetOption(wxIMAGE_OPTION_BMP_FORMAT, bppvalues[bppselection]); - - wxString deffilename = bppchoices[bppselection]; - deffilename.Replace(wxT(" "), wxT("_")); - deffilename += wxT(".bmp"); wxString savefilename = wxFileSelector( wxT("Save Image"), wxT(""), - deffilename, + wxT(""), (const wxChar *)NULL, wxT("BMP files (*.bmp)|*.bmp|") wxT("PNG files (*.png)|*.png|") @@ -199,39 +166,106 @@ public: if ( savefilename.empty() ) return; - if ( image.GetOptionInt(wxIMAGE_OPTION_BMP_FORMAT) == wxBMP_8BPP_PALETTE ) - { - unsigned char *cmap = new unsigned char [256]; - for ( int i = 0; i < 256; i++ ) - cmap[i] = i; - image.SetPalette(wxPalette(256, cmap, cmap, cmap)); + wxString extension; + wxFileName::SplitPath(savefilename, NULL, NULL, &extension); - delete cmap; + bool saved = false; + if ( extension == _T("bpp") ) + { + static const int bppvalues[] = + { + wxBMP_1BPP, + wxBMP_1BPP_BW, + wxBMP_4BPP, + wxBMP_8BPP, + wxBMP_8BPP_GREY, + wxBMP_8BPP_RED, + wxBMP_8BPP_PALETTE, + wxBMP_24BPP + }; + + const wxString bppchoices[] = + { + _T("1 bpp color"), + _T("1 bpp B&W"), + _T("4 bpp color"), + _T("8 bpp color"), + _T("8 bpp greyscale"), + _T("8 bpp red"), + _T("8 bpp own palette"), + _T("24 bpp") + }; + + int bppselection = wxGetSingleChoiceIndex(_T("Set BMP BPP"), + _T("Image sample: save file"), + WXSIZEOF(bppchoices), + bppchoices, + this); + if ( bppselection != -1 ) + { + int format = bppvalues[bppselection]; + image.SetOption(wxIMAGE_OPTION_BMP_FORMAT, format); + + if ( format == wxBMP_8BPP_PALETTE ) + { + unsigned char *cmap = new unsigned char [256]; + for ( int i = 0; i < 256; i++ ) + cmap[i] = (unsigned char)i; + image.SetPalette(wxPalette(256, cmap, cmap, cmap)); + + delete cmap; + } + } } - - bool loaded; - wxString extension = savefilename.AfterLast('.').Lower(); - - if (extension == _T("cur")) + else if ( extension == _T("png") ) + { + static const int pngvalues[] = + { + wxPNG_TYPE_COLOUR, + wxPNG_TYPE_COLOUR, + wxPNG_TYPE_GREY, + wxPNG_TYPE_GREY, + wxPNG_TYPE_GREY_RED, + wxPNG_TYPE_GREY_RED, + }; + + const wxString pngchoices[] = + { + _T("Colour 8bpp"), + _T("Colour 16bpp"), + _T("Grey 8bpp"), + _T("Grey 16bpp"), + _T("Grey red 8bpp"), + _T("Grey red 16bpp"), + }; + + int sel = wxGetSingleChoiceIndex(_T("Set PNG format"), + _T("Image sample: save file"), + WXSIZEOF(pngchoices), + pngchoices, + this); + if ( sel != -1 ) + { + image.SetOption(wxIMAGE_OPTION_PNG_FORMAT, pngvalues[sel]); + image.SetOption(wxIMAGE_OPTION_PNG_BITDEPTH, sel % 2 ? 16 : 8); + } + } + else if ( extension == _T("cur") ) { image.Rescale(32,32); image.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_X, 0); image.SetOption(wxIMAGE_OPTION_CUR_HOTSPOT_Y, 0); // This shows how you can save an image with explicitly // specified image format: - loaded = image.SaveFile(savefilename, wxBITMAP_TYPE_CUR); + saved = image.SaveFile(savefilename, wxBITMAP_TYPE_CUR); } - else + + if ( !saved ) { // This one guesses image format from filename extension // (it may fail if the extension is not recognized): - loaded = image.SaveFile(savefilename); + image.SaveFile(savefilename); } - - if ( !loaded ) - wxMessageBox(_T("No handler for this file type."), - _T("File was not saved"), - wxOK|wxCENTRE, this); } private: @@ -285,10 +319,12 @@ public: for ( int x = 0; x < REAL_SIZE; ++x ) { - p.Red() = r; - p.Green() = g; - p.Blue() = b; - p.Alpha() = (Data::Iterator::ChannelType)((x*255.)/REAL_SIZE); + // note that RGB must be premultiplied by alpha + unsigned a = (Data::Iterator::ChannelType)((x*255.)/REAL_SIZE); + p.Red() = r * a / 256; + p.Green() = g * a / 256; + p.Blue() = b * a / 256; + p.Alpha() = a; ++p; // same as p.OffsetX(1) } @@ -538,7 +574,7 @@ MyCanvas::MyCanvas( wxWindow *parent, wxWindowID id, tmp << i ; wxLogError(tmp); } - else + else my_horse_ani [i] = wxBitmap( image ); } #endif // wxUSE_ICO_CUR @@ -549,13 +585,14 @@ MyCanvas::MyCanvas( wxWindow *parent, wxWindowID id, wxFile file(dir + _T("horse.bmp")); if ( file.IsOpened() ) { - off_t len = file.Length(); - void *data = malloc(len); - if ( file.Read(data, len) != len ) + wxFileOffset len = file.Length(); + size_t dataSize = (size_t)len; + void *data = malloc(dataSize); + if ( file.Read(data, dataSize) != len ) wxLogError(_T("Reading bitmap file failed")); else { - wxMemoryInputStream mis(data, len); + wxMemoryInputStream mis(data, dataSize); if ( !image.LoadFile(mis) ) wxLogError(wxT("Can't load BMP image from stream")); else @@ -713,7 +750,7 @@ void MyCanvas::OnPaint( wxPaintEvent &WXUNUSED(event) ) // For testing transparency dc.SetBrush( *wxRED_BRUSH ); dc.DrawRectangle( 20, 2220, 560, 68 ); - + dc.DrawText(_T("XPM bitmap"), 30, 2230 ); if ( m_bmpSmileXpm.Ok() ) dc.DrawBitmap(m_bmpSmileXpm, 30, 2250, true); @@ -721,8 +758,8 @@ void MyCanvas::OnPaint( wxPaintEvent &WXUNUSED(event) ) dc.DrawText(_T("XPM icon"), 110, 2230 ); if ( m_iconSmileXpm.Ok() ) dc.DrawIcon(m_iconSmileXpm, 110, 2250); - - // testing icon -> bitmap conversion + + // testing icon -> bitmap conversion wxBitmap to_blit( m_iconSmileXpm ); if (to_blit.Ok()) { @@ -737,7 +774,7 @@ void MyCanvas::OnPaint( wxPaintEvent &WXUNUSED(event) ) dc.SetUserScale( 2, 2 ); dc.DrawBitmap( to_blit, (int)(300/2), (int)(2250/2), true ); dc.SetUserScale( 1.0, 1.0 ); - + dc.DrawText( _T("Blit"), 400, 2230); wxMemoryDC blit_dc; blit_dc.SelectObject( to_blit ); @@ -822,7 +859,7 @@ void MyCanvas::CreateAntiAliasedBitmap() original.GetBlue( x*2, y*2+1 ) + original.GetBlue( x*2+1, y*2+1 ); blue = blue/4; - anti.SetRGB( x, y, red, green, blue ); + anti.SetRGB( x, y, (unsigned char)red, (unsigned char)green, (unsigned char)blue ); } my_anti = new wxBitmap(anti); } @@ -880,9 +917,11 @@ MyFrame::MyFrame() SetMenuBar( menu_bar ); +#if wxUSE_STATUSBAR CreateStatusBar(2); int widths[] = { -1, 100 }; SetStatusWidths( 2, widths ); +#endif // wxUSE_STATUSBAR m_canvas = new MyCanvas( this, wxID_ANY, wxPoint(0,0), wxSize(10,10) );