/* * The Mana Client * Copyright (C) 2008-2009 The Mana World Development Team * Copyright (C) 2009-2012 The Mana Developers * * This file is part of The Mana Client. * * 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 2 of the License, or * 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, see . */ #include #include #include #include "dye.h" #include "imagewriter.h" using namespace std; // return values enum ReturnValues { RETURN_OK = 0, INVALID_PARAMETER_LIST = 100, INVALID_INPUT_IMAGE = 101, INVALID_OUTPUT_IMAGE = 102, INVALID_DYE_PARAMETER = 105 }; SDL_Surface* recolor(SDL_Surface* tmpImage, Dye* dye) { SDL_PixelFormat rgba; rgba.palette = NULL; rgba.BitsPerPixel = 32; rgba.BytesPerPixel = 4; rgba.Rmask = 0xFF000000; rgba.Rloss = 0; rgba.Rshift = 24; rgba.Gmask = 0x00FF0000; rgba.Gloss = 0; rgba.Gshift = 16; rgba.Bmask = 0x0000FF00; rgba.Bloss = 0; rgba.Bshift = 8; rgba.Amask = 0x000000FF; rgba.Aloss = 0; rgba.Ashift = 0; rgba.colorkey = 0; rgba.alpha = 255; SDL_Surface *surf = SDL_ConvertSurface(tmpImage, &rgba, SDL_SWSURFACE); //SDL_FreeSurface(tmpImage); <-- We'll free the surface later. Uint32 *pixels = static_cast< Uint32 * >(surf->pixels); for (Uint32 *p_end = pixels + surf->w * surf->h; pixels != p_end; ++pixels) { int alpha = (*pixels >> rgba.Ashift) & 255; if (!alpha) continue; int v[3]; v[0] = (*pixels >> rgba.Rshift) & 255; v[1] = (*pixels >> rgba.Gshift) & 255; v[2] = (*pixels >> rgba.Bshift) & 255; dye->update(v); #if SDL_BYTEORDER == SDL_BIG_ENDIAN *pixels = (v[0] << 24) | (v[1] << 16) | (v[2] << 8) | alpha; #else *pixels = v[0] | (v[1] << 8) | (v[2] << 16) | (alpha << 24); #endif } return surf; } void printHelp() { cout << endl << "This tool is used to dye item graphics used by the Mana client " << "according to the specification described here: " << endl << "http://doc.manasource.org/image_dyeing_system" << endl << endl << "The tool expects 3 parameters:" << endl << "dyecmd " << endl << "e.g.:" << endl << "dyecmd \"armor-legs-shorts.png\" " <<"\"armor-legs-shorts2.png\" \"W:#222255,6666ff\"" << std::endl; } int main(int argc, char* argv[]) { Dye* dye = NULL; SDL_Surface* source = NULL, *target = NULL; ReturnValues returnValue = RETURN_OK; if (argc > 1 && (!strcmp(argv[1], "--help") || !strcmp(argv[1], "-h"))) { printHelp(); } // not enough or to many parameters else if (argc != 4) { cout << INVALID_PARAMETER_LIST << " - INVALID_PARAMETER_LIST"; printHelp(); returnValue = INVALID_PARAMETER_LIST; } else { // Start dyeing process. string inputFile = argv[1]; string outputFile = argv[2]; string dyeDescription = argv[3]; dye = new Dye(dyeDescription); if (!dye->loaded()) { cout << INVALID_DYE_PARAMETER << " - INVALID_DYE_PARAMETER"; printHelp(); returnValue = INVALID_DYE_PARAMETER; } else { source = IMG_Load(inputFile.c_str()); if (!source) { cout << INVALID_INPUT_IMAGE << " - INVALID_INPUT_IMAGE"; printHelp(); returnValue = INVALID_INPUT_IMAGE; } else { target = recolor(source, dye); if (!ImageWriter::writePNG(target, outputFile)) { cout << INVALID_OUTPUT_IMAGE << " - INVALID_OUTPUT_IMAGE"; printHelp(); returnValue = INVALID_OUTPUT_IMAGE; } } // Valid source image file } // Valid dye parameter } // Parameters ok if (source) SDL_FreeSurface(source); if (target) SDL_FreeSurface(target); if (dye) delete dye; return returnValue; }