From 5994a6198ac35ea149a7211213dc296ee7406f44 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Wed, 25 May 2016 20:48:35 +0300 Subject: Move imageset load function from resourcemanager into separate file. --- src/resources/loaders/imagesetloader.cpp | 77 ++++++++++++++++++++++++++++++++ 1 file changed, 77 insertions(+) create mode 100644 src/resources/loaders/imagesetloader.cpp (limited to 'src/resources/loaders/imagesetloader.cpp') diff --git a/src/resources/loaders/imagesetloader.cpp b/src/resources/loaders/imagesetloader.cpp new file mode 100644 index 000000000..ad3868cc3 --- /dev/null +++ b/src/resources/loaders/imagesetloader.cpp @@ -0,0 +1,77 @@ +/* + * The ManaPlus Client + * Copyright (C) 2004-2009 The Mana World Development Team + * Copyright (C) 2009-2010 The Mana Developers + * Copyright (C) 2011-2016 The ManaPlus Developers + * + * This file is part of The ManaPlus 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 "logger.h" + +#include "resources/image.h" +#include "resources/imageset.h" + +#include "resources/loaders/imageloader.h" +#include "resources/loaders/imagesetloader.h" + +#include "resources/resourcemanager/resourcemanager.h" + +#include "utils/checkutils.h" +#include "utils/stringutils.h" + +#include "debug.h" + +struct ImageSetLoader final +{ + std::string path; + int w; + int h; + static Resource *load(const void *const v) + { + if (!v) + return nullptr; + + const ImageSetLoader *const + rl = static_cast(v); + + Image *const img = Loader::getImage(rl->path); + if (!img) + { + reportAlways("Image loading error: %s", rl->path.c_str()); + return nullptr; + } + ImageSet *const res = new ImageSet(img, rl->w, rl->h); + img->decRef(); + return res; + } +}; + +ImageSet *Loader::getImageSet(const std::string &imagePath, + const int w, + const int h) +{ + ImageSetLoader rl = { imagePath, w, h }; + const std::string str = std::string( + imagePath).append( + "[").append(toString( + w)).append( + "x").append(toString( + h)).append( + "]"); + return static_cast(resourceManager->get(str, + ImageSetLoader::load, &rl)); +} -- cgit v1.2.3-70-g09d2