OHIF / Viewers

OHIF zero-footprint DICOM viewer and oncology specific Lesion Tracker, plus shared extension packages
https://docs.ohif.org/
MIT License
3.37k stars 3.39k forks source link
cancer-imaging-research dicom dicom-viewer hacktoberfest healthcare-imaging image-analysis imaging imaging-informatics javascript medical medical-image-processing medical-imaging nci-itcr nci-qin quantitative-imaging reactjs

OHIF Medical Imaging Viewer

The OHIF Viewer is a zero-footprint medical image viewer provided by the Open Health Imaging Foundation (OHIF). It is a configurable and extensible progressive web application with out-of-the-box support for image archives which support DICOMweb.

Read The Docs
Live Demo | Component Library
πŸ“° Join OHIF Newsletter πŸ“°
πŸ“° Join OHIF Newsletter πŸ“°

NPM version MIT License This project is using Percy.io for visual regression testing.

Measurement tracking Measurement Tracking Demo
Segmentations Labelmap Segmentations Demo
Hanging Protocols Fusion and Custom Hanging protocols Demo
Volume Rendering Volume Rendering Demo
PDF PDF Demo
RTSTRUCT RT STRUCT Demo
4D 4D Demo
VIDEO Video Demo
microscopy Slide Microscopy Demo

About

The OHIF Viewer can retrieve and load images from most sources and formats; render sets in 2D, 3D, and reconstructed representations; allows for the manipulation, annotation, and serialization of observations; supports internationalization, OpenID Connect, offline use, hotkeys, and many more features.

Almost everything offers some degree of customization and configuration. If it doesn't support something you need, we accept pull requests and have an ever improving Extension System.

Why Choose Us

Community & Experience

The OHIF Viewer is a collaborative effort that has served as the basis for many active, production, and FDA Cleared medical imaging viewers. It benefits from our extensive community's collective experience, and from the sponsored contributions of individuals, research groups, and commercial organizations.

Built to Adapt

After more than 8-years of integrating with many companies and organizations, The OHIF Viewer has been rebuilt from the ground up to better address the varying workflow and configuration needs of its many users. All of the Viewer's core features are built using it's own extension system. The same extensibility that allows us to offer:

Can be leveraged by you to customize the viewer for your workflow, and to add any new functionality you may need (and wish to maintain privately without forking).

Support

For commercial support, academic collaborations, and answers to common questions; please use Get Support to contact us.

Developing

Branches

master branch - The latest dev (beta) release

This is typically where the latest development happens. Code that is in the master branch has passed code reviews and automated tests, but it may not be deemed ready for production. This branch usually contains the most recent changes and features being worked on by the development team. It's often the starting point for creating feature branches (where new features are developed) and hotfix branches (for urgent fixes).

Each package is tagged with beta version numbers, and published to npm such as @ohif/ui@3.6.0-beta.1

release/* branches - The latest stable releases

Once the master branch code reaches a stable, release-ready state, we conduct a comprehensive code review and QA testing. Upon approval, we create a new release branch from master. These branches represent the latest stable version considered ready for production.

For example, release/3.5 is the branch for version 3.5.0, and release/3.6 is for version 3.6.0. After each release, we wait a few days to ensure no critical bugs. If any are found, we fix them in the release branch and create a new release with a minor version bump, e.g., 3.5.1 in the release/3.5 branch.

Each package is tagged with version numbers and published to npm, such as @ohif/ui@3.5.0. Note that master is always ahead of the release branch. We publish docker builds for both beta and stable releases.

Here is a schematic representation of our development workflow:

alt text

Requirements

Getting Started

  1. Fork this repository
  2. Clone your forked repository
    • git clone https://github.com/YOUR-USERNAME/Viewers.git
  3. Navigate to the cloned project's directory
  4. Add this repo as a remote named upstream
    • git remote add upstream https://github.com/OHIF/Viewers.git
  5. yarn install to restore dependencies and link projects

To Develop

From this repository's root directory:

# Enable Yarn Workspaces
yarn config set workspaces-experimental true

# Restore dependencies
yarn install

Commands

These commands are available from the root directory. Each project directory also supports a number of commands that can be found in their respective README.md and package.json files.

Yarn Commands Description
Develop
dev or start Default development experience for Viewer
test:unit Jest multi-project test runner; overall coverage
Deploy
build* Builds production output for our PWA Viewer

* - For more information on different builds, check out our Deploy Docs

Project

The OHIF Medical Image Viewing Platform is maintained as a monorepo. This means that this repository, instead of containing a single project, contains many projects. If you explore our project structure, you'll see the following:

.
β”œβ”€β”€ extensions               #
β”‚   β”œβ”€β”€ _example             # Skeleton of example extension
β”‚   β”œβ”€β”€ default              # basic set of useful functionalities (datasources, panels, etc)
β”‚   β”œβ”€β”€ cornerstone       # image rendering and tools w/ Cornerstone3D
β”‚   β”œβ”€β”€ cornerstone-dicom-sr # DICOM Structured Report rendering and export
β”‚   β”œβ”€β”€ cornerstone-dicom-sr # DICOM Structured Report rendering and export
β”‚   β”œβ”€β”€ cornerstone-dicom-seg # DICOM Segmentation rendering and export
β”‚   β”œβ”€β”€ cornerstone-dicom-rt # DICOM RTSTRUCT rendering
β”‚   β”œβ”€β”€ cornerstone-microscopy # Whole Slide Microscopy rendering
β”‚   β”œβ”€β”€ dicom-pdf # PDF rendering
β”‚   β”œβ”€β”€ dicom-video # DICOM RESTful Services
β”‚   β”œβ”€β”€ measurement-tracking # Longitudinal measurement tracking
β”‚   β”œβ”€β”€ tmtv # Total Metabolic Tumor Volume (TMTV) calculation
|

β”‚
β”œβ”€β”€ modes                    #
β”‚   β”œβ”€β”€ _example             # Skeleton of example mode
β”‚   β”œβ”€β”€ basic-dev-mode       # Basic development mode
β”‚   β”œβ”€β”€ longitudinal         # Longitudinal mode (measurement tracking)
β”‚   β”œβ”€β”€ tmtv       # Total Metabolic Tumor Volume (TMTV) calculation mode
β”‚   └── microscopy          # Whole Slide Microscopy mode
β”‚
β”œβ”€β”€ platform                 #
β”‚   β”œβ”€β”€ core                 # Business Logic
β”‚   β”œβ”€β”€ i18n                 # Internationalization Support
β”‚   β”œβ”€β”€ ui                   # React component library
β”‚   β”œβ”€β”€ docs                 # Documentation
β”‚   └── viewer               # Connects platform and extension projects
β”‚
β”œβ”€β”€ ...                      # misc. shared configuration
β”œβ”€β”€ lerna.json               # MonoRepo (Lerna) settings
β”œβ”€β”€ package.json             # Shared devDependencies and commands
└── README.md                # This file

Acknowledgments

To acknowledge the OHIF Viewer in an academic publication, please cite

Open Health Imaging Foundation Viewer: An Extensible Open-Source Framework for Building Web-Based Imaging Applications to Support Cancer Research

Erik Ziegler, Trinity Urban, Danny Brown, James Petts, Steve D. Pieper, Rob Lewis, Chris Hafey, and Gordon J. Harris

JCO Clinical Cancer Informatics, no. 4 (2020), 336-345, DOI: 10.1200/CCI.19.00131

Open-Access on Pubmed Central: https://www.ncbi.nlm.nih.gov/pmc/articles/PMC7259879/

or, for v1, please cite:

LesionTracker: Extensible Open-Source Zero-Footprint Web Viewer for Cancer Imaging Research and Clinical Trials

Trinity Urban, Erik Ziegler, Rob Lewis, Chris Hafey, Cheryl Sadow, Annick D. Van den Abbeele and Gordon J. Harris

Cancer Research, November 1 2017 (77) (21) e119-e122 DOI: 10.1158/0008-5472.CAN-17-0334

Note: If you use or find this repository helpful, please take the time to star this repository on GitHub. This is an easy way for us to assess adoption and it can help us obtain future funding for the project.

This work is supported primarily by the National Institutes of Health, National Cancer Institute, Informatics Technology for Cancer Research (ITCR) program, under a grant to Dr. Gordon Harris at Massachusetts General Hospital (U24 CA199460).

NCI Imaging Data Commons (IDC) project supported the development of new features and bug fixes marked with "IDC:priority", "IDC:candidate" or "IDC:collaboration". NCI Imaging Data Commons is supported by contract number 19X037Q from Leidos Biomedical Research under Task Order HHSN26100071 from NCI. IDC Viewer is a customized version of the OHIF Viewer.

This project is tested with BrowserStack. Thank you for supporting open-source!

License

MIT Β© OHIF

FOSSA Status