{ "flashRate", ArgInt, (void *) &appData.flashRate, XBOARD, (ArgIniType) FLASH_RATE },
{ "pngDirectory", ArgFilename, (void *) &appData.pngDirectory, XBOARD, (ArgIniType) "" },
{ "png", ArgFilename, (void *) &appData.pngDirectory, FALSE, INVALID },
+ { "svgDirectory", ArgFilename, (void *) &appData.svgDirectory, XBOARD, (ArgIniType) "" },
+ { "svg", ArgFilename, (void *) &appData.svgDirectory, FALSE, INVALID },
{ "soundDirectory", ArgFilename, (void *) &appData.soundDirectory, XBOARD, (ArgIniType) "" },
{ "msLoginDelay", ArgInt, (void *) &appData.msLoginDelay, XBOARD, (ArgIniType) MS_LOGIN_DELAY },
{ "pasteSelection", ArgBoolean, (void *) &appData.pasteSelection, XBOARD, (ArgIniType) FALSE },
Boolean noChessProgram;
char *host[ENGINES];
char *pngDirectory;
+ char *svgDirectory;
char *soundDirectory;
char *remoteShell;
char *remoteUser;
static void AdjustColor P((int i));
static char oldPngDir[MSG_SIZ];
+static char oldSvgDir[MSG_SIZ];
static int
BoardOptionsOK (int n)
{
if(appData.overrideLineGap >= 0) lineGap = appData.overrideLineGap; else lineGap = defaultLineGap;
- InitDrawingParams(strcmp(oldPngDir, appData.pngDirectory));
+ InitDrawingParams(strcmp(oldPngDir, appData.pngDirectory) || strcmp(oldSvgDir, appData.svgDirectory));
InitDrawingSizes(-1, 0);
DrawPosition(True, NULL);
return 1;
{ 0, 0, 0, NULL, (void*) &appData.liteBackTextureFile, ".xpm", NULL, FileName, N_("Light-Squares Texture File:") },
{ 0, 0, 0, NULL, (void*) &appData.darkBackTextureFile, ".xpm", NULL, FileName, N_("Dark-Squares Texture File:") },
{ 0, 0, 0, NULL, (void*) &appData.pngDirectory, "", NULL, PathName, N_("Directory with PNG Pieces:") },
+{ 0, 0, 0, NULL, (void*) &appData.svgDirectory, "", NULL, PathName, N_("Directory with SVG Pieces:") },
{ 0, 0, 0, NULL, (void*) &BoardOptionsOK, "", NULL, EndMark , "" }
};
BoardOptionsProc ()
{
strncpy(oldPngDir, appData.pngDirectory, MSG_SIZ-1); // to see if it changed
+ strncpy(oldSvgDir, appData.svgDirectory, MSG_SIZ-1); // to see if it changed
GenericPopUp(boardOptions, _("Board Options"), TransientDlg, BoardWindow, MODAL, 0);
}
GError **svgerror=NULL;
cairo_surface_t *img, *cs;
cairo_t *cr;
- int stride = squareSize * 4;
- double scale;
g_type_init ();
- if((img = pngPieceImages[color][piece]) == NULL) { // if PNG file for this piece was not yet read, read it now and store it
- if(!*appData.pngDirectory) img = ConvertPixmap(color, piece); else {
- snprintf(buf, MSG_SIZ, "%s/%s%s.svg", appData.pngDirectory, color ? "Black" : "White", pngPieceNames[piece]);
+ if(*appData.svgDirectory) { // try to freshly render svg pieces first, always from file, to supply the source bitmap
+ snprintf(buf, MSG_SIZ, "%s/%s%s.svg", appData.svgDirectory, color ? "Black" : "White", pngPieceNames[piece]);
- svg = rsvg_handle_new ();
- svg = rsvg_handle_new_from_file(buf,svgerror);
+ if(svg = rsvg_handle_new_from_file(buf,svgerror)) {
rsvg_handle_get_dimensions(svg, &svg_dimensions);
+ img = cairo_image_surface_create(CAIRO_FORMAT_ARGB32, squareSize, squareSize);
- unsigned char* cairo_data =(unsigned char *) calloc(stride * squareSize, 1);
- img = cairo_image_surface_create_for_data(cairo_data, CAIRO_FORMAT_ARGB32, squareSize, squareSize, stride);
-
- cairo_t *cr_svg = cairo_create(img);
+ cr = cairo_create(img);
+ cairo_scale(cr, squareSize/(double) svg_dimensions.width, squareSize/(double) svg_dimensions.height);
+ rsvg_handle_render_cairo(svg, cr);
+ if(cairo_surface_status(img) == CAIRO_STATUS_SUCCESS) {
+ if(pngPieceImages[color][piece]) cairo_surface_destroy(pngPieceImages[color][piece]);
+ pngPieceImages[color][piece] = img;
+ }
+ cairo_destroy(cr);
- scale = (double) squareSize/(double) svg_dimensions.height;
- cairo_scale(cr_svg, scale,scale);
- cairo_set_antialias (cr_svg, CAIRO_ANTIALIAS_NONE);
- rsvg_handle_render_cairo(svg, cr_svg);
+ rsvg_handle_close (svg,NULL);
+ }
+ }
+ if((img = pngPieceImages[color][piece]) == NULL) { // if PNG file for this piece was not yet read, read it now and store it
+ if(!*appData.pngDirectory) img = ConvertPixmap(color, piece); else {
+ snprintf(buf, MSG_SIZ, "%s/%s%s.png", appData.pngDirectory, color ? "Black" : "White", pngPieceNames[piece]);
+ img = cairo_image_surface_create_from_png (buf);
if(cairo_surface_status(img) != CAIRO_STATUS_SUCCESS) img = ConvertPixmap(color, piece);
-
- rsvg_handle_close (svg,NULL);
}
}
pngPieceImages[color][piece] = img;