2009-01-29 00:18:34 +08:00
////////////////////////////////////////////////////////////
//
// PySFML - Python binding for SFML (Simple and Fast Multimedia Library)
// Copyright (C) 2007, 2008 Rémi Koenig (remi.k2620@gmail.com)
//
// This software is provided 'as-is', without any express or implied warranty.
// In no event will the authors be held liable for any damages arising from the use of this software.
//
// Permission is granted to anyone to use this software for any purpose,
// including commercial applications, and to alter it and redistribute it freely,
// subject to the following restrictions:
//
// 1. The origin of this software must not be misrepresented;
// you must not claim that you wrote the original software.
// If you use this software in a product, an acknowledgment
// in the product documentation would be appreciated but is not required.
//
// 2. Altered source versions must be plainly marked as such,
// and must not be misrepresented as being the original software.
//
// 3. This notice may not be removed or altered from any source distribution.
//
////////////////////////////////////////////////////////////
# include "Font.hpp"
# include "Glyph.hpp"
2009-02-26 20:36:06 +08:00
# include "compat.hpp"
2009-01-29 00:18:34 +08:00
static void
PySfFont_dealloc ( PySfFont * self )
{
if ( self - > Owner )
delete self - > obj ;
2009-02-26 20:36:06 +08:00
free_object ( self ) ;
2009-01-29 00:18:34 +08:00
}
static PyObject *
PySfFont_new ( PyTypeObject * type , PyObject * args , PyObject * kwds )
{
PySfFont * self ;
self = ( PySfFont * ) type - > tp_alloc ( type , 0 ) ;
if ( self ! = NULL )
self - > Owner = true ;
return ( PyObject * ) self ;
}
static int
PySfFont_init ( PySfFont * self , PyObject * args , PyObject * kwds )
{
self - > obj = new sf : : Font ( ) ;
return 0 ;
}
static PyObject *
PySfFont_LoadFromFile ( PySfFont * self , PyObject * args , PyObject * kwds )
{
const char * kwlist [ ] = { " Filename " , " Charsize " , " Charset " , NULL } ;
unsigned int Charsize = 30 ;
char * Filename ;
char * CharsetTmp = NULL ;
int CharsetSize ;
bool Result ;
2009-02-26 20:36:06 +08:00
if ( ! PyArg_ParseTupleAndKeywords ( args , kwds , " s|Is#:Font.LoadFromFile " , ( char * * ) kwlist , & Filename , & Charsize , & CharsetTmp , & CharsetSize ) )
2009-01-29 00:18:34 +08:00
return NULL ;
if ( CharsetTmp )
{
if ( ( unsigned char ) CharsetTmp [ 0 ] = = 0xff & & ( unsigned char ) CharsetTmp [ 1 ] = = 0xfe )
Result = self - > obj - > LoadFromFile ( Filename , Charsize , sf : : Unicode : : Text ( ( const sf : : Uint16 * ) ( CharsetTmp + 2 ) ) ) ;
else
Result = self - > obj - > LoadFromFile ( Filename , Charsize , sf : : Unicode : : Text ( ( const sf : : Uint8 * ) CharsetTmp ) ) ;
}
else
Result = self - > obj - > LoadFromFile ( Filename , Charsize ) ;
if ( Result )
Py_RETURN_TRUE ;
else
Py_RETURN_FALSE ;
}
static PyObject *
PySfFont_LoadFromMemory ( PySfFont * self , PyObject * args , PyObject * kwds )
{
const char * kwlist [ ] = { " Data " , " Charsize " , " Charset " , NULL } ;
unsigned int Charsize = 30 , Size ;
char * Data ;
char * CharsetTmp = NULL ;
int CharsetSize ;
bool Result ;
2009-02-26 20:36:06 +08:00
if ( ! PyArg_ParseTupleAndKeywords ( args , kwds , " s#|Is#:Font.LoadFromMemory " , ( char * * ) kwlist , & Data , & Size , & Charsize , & CharsetTmp , & CharsetSize ) )
2009-01-29 00:18:34 +08:00
return NULL ;
if ( CharsetTmp )
{
if ( ( unsigned char ) CharsetTmp [ 0 ] = = 0xff & & ( unsigned char ) CharsetTmp [ 1 ] = = 0xfe )
Result = self - > obj - > LoadFromMemory ( Data , Size , Charsize , sf : : Unicode : : Text ( ( const sf : : Uint16 * ) ( CharsetTmp + 2 ) ) ) ;
else
Result = self - > obj - > LoadFromMemory ( Data , Size , Charsize , sf : : Unicode : : Text ( ( const sf : : Uint8 * ) CharsetTmp ) ) ;
}
else
Result = self - > obj - > LoadFromMemory ( Data , Size , Charsize ) ;
if ( Result )
Py_RETURN_TRUE ;
else
Py_RETURN_FALSE ;
}
static PyObject *
PySfFont_GetDefaultFont ( PySfFont * self , PyObject * args )
{
PySfFont * DefaultFont = GetNewPySfFont ( ) ;
DefaultFont - > Owner = false ;
DefaultFont - > obj = ( sf : : Font * ) & ( sf : : Font : : GetDefaultFont ( ) ) ;
return ( PyObject * ) DefaultFont ;
}
static PyObject *
PySfFont_GetCharacterSize ( PySfFont * self )
{
return PyLong_FromUnsignedLong ( self - > obj - > GetCharacterSize ( ) ) ;
}
static PyObject *
PySfFont_GetGlyph ( PySfFont * self , PyObject * args )
{
PySfGlyph * PyGlyph = GetNewPySfGlyph ( ) ;
sf : : Glyph * Glyph = new sf : : Glyph ( self - > obj - > GetGlyph ( PyLong_AsUnsignedLong ( args ) ) ) ;
PyGlyph - > obj = Glyph ;
PyGlyph - > Rectangle - > obj = & ( PyGlyph - > obj - > Rectangle ) ;
PyGlyph - > TexCoords - > obj = & ( PyGlyph - > obj - > TexCoords ) ;
PySfGlyphUpdateSelf ( PyGlyph ) ;
return ( PyObject * ) PyGlyph ;
}
static PyMethodDef PySfFont_methods [ ] = {
{ " LoadFromFile " , ( PyCFunction ) PySfFont_LoadFromFile , METH_VARARGS | METH_KEYWORDS , " LoadFromFile(Filename, CharSize, Charset) \n \
Load the font from a file . Returns True if loading was successful . \ n \
Filename : Font file to load \ n \
CharSize : Size of characters in bitmap - the bigger , the higher quality ( 30 by default ) \ n \
Charset : Characters set to generate ( empty by default - takes the ASCII range [ 31 , 255 ] ) " },
{ " LoadFromMemory " , ( PyCFunction ) PySfFont_LoadFromMemory , METH_VARARGS | METH_KEYWORDS , " LoadFromMemory(Data, CharSize, Charset) \n \
Load the font from a file in memory . Returns True if loading was successful . \ n \
Data : data to load \ n \
CharSize : Size of characters in bitmap - the bigger , the higher quality ( 30 by default ) \ n \
Charset : Characters set to generate ( empty by default - takes the ASCII range [ 31 , 255 ] ) " },
{ " GetDefaultFont " , ( PyCFunction ) PySfFont_GetDefaultFont , METH_NOARGS | METH_STATIC , " GetDefaultFont() \n \
Get the SFML default built - in font ( Arial ) . " },
{ " GetCharacterSize " , ( PyCFunction ) PySfFont_GetCharacterSize , METH_NOARGS , " GetCharacterSize() \n \
Get the base size of characters in the font ; All glyphs dimensions are based on this value " },
{ " GetGlyph " , ( PyCFunction ) PySfFont_GetGlyph , METH_O , " GetGlyph(CodePoint) \n \
Get the description of a glyph ( character ) given by its unicode value . Returns glyph ' s visual settings , or an invalid glyph if character not found . \ n \
CodePoint : Unicode value of the character to get . " },
{ NULL } /* Sentinel */
} ;
PyTypeObject PySfFontType = {
2009-02-26 20:36:06 +08:00
head_init
2009-01-29 00:18:34 +08:00
" Font " , /*tp_name*/
sizeof ( PySfFont ) , /*tp_basicsize*/
0 , /*tp_itemsize*/
( destructor ) PySfFont_dealloc , /*tp_dealloc*/
0 , /*tp_print*/
0 , /*tp_getattr*/
0 , /*tp_setattr*/
0 , /*tp_compare*/
0 , /*tp_repr*/
0 , /*tp_as_number*/
0 , /*tp_as_sequence*/
0 , /*tp_as_mapping*/
0 , /*tp_hash */
0 , /*tp_call*/
0 , /*tp_str*/
0 , /*tp_getattro*/
0 , /*tp_setattro*/
0 , /*tp_as_buffer*/
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE , /*tp_flags*/
" sf.Font is the low-level class for loading and manipulating character fonts. This class is meant to be used by sf.String. \n Default constructor : sf.Font(). " , /* tp_doc */
0 , /* tp_traverse */
0 , /* tp_clear */
0 , /* tp_richcompare */
0 , /* tp_weaklistoffset */
0 , /* tp_iter */
0 , /* tp_iternext */
PySfFont_methods , /* tp_methods */
2009-02-26 20:36:06 +08:00
0 , /* tp_members */
2009-01-29 00:18:34 +08:00
0 , /* tp_getset */
0 , /* tp_base */
0 , /* tp_dict */
0 , /* tp_descr_get */
0 , /* tp_descr_set */
0 , /* tp_dictoffset */
( initproc ) PySfFont_init , /* tp_init */
0 , /* tp_alloc */
PySfFont_new , /* tp_new */
} ;
PySfFont *
GetNewPySfFont ( )
{
return ( PySfFont * ) PySfFont_new ( & PySfFontType , NULL , NULL ) ;
}