view Sphinx/source/plugins/webviewer.rst @ 748:a296fe06fd86

Implementing a custom storage area in Python
author Sebastien Jodogne <s.jodogne@gmail.com>
date Thu, 12 Aug 2021 17:51:54 +0200
parents d3d0696c2258
children 525d59a7c198
line wrap: on
line source

.. _webviewer:


Orthanc Web Viewer plugin
=========================

.. contents::

This **official** plugin extends Orthanc with a Web viewer of medical images.

For general information, check out the `official homepage of the
plugin <https://www.orthanc-server.com/static.php?page=web-viewer>`__.


Compilation
-----------

.. highlight:: bash

The procedure to compile this plugin is similar of that for the
:ref:`core of Orthanc <binaries>`. The following commands should work
for every UNIX-like distribution (including GNU/Linux)::

  $ mkdir Build
  $ cd Build
  $ cmake .. -DSTATIC_BUILD=ON -DCMAKE_BUILD_TYPE=Release
  $ make

The compilation will produce a shared library ``OrthancWebViewer``
that contains the Web viewer plugin.  Pre-compiled binaries for
Microsoft Windows `are also available
<https://www.orthanc-server.com/browse.php?path=/plugin-webviewer>`__.

*Remark:* Some older build instructions are also available in the
`source distribution
<https://hg.orthanc-server.com/orthanc-webviewer/file/default/Resources/BuildInstructions.txt>`__.


Usage
-----

.. highlight:: json

You of course first have to :ref:`install Orthanc <compiling>`. Once
Orthanc is installed, you must change the :ref:`configuration file
<configuration>` to tell Orthanc where it can find the plugin: This is
done by properly modifying the ``Plugins`` option. You could for
instance use the following configuration file::

  {
    "Name" : "MyOrthanc",
    [...]
    "Plugins" : [
      "/home/user/OrthancWebViewer/Build/libOrthancWebViewer.so"
    ]
  }

.. highlight:: text

Orthanc must of course be restarted after the modification of its
configuration file. The log will contain an output similar to::

  # Orthanc ./Configuration.json 
  W0226 16:59:10.480226  7906 main.cpp:636] Orthanc version: mainline
  [...]
  W0226 16:59:10.519664  7906 PluginsManager.cpp:258] Registering plugin 'web-viewer' (version 1.0)
  W0226 16:59:10.519696  7906 PluginsManager.cpp:148] Initializing the Web viewer
  W0226 16:59:10.520004  7906 PluginsManager.cpp:148] Web viewer using 6 threads for the decoding of the DICOM images
  W0226 16:59:10.520021  7906 PluginsManager.cpp:148] Storing the cache of the Web viewer in folder: OrthancStorage/WebViewerCache
  W0226 16:59:10.522011  7906 PluginsManager.cpp:148] Web viewer using a cache of 100 MB
  [...]
  W0226 16:59:10.530807  7906 main.cpp:516] HTTP server listening on port: 8042
  W0226 16:59:10.581029  7906 main.cpp:526] DICOM server listening on port: 4242
  W0226 16:59:10.581066  7906 main.cpp:533] Orthanc has started

Once a :ref:`DICOM series <model-world>` is opened using Orthanc
Explorer, a yellow button entitled ``Orthanc Web Viewer`` will show
up. It will open the Web viewer for that particular series.  See also
the demonstration video on `official homepage of the plugin
<https://www.orthanc-server.com/static.php?page=web-viewer>`__.


Advanced options
----------------

.. highlight:: json

The configuration of the Web viewer can be fine-tuned by adding some options::

  {
    "Name" : "MyOrthanc",
    [...]
    "Plugins" : [
      "/home/user/OrthancWebViewer/Build/libOrthancWebViewer.so"
    ],
    "WebViewer" : {
      "CachePath" : "WebViewerCache",
      "CacheSize" : 10,
      "Threads" : 4
    }
  }

* ``CachePath`` specifies the location of the cache of the Web
  viewer. By default, the cache is located inside the storage
  directory of Orthanc.
* ``CacheSize`` specifies the maximum size for the cached images, in
  megabytes. By default, a cache of 100 MB is used.
* ``Threads`` specifies the number of threads that are used by the
  plugin to decode the DICOM images.


Old advanced options (up to 2.5)
--------------------------------

Up to release 2.5 of the Orthanc Web Viewer plugin, the plugin was
shipping a decoder of DICOM images using the GDCM library. In May
2020, the support of GDCM has been :ref:`moved as a separate plugin
<gdcm>`. As a consequence, releases <= 2.5 had two more advanced
options, that were removed starting with version 2.6:
  
* ``EnableGdcm`` specified whether `GDCM
  <https://sourceforge.net/projects/gdcm/>`__ should be used to decode
  DICOM images, replacing the built-in decoder of Orthanc that
  internally uses `DCMTK <https://dicom.offis.de/dcmtk.php.en>`__.
  This was notably necessary to deal with DICOM images encoded using
  `JPEG2000 <https://en.wikipedia.org/wiki/JPEG_2000>`__, as this
  format is not readily supported by the core version of DCMTK. By
  default, this option was set to ``true``.

* As a complement to the ``EnableGdcm`` option, it was also possible
  to restrict the GDCM decoder to some specific `transfer syntaxes
  <http://dicom.nema.org/medical/dicom/current/output/html/part05.html#chapter_10>`__
  using the ``RestrictTransferSyntaxes`` option.

  
.. highlight:: json

For instance, the following configuration would enable GDCM to decode
JPEG 2000 images, while using DCMTK to decode the other transfer
syntaxes::

  {
    [...]
    "WebViewer" : {
      "EnableGdcm" : true,
      "RestrictTransferSyntaxes" : [
        "1.2.840.10008.1.2.4.90",   // JPEG 2000 Image Compression (Lossless Only)	 
        "1.2.840.10008.1.2.4.91",   // JPEG 2000 Image Compression 	 
        "1.2.840.10008.1.2.4.92",   // JPEG 2000 Part 2 Multicomponent Image Compression (Lossless Only)
        "1.2.840.10008.1.2.4.93"    // JPEG 2000 Part 2 Multicomponent Image Compression
      ]
    }
  }


Frequently Asked Questions
--------------------------

* If **Orthanc does not start anymore** after a hard shutdown, this
  might reflect a corruption in the cache of the Web viewer. In such a
  case, it is safe to remove the folder that contains the cache. By
  default, this folder is called
  ``OrthancStorage/WebViewerCache/``. Of course, don't remove the
  folder ``OrthancStorage/``, as it contains the DICOM files.