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

FXXBMIcon.h

00001 /******************************************************************************** 00002 * * 00003 * X B M I c o n O b j e c t * 00004 * * 00005 ********************************************************************************* 00006 * Copyright (C) 2003,2004 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: FXXBMIcon.h,v 1.5 2004/02/08 17:17:34 fox Exp $ * 00023 ********************************************************************************/ 00024 #ifndef FXXBMICON_H 00025 #define FXXBMICON_H 00026 00027 #ifndef FXICON_H 00028 #include "FXIcon.h" 00029 #endif 00030 00031 namespace FX { 00032 00033 00034 /// X Bitmap icon 00035 class FXAPI FXXBMIcon : public FXIcon { 00036 FXDECLARE(FXXBMIcon) 00037 protected: 00038 FXXBMIcon(){} 00039 private: 00040 FXXBMIcon(const FXXBMIcon&); 00041 FXXBMIcon &operator=(const FXXBMIcon&); 00042 public: 00043 00044 /// Construct icon from memory stream formatted in X Bitmap format 00045 FXXBMIcon(FXApp* a,const FXuchar *pixels=NULL,const FXuchar *mask=NULL,FXColor clr=FXRGB(192,192,192),FXuint opts=0,FXint w=1,FXint h=1); 00046 00047 /// Save pixels into stream in X Bitmap format 00048 virtual FXbool savePixels(FXStream& store) const; 00049 00050 /// Load pixels from stream in X Bitmap format 00051 virtual FXbool loadPixels(FXStream& store); 00052 00053 /// Destroy icon 00054 virtual ~FXXBMIcon(); 00055 }; 00056 00057 00058 #ifndef FXLOADXBM 00059 #define FXLOADXBM 00060 00061 /** 00062 * Load an XBM (X Bitmap) from pixel array and mask array. 00063 * Upon successful return, the pixel array and size are returned. 00064 * If an error occurred, the pixel array is set to NULL. 00065 */ 00066 extern FXAPI FXbool fxloadXBM(FXColor*& data,const FXuchar *pix,const FXuchar *msk,FXint width,FXint height); 00067 00068 00069 /** 00070 * Load an XBM (X Bitmap) file from a stream. 00071 * Upon successful return, the pixel array and size, and hot-spot are returned. 00072 * If an error occurred, the pixel array is set to NULL. 00073 */ 00074 extern FXAPI FXbool fxloadXBM(FXStream& store,FXColor*& data,FXint& width,FXint& height,FXint& hotx,FXint& hoty); 00075 00076 00077 /** 00078 * Save an XBM (X Bitmap) file to a stream; if the parameters hotx and hoty are set 00079 * to -1, no hotspot location is saved. 00080 */ 00081 extern FXAPI FXbool fxsaveXBM(FXStream& store,const FXColor *data,FXint width,FXint height,FXint hotx=-1,FXint hoty=-1); 00082 00083 /** 00084 * Save a PostScript file to a stream; format the picture to the maximal 00085 * size that fits within the given margins of the indicated paper size. 00086 */ 00087 extern FXAPI FXbool fxsavePS(FXStream& store,const FXColor *data,FXint width,FXint height,FXint paperw=612,FXint paperh=792,FXint margin=35,FXbool color=TRUE); 00088 00089 #endif 00090 00091 } 00092 00093 #endif

Copyright © 1997-2004 Jeroen van der Zijp