/* * * Copyright (C) 2001-2017, OFFIS e.V. * All rights reserved. See COPYRIGHT file for details. * * This software and supporting documentation were developed by * * OFFIS e.V. * R&D Division Health * Escherweg 2 * D-26121 Oldenburg, Germany * * * Module: dcmjpeg * * Author: Marco Eichelberg, Norbert Olges * * Purpose: Codec class for decoding JPEG Extended Sequential (lossy, 8/12-bit) * */ #include "dcmtk/config/osconfig.h" #include "dcmtk/dcmjpeg/djdecext.h" #include "dcmtk/dcmjpeg/djcparam.h" #include "dcmtk/dcmjpeg/djrploss.h" #include "dcmtk/dcmjpeg/djdijg8.h" #include "dcmtk/dcmjpeg/djdijg12.h" DJDecoderExtended::DJDecoderExtended() : DJCodecDecoder() { } DJDecoderExtended::~DJDecoderExtended() { } E_TransferSyntax DJDecoderExtended::supportedTransferSyntax() const { return EXS_JPEGProcess2_4; } OFBool DJDecoderExtended::isLosslessProcess() const { return OFFalse; } DJDecoder *DJDecoderExtended::createDecoderInstance( const DcmRepresentationParameter * /* toRepParam */, const DJCodecParameter *cp, Uint8 bitsPerSample, OFBool isYBR) const { if (bitsPerSample > 8) return new DJDecompressIJG12Bit(*cp, isYBR); else return new DJDecompressIJG8Bit(*cp, isYBR); }