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".
***********************************************************************/
%rename("supported?") FXPNGIcon::isSupported();
/// Portable Network Graphics (PNG) Icon
class FXPNGIcon : public FXIcon {
protected:
FXPNGIcon(){}
public:
%extend {
static VALUE fileExt() {
return to_ruby(FXPNGIcon::fileExt);
return to_ruby(FXPNGIcon::mimeType);
}
/// True if format is supported
static bool isSupported() { return FXPNGIcon::supported; }
}
public:
%extend {
/// Construct icon from memory stream formatted in PNG format
FXPNGIcon(FXApp* a,const void *pix=NULL,FXColor clr=0,FXuint opts=0,FXint w=1,FXint h=1){
return new FXRbPNGIcon(a,pix,clr,opts,w,h);
}
}
/// Destroy icon
virtual ~FXPNGIcon();
};
DECLARE_FXOBJECT_VIRTUALS(FXPNGIcon)
DECLARE_FXID_VIRTUALS(FXPNGIcon)
DECLARE_FXDRAWABLE_VIRTUALS(FXPNGIcon)
DECLARE_FXIMAGE_VIRTUALS(FXPNGIcon)
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
89
90
91
92
93
94
95
%inline %{
/**
* Load an PNG (Portable Network Graphics) 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 fxloadPNG(FXStream& store){
FXColor* data;
FXint width;
FXint height;
if(fxloadPNG(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 an PNG (Portable Network Graphics) file to a stream.
*/
bool fxsavePNG(FXStream& store,const FXColor *PIXELS,FXint width,FXint height);
/**
* Check if stream contains a bitmap, return TRUE if so.
*/
bool fxcheckPNG(FXStream& store);