view Framework/Deprecated/Toolbox/MessagingToolbox.h @ 903:ef6e425dc79f am-dev

notes for AM build
author Alain Mazy <alain@mazy.be>
date Wed, 17 Jul 2019 15:33:07 +0200
parents 4fe4b221a31f
children 2d8ab34c8c91
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-2019 Osimis S.A., 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 "../../StoneEnumerations.h"

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

#include <json/value.h>

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

    void JsonToString(std::string& target,
                      const Json::Value& source);


    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);
  }
}