📄 djencabs.h
字号:
/* * * Copyright (C) 1997-2005, OFFIS * * This software and supporting documentation were developed by * * Kuratorium OFFIS e.V. * Healthcare Information and Communication Systems * Escherweg 2 * D-26121 Oldenburg, Germany * * THIS SOFTWARE IS MADE AVAILABLE, AS IS, AND OFFIS MAKES NO WARRANTY * REGARDING THE SOFTWARE, ITS PERFORMANCE, ITS MERCHANTABILITY OR * FITNESS FOR ANY PARTICULAR USE, FREEDOM FROM ANY COMPUTER DISEASES OR * ITS CONFORMITY TO ANY SPECIFICATION. THE ENTIRE RISK AS TO QUALITY AND * PERFORMANCE OF THE SOFTWARE IS WITH THE USER. * * Module: dcmjpeg * * Author: Norbert Olges, Marco Eichelberg * * Purpose: abstract base class for compression classes * * Last Update: $Author: meichel $ * Update Date: $Date: 2005/12/08 16:59:28 $ * Source File: $Source: /share/dicom/cvs-depot/dcmtk/dcmjpeg/include/dcmtk/dcmjpeg/djencabs.h,v $ * CVS/RCS Revision: $Revision: 1.2 $ * Status: $State: Exp $ * * CVS/RCS Log at end of file * */#ifndef DJENCABS_H#define DJENCABS_H#include "dcmtk/config/osconfig.h"#include "dcmtk/dcmdata/dctypes.h"#include "dcmtk/dcmimgle/diutils.h" /* for EP_Interpretation */#include "dcmtk/dcmjpeg/djutils.h" /* for enums *//** abstract base class for compression classes. */class DJEncoder{public: /// default constructor DJEncoder() { } /// destructor virtual ~DJEncoder() { } /** single frame compression routine for 16-bit raw pixel data. * May only be called if bytesPerSample() == 2. * @param columns columns of frame * @param rows rows of frame * @param interpr photometric interpretation of input frame * @param samplesPerPixel samples per pixel of input frame * @param image_buffer pointer to frame buffer * @param to compressed frame returned in this parameter upon success * @param length length of compressed frame (in bytes) returned in this parameter * upon success; length guaranteed to be always even. * @return EC_Normal if successful, an error code otherwise. */ virtual OFCondition encode( Uint16 columns, Uint16 rows, EP_Interpretation interpr, Uint16 samplesPerPixel, Uint16 *image_buffer, Uint8 *&to, Uint32 &length) = 0; /** single frame compression routine for 8-bit raw pixel data. * May only be called if bytesPerSample() == 1. * @param columns columns of frame * @param rows rows of frame * @param interpr photometric interpretation of input frame * @param samplesPerPixel samples per pixel of input frame * @param image_buffer pointer to frame buffer * @param to compressed frame returned in this parameter upon success * @param length length of compressed frame (in bytes) returned in this parameter * upon success; length guaranteed to be always even. * @return EC_Normal if successful, an error code otherwise. */ virtual OFCondition encode( Uint16 columns, Uint16 rows, EP_Interpretation interpr, Uint16 samplesPerPixel, Uint8 *image_buffer, Uint8 *&to, Uint32 &length) = 0; /** returns the number of bytes per sample that will be expected when encoding. */ virtual Uint16 bytesPerSample() const = 0; /** returns the number of bits per sample that will be expected when encoding. */ virtual Uint16 bitsPerSample() const = 0;};#endif/* * CVS/RCS Log * $Log: djencabs.h,v $ * Revision 1.2 2005/12/08 16:59:28 meichel * Changed include path schema for all DCMTK header files * * Revision 1.1 2001/11/13 15:56:25 meichel * Initial release of module dcmjpeg * * */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -