369 lines
7.5 KiB
C++
Raw Normal View History

/***************************************************************************
CFont.cpp
(c) 2004-2006 - Daniel Campos Fernández <dcamposf@gmail.com>
GTK+ component
Realizado para la Junta de Extremadura.
Consejería de Educación Ciencia y Tecnología.
Proyecto gnuLinEx
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 1, or (at your option)
any later version.
This program 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
***************************************************************************/
#define __CFONT_CPP
#include <math.h>
#include "CFont.h"
#include "gdesktop.h"
#include "gb.form.font.h"
CFONT *CFONT_create(gFont *font, FONT_FUNC func, void *object)
{
CFONT *_object;
GB.New(POINTER(&_object), GB.FindClass("Font"), NULL, NULL);
if (func)
font = font->copy();
gFont::assign(&THIS->font, font);
THIS->func = func;
THIS->object = object;
if (object)
GB.Ref(object);
return THIS;
}
BEGIN_METHOD(CFONT_new, GB_STRING font)
if (!MISSING(font))
FONT = new gFont(GB.ToZeroString(ARG(font)));
else
FONT = gDesktop::font()->copy();
END_METHOD
BEGIN_METHOD_VOID(CFONT_free)
GB.Unref(POINTER(&THIS->object));
gFont::assign(&THIS->font);
END_METHOD
static void CFONT_manage(int prop, CFONT *_object, void *_param)
{
gFont *f = FONT;
if (READ_PROPERTY)
{
switch(prop)
{
case CFONT::Name: GB.ReturnNewZeroString(f->name()); break;
case CFONT::Size: GB.ReturnFloat(f->size()); break;
case CFONT::Grade: GB.ReturnInteger(f->grade()); break;
case CFONT::Bold: GB.ReturnBoolean(f->bold()); break;
case CFONT::Italic: GB.ReturnBoolean(f->italic()); break;
case CFONT::Underline: GB.ReturnBoolean(f->underline()); break;
case CFONT::StrikeOut: GB.ReturnBoolean(f->strikeOut()); break;
}
}
else
{
switch (prop)
{
case CFONT::Name: f->setName(GB.ToZeroString(PROP(GB_STRING))); break;
case CFONT::Size: f->setSize(VPROP(GB_FLOAT)); break;
case CFONT::Grade: f->setGrade(VPROP(GB_INTEGER)); break;
case CFONT::Bold: f->setBold(VPROP(GB_BOOLEAN)); break;
case CFONT::Italic: f->setItalic(VPROP(GB_BOOLEAN)); break;
case CFONT::Underline: f->setUnderline(VPROP(GB_BOOLEAN)); break;
case CFONT::StrikeOut: f->setStrikeOut(VPROP(GB_BOOLEAN)); break;
}
if (THIS->func)
(*(THIS->func))(f, THIS->object);
else if (THIS->object)
{
// THIS->control->widget->setFont(*f); - Not needed anymore
// TODO Make a Gambas API to call SetProperty faster
GB_FUNCTION func;
GB.GetFunction(&func, GB.FindClass("Object"), "SetProperty", NULL, NULL);
GB.Push(3,
GB_T_OBJECT, THIS->object,
GB_T_STRING, "Font", 4,
GB_T_OBJECT, THIS
);
GB.Call(&func, 3, TRUE);
}
}
}
BEGIN_PROPERTY(CFONT_name)
CFONT_manage(CFONT::Name, OBJECT(CFONT), _param);
END_PROPERTY
BEGIN_PROPERTY(CFONT_size)
CFONT_manage(CFONT::Size, OBJECT(CFONT), _param);
END_PROPERTY
BEGIN_PROPERTY(CFONT_grade)
CFONT_manage(CFONT::Grade, OBJECT(CFONT), _param);
END_PROPERTY
BEGIN_PROPERTY(CFONT_bold)
CFONT_manage(CFONT::Bold, OBJECT(CFONT), _param);
END_PROPERTY
BEGIN_PROPERTY(CFONT_italic)
CFONT_manage(CFONT::Italic, OBJECT(CFONT), _param);
END_PROPERTY
BEGIN_PROPERTY(CFONT_underline)
CFONT_manage(CFONT::Underline, OBJECT(CFONT), _param);
END_PROPERTY
BEGIN_PROPERTY(CFONT_strikeout)
CFONT_manage(CFONT::StrikeOut, OBJECT(CFONT), _param);
END_PROPERTY
#if 0
BEGIN_PROPERTY(CFONT_name)
const char *buf;
if (READ_PROPERTY)
{
buf=FONT->name();
GB.ReturnNewString(buf,0);
return;
}
FONT->setName(GB.ToZeroString(PROP(GB_STRING)));
END_PROPERTY
BEGIN_PROPERTY(CFONT_size)
if (READ_PROPERTY) { GB.ReturnFloat(FONT->size()); return; }
FONT->setSize(VPROP(GB_FLOAT));
END_PROPERTY
BEGIN_PROPERTY(CFONT_bold)
if (READ_PROPERTY){ GB.ReturnBoolean(FONT->bold()); return; }
FONT->setBold(VPROP(GB_BOOLEAN));
END_PROPERTY
BEGIN_PROPERTY(CFONT_italic)
if (READ_PROPERTY){ GB.ReturnBoolean(FONT->italic()); return; }
FONT->setItalic(VPROP(GB_BOOLEAN));
END_PROPERTY
#endif
BEGIN_METHOD_VOID(CFONT_to_string)
GB.ReturnNewString(FONT->toString(), 0);
END_METHOD
BEGIN_METHOD(CFONT_get, GB_STRING str)
CFONT *font;
gFont *fnt;
fnt = new gFont(GB.ToZeroString(PROP(GB_STRING)));
font = CFONT_create(fnt);
gFont::assign(&fnt);
GB.ReturnObject(font);
END_METHOD
BEGIN_METHOD(CFONT_width, GB_STRING text)
GB.ReturnInteger( FONT->width( STRING(text), LENGTH(text) ) );
END_METHOD
BEGIN_PROPERTY(CFONT_ascent)
GB.ReturnInteger(FONT->ascent());
END_PROPERTY
BEGIN_PROPERTY(CFONT_descent)
GB.ReturnInteger(FONT->descent());
END_PROPERTY
BEGIN_METHOD(CFONT_height, GB_STRING text)
if (MISSING(text))
GB.ReturnInteger(FONT->height());
else
GB.ReturnInteger(FONT->height(STRING(text), LENGTH(text)));
END_METHOD
BEGIN_PROPERTY(CFONT_fixed)
GB.ReturnBoolean(FONT->fixed());
END_PROPERTY
#if 0
BEGIN_PROPERTY(CFONT_resolution)
END_PROPERTY
#endif
BEGIN_METHOD_VOID(CFONTS_next)
long *pos;
pos=(long*)GB.GetEnum();
if ( pos[0]>=gFont::count() )
{
GB.StopEnum ();
return;
}
GB.ReturnNewString ( gFont::familyItem(pos[0]++),0 );
END_METHOD
BEGIN_PROPERTY(CFONTS_count)
GB.ReturnInteger(gFont::count());
END_PROPERTY
BEGIN_PROPERTY(CFONT_styles)
stub("CFONT_styles");
END_PROPERTY
BEGIN_PROPERTY(CFONT_scalable)
GB.ReturnBoolean(FONT->scalable());
END_PROPERTY
#if 0
BEGIN_PROPERTY(CFONT_underline)
if (READ_PROPERTY) { GB.ReturnBoolean(FONT->underline()); return; }
FONT->setUnderline(VPROP(GB_BOOLEAN));
END_PROPERTY
BEGIN_PROPERTY(CFONT_strikeout)
if (READ_PROPERTY) { GB.ReturnBoolean(FONT->strikeOut()); return; }
FONT->setStrikeOut(VPROP(GB_BOOLEAN));
END_PROPERTY
#endif
GB_DESC CFontsDesc[] =
{
GB_DECLARE("Fonts", 0),
GB_NOT_CREATABLE(),
GB_STATIC_METHOD("_next", "s", CFONTS_next, NULL),
GB_STATIC_PROPERTY_READ("Count", "i", CFONTS_count),
GB_END_DECLARE
};
GB_DESC CFontDesc[] =
{
GB_DECLARE("Font", sizeof(CFONT)),
GB_METHOD("_new", NULL, CFONT_new, "[(Font)s]"),
GB_METHOD("_free", NULL, CFONT_free, NULL),
GB_PROPERTY("Name", "s", CFONT_name),
GB_PROPERTY("Size", "f", CFONT_size),
GB_PROPERTY("Bold", "b", CFONT_bold),
GB_PROPERTY("Italic", "b", CFONT_italic),
GB_PROPERTY("Underline", "b", CFONT_underline),
GB_PROPERTY("StrikeOut", "b", CFONT_strikeout),
GB_PROPERTY("Grade", "i", CFONT_grade),
GB_METHOD("ToString", "s", CFONT_to_string, NULL),
GB_METHOD("Width", "i", CFONT_width, "(Text)s"),
GB_METHOD("Height", "i", CFONT_height, "[(Text)s]"),
GB_STATIC_METHOD("_get", "Font", CFONT_get, "(Font)s"),
#if 0
GB_STATIC_PROPERTY("Resolution", "i", CFONT_resolution),
#endif
GB_PROPERTY_READ("Ascent", "i", CFONT_ascent),
GB_PROPERTY_READ("Descent", "i", CFONT_descent),
GB_PROPERTY_READ("Fixed", "b", CFONT_fixed),
GB_PROPERTY_READ("Scalable", "b", CFONT_scalable),
GB_PROPERTY_READ("Styles", "String[]", CFONT_styles),
GB_END_DECLARE
};