Newer
Older
/***********************************************************************
* FXRuby -- the Ruby language bindings for the FOX GUI toolkit.
* Copyright (c) 2001-2009 by Lyle Johnson. All Rights Reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*
* For further information please contact the author by e-mail
* at "lyle@lylejohnson.name".
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
***********************************************************************/
/// Microsoft Bitmap icon
class FXBMPIcon : public FXIcon {
protected:
FXBMPIcon(){}
public:
%extend {
static VALUE fileExt() {
return rb_str_new2(FXBMPIcon::fileExt);
}
static VALUE mimeType() {
return rb_str_new2(FXBMPIcon::mimeType);
}
}
public:
%extend {
/// Construct icon from memory stream formatted in Microsoft BMP format
FXBMPIcon(FXApp* a,const void *pix=NULL,FXColor clr=0,FXuint opts=0,FXint w=1,FXint h=1){
return new FXRbBMPIcon(a,pix,clr,opts,w,h);
}
}
/// Destroy icon
virtual ~FXBMPIcon();
};
DECLARE_FXOBJECT_VIRTUALS(FXBMPIcon)
DECLARE_FXID_VIRTUALS(FXBMPIcon)
DECLARE_FXDRAWABLE_VIRTUALS(FXBMPIcon)
DECLARE_FXIMAGE_VIRTUALS(FXBMPIcon)
%inline %{
/**
* Load an BMP (Microsoft Bitmap) file from a stream.
* Upon successful return, the pixel array and size are returned.
* If an error occurred, the pixel array is set to NULL.
*/
VALUE fxloadBMP(FXStream& store){
FXColor* data;
FXint width;
FXint height;
if(fxloadBMP(store,data,width,height)){
VALUE ary=rb_ary_new();
rb_ary_push(ary,FXRbMakeColorArray(data,width,height));
FXFREE(&data);
rb_ary_push(ary,to_ruby(width));
rb_ary_push(ary,to_ruby(height));
return ary;
}
else{
return Qnil;
}
}
%}
/// Save a bmp file to a stream
bool fxsaveBMP(FXStream& store,const FXColor *PIXELS,FXint width,FXint height);
/**
* Check if stream contains a bitmap, return TRUE if so.
*/
bool fxcheckBMP(FXStream& store);