Mercurial > hg > orthanc-wsi
view Framework/Algorithms/TranscodeTileCommand.cpp @ 110:7e45d8856495
"--max-size=0" allowed to create a single instance per pyramid level
author | Sebastien Jodogne <s.jodogne@gmail.com> |
---|---|
date | Thu, 24 Aug 2017 17:43:47 +0200 |
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/>. **/ #include "../PrecompiledHeadersWSI.h" #include "TranscodeTileCommand.h" #include "../../Resources/Orthanc/Core/OrthancException.h" #include "../../Resources/Orthanc/Core/Logging.h" #include <cassert> namespace OrthancWSI { TranscodeTileCommand::TranscodeTileCommand(IPyramidWriter& target, ITiledPyramid& source, unsigned int level, unsigned int x, unsigned int y, unsigned int countTilesX, unsigned int countTilesY, const DicomizerParameters& parameters) : target_(target), source_(source, level, target.GetTileWidth(), target.GetTileHeight(), parameters), level_(level), x_(x), y_(y), countTilesX_(countTilesX), countTilesY_(countTilesY) { assert(x_ + countTilesX_ <= target_.GetCountTilesX(level_) && y_ + countTilesY_ <= target_.GetCountTilesY(level_)); if (target.GetPixelFormat() != source.GetPixelFormat()) { throw Orthanc::OrthancException(Orthanc::ErrorCode_IncompatibleImageFormat); } } bool TranscodeTileCommand::Execute() { for (unsigned int x = x_; x < x_ + countTilesX_; x++) { for (unsigned int y = y_; y < y_ + countTilesY_; y++) { LOG(INFO) << "Adding tile (" << x << "," << y << ") at level " << level_; ImageCompression compression; const std::string* rawTile = source_.GetRawTile(compression, x, y); if (rawTile != NULL) { // Simple transcoding target_.WriteRawTile(*rawTile, compression, level_, x, y); } else { Orthanc::ImageAccessor tile = source_.GetDecodedTile(x, y); // Re-encoding the file target_.EncodeTile(tile, level_, x, y); } } } return true; } void TranscodeTileCommand::PrepareBagOfTasks(Orthanc::BagOfTasks& tasks, IPyramidWriter& target, ITiledPyramid& source, const DicomizerParameters& parameters) { const unsigned int stepX = source.GetTileWidth() / target.GetTileWidth(); const unsigned int stepY = source.GetTileHeight() / target.GetTileHeight(); assert(stepX >= 1 && stepY >= 1); for (unsigned int level = 0; level < source.GetLevelCount(); level++) { const unsigned int targetCountTilesX = target.GetCountTilesX(level); const unsigned int targetCountTilesY = target.GetCountTilesY(level); for (unsigned int y = 0; y < targetCountTilesY; y += stepY) { unsigned int cy = stepY; if (y + cy > targetCountTilesY) { cy = targetCountTilesY - y; } for (unsigned int x = 0; x < targetCountTilesX; x += stepX) { unsigned int cx = stepX; if (x + cx > targetCountTilesX) { cx = targetCountTilesX - x; } tasks.Push(new TranscodeTileCommand (target, source, level, x, y, cx, cy, parameters)); } } } } }