view Framework/Toolbox/MessagingToolbox.h @ 130:1982d6c1d2ff wasm

IVolumeLoader
author Sebastien Jodogne <s.jodogne@gmail.com>
date Thu, 16 Nov 2017 13:46:03 +0100
parents a4d0b6c82b29
children e2fe9352f240
line wrap: on
line source

/**
 * Stone of Orthanc
 * 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 "../Enumerations.h"

#include <Plugins/Samples/Common/IOrthancConnection.h>
#include <Plugins/Samples/Common/IDicomDataset.h>
#include <Core/Images/ImageAccessor.h>
#include <Core/DicomFormat/DicomMap.h>

#include <json/value.h>

namespace OrthancStone
{
  namespace MessagingToolbox
  {
    bool ParseJson(Json::Value& target,
                   const void* content,
                   size_t size);

    void RestApiGet(Json::Value& target,
                    OrthancPlugins::IOrthancConnection& orthanc,
                    const std::string& uri);

    void RestApiPost(Json::Value& target,
                     OrthancPlugins::IOrthancConnection& orthanc,
                     const std::string& uri,
                     const std::string& body);

    bool HasWebViewerInstalled(OrthancPlugins::IOrthancConnection& orthanc);

    bool CheckOrthancVersion(OrthancPlugins::IOrthancConnection& orthanc);

    // This downloads the image from Orthanc and keeps its pixel
    // format unchanged (will be either Grayscale8, Grayscale16,
    // SignedGrayscale16, or RGB24)
    Orthanc::ImageAccessor* DecodeFrame(OrthancPlugins::IOrthancConnection& orthanc,
                                        const std::string& instance,
                                        unsigned int frame,
                                        Orthanc::PixelFormat targetFormat);

    Orthanc::ImageAccessor* DecodeJpegFrame(OrthancPlugins::IOrthancConnection& orthanc,
                                            const std::string& instance,
                                            unsigned int frame,
                                            unsigned int quality,
                                            Orthanc::PixelFormat targetFormat);

    void ConvertDataset(Orthanc::DicomMap& target,
                        const OrthancPlugins::IDicomDataset& source);
  }
}