Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members

FXBMPImage.h

Go to the documentation of this file.
00001 /********************************************************************************
00002 *                                                                               *
00003 *                            B M P   I m a g e   O b j e c t                    *
00004 *                                                                               *
00005 *********************************************************************************
00006 * Copyright (C) 1998,2006 by Jeroen van der Zijp.   All Rights Reserved.        *
00007 *********************************************************************************
00008 * This library is free software; you can redistribute it and/or                 *
00009 * modify it under the terms of the GNU Lesser General Public                    *
00010 * License as published by the Free Software Foundation; either                  *
00011 * version 2.1 of the License, or (at your option) any later version.            *
00012 *                                                                               *
00013 * This library is distributed in the hope that it will be useful,               *
00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of                *
00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU             *
00016 * Lesser General Public License for more details.                               *
00017 *                                                                               *
00018 * You should have received a copy of the GNU Lesser General Public              *
00019 * License along with this library; if not, write to the Free Software           *
00020 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA.    *
00021 *********************************************************************************
00022 * $Id: FXBMPImage.h,v 1.22 2006/01/22 17:57:59 fox Exp $                        *
00023 ********************************************************************************/
00024 #ifndef FXBMPIMAGE_H
00025 #define FXBMPIMAGE_H
00026 
00027 #ifndef FXIMAGE_H
00028 #include "FXImage.h"
00029 #endif
00030 
00031 namespace FX {
00032 
00033 
00034 /**
00035 * The BMP Image class is a convenience class for working with images in the
00036 * Microsoft Bitmap (.bmp) graphics file format.  This makes it possible to
00037 * use resources created with Windows development tools inside FOX without
00038 * need for graphics file format translators.  The bitmap loaded handles
00039 * 1, 4, and 8 bit paletted bitmaps, 16 and 24 bit RGB bitmaps, and
00040 * 32 bit RGBA bitmaps.
00041 */
00042 class FXAPI FXBMPImage : public FXImage {
00043   FXDECLARE(FXBMPImage)
00044 protected:
00045   FXBMPImage(){}
00046 private:
00047   FXBMPImage(const FXBMPImage&);
00048   FXBMPImage &operator=(const FXBMPImage&);
00049 public:
00050   static const FXchar fileExt[];
00051   static const FXchar mimeType[];
00052 public:
00053 
00054   /// Construct image from memory stream formatted in Microsoft BMP format
00055   FXBMPImage(FXApp* a,const void *pix=NULL,FXuint opts=0,FXint w=1,FXint h=1);
00056 
00057   /// Save pixels into stream in Microsoft bitmap format
00058   virtual bool savePixels(FXStream& store) const;
00059 
00060   /// Load pixels from stream in Microsoft bitmap format
00061   virtual bool loadPixels(FXStream& store);
00062 
00063   /// Destroy icon
00064   virtual ~FXBMPImage();
00065   };
00066 
00067 
00068 /**
00069 * Check if stream contains a bitmap, return TRUE if so.
00070 */
00071 extern FXAPI bool fxcheckBMP(FXStream& store);
00072 
00073 
00074 /**
00075 * Load an BMP (Microsoft Bitmap) file from a stream.
00076 * Upon successful return, the pixel array and size are returned.
00077 * If an error occurred, the pixel array is set to NULL.
00078 */
00079 extern FXAPI bool fxloadBMP(FXStream& store,FXColor*& data,FXint& width,FXint& height);
00080 
00081 
00082 /**
00083 * Save an BMP (Microsoft Bitmap) file to a stream.
00084 */
00085 extern FXAPI bool fxsaveBMP(FXStream& store,const FXColor *data,FXint width,FXint height);
00086 
00087 }
00088 
00089 #endif

Copyright © 1997-2005 Jeroen van der Zijp