Mercurial > hg > orthanc-wsi
view Framework/Inputs/OpenSlideLibrary.h @ 100:16b8e1cc9bbf
Fix issue #30: Bad colorspace if using OpenSlide
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Fri, 20 Jan 2017 13:15:05 +0100 |
parents | ff0ef01c332c |
children | a51dee6a1515 |
line wrap: on
line source
/** * Orthanc - A Lightweight, RESTful DICOM Store * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics * Department, University Hospital of Liege, Belgium * Copyright (C) 2017 Osimis, Belgium * * This program is free software: you can redistribute it and/or * modify it under the terms of the GNU Affero General Public License * as published by the Free Software Foundation, either version 3 of * the License, 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 * Affero General Public License for more details. * * You should have received a copy of the GNU Affero General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. **/ #pragma once #include "../../Resources/Orthanc/Plugins/Engine/SharedLibrary.h" #include "../../Resources/Orthanc/Core/Images/ImageAccessor.h" #include <vector> namespace OrthancWSI { class OpenSlideLibrary : public boost::noncopyable { private: typedef void* (*FunctionClose) (void*); typedef int32_t (*FunctionGetLevelCount) (void*); typedef void (*FunctionGetLevelDimensions) (void*, int32_t, int64_t*, int64_t*); typedef double (*FunctionGetLevelDownsample) (void*, int32_t); typedef void* (*FunctionOpen) (const char*); typedef void (*FunctionReadRegion) (void*, uint32_t*, int64_t, int64_t, int32_t, int64_t, int64_t); Orthanc::SharedLibrary library_; FunctionClose close_; FunctionGetLevelCount getLevelCount_; FunctionGetLevelDimensions getLevelDimensions_; FunctionGetLevelDownsample getLevelDownsample_; FunctionOpen open_; FunctionReadRegion readRegion_; public: OpenSlideLibrary(const std::string& path); static OpenSlideLibrary& GetInstance(); static void Initialize(const std::string& path); static void Finalize(); class Image : public boost::noncopyable { private: struct Level { unsigned int width_; unsigned int height_; double downsample_; Level(); Level(int64_t width, int64_t height, double downsample); }; OpenSlideLibrary& that_; void* handle_; std::vector<Level> levels_; void Initialize(const std::string& path); void Close(); void CheckLevel(unsigned int level) const; public: Image(OpenSlideLibrary& that, const std::string& path); Image(const std::string& path); ~Image() { Close(); } unsigned int GetLevelCount() const { return levels_.size(); } double GetLevelDownsample(unsigned int level) const; unsigned int GetLevelWidth(unsigned int level) const; unsigned int GetLevelHeight(unsigned int level) const; Orthanc::ImageAccessor* ReadRegion(unsigned int level, uint64_t x, uint64_t y, unsigned int width, unsigned int height); }; }; }