IM: im_lib.h Source File

IM - An Imaging Tool

im_lib.h

Go to the documentation of this file.
00001 /** \file
00002  * \brief Library Management and Main Documentation
00003  *
00004  * See Copyright Notice in this file.
00005  * $Id: im_lib.h,v 1.2 2005/04/14 19:41:10 scuri Exp $
00006  */
00007 
00008 #ifndef __IM_LIB_H
00009 #define __IM_LIB_H
00010 
00011 #if defined(__cplusplus)
00012 extern "C" {
00013 #endif
00014 
00015       
00016 /** \defgroup lib Library Management
00017  * \ingroup util 
00018  * \par
00019  * Usefull definitions for about dialogs and 
00020  * for checking the compiled version with the linked version for dynamic libraries.
00021  * \par
00022  * See \ref im_lib.h
00023  * @{
00024  */
00025 #define IM_AUTHOR "Antonio Scuri"
00026 #define IM_COPYRIGHT  "Copyright (C) 1994-2005 Tecgraf/PUC-Rio and PETROBRAS S/A"
00027 #define IM_VERSION "3.0.4"
00028 #define IM_VERSION_DATE "2005/07/18"
00029 /** @} */
00030 
00031 /** Library release number used in the compilation time. \n
00032  * You can compare this with the value returned by \ref imVersionNumber.
00033  * \ingroup lib */
00034 #define IM_VERSION_NUMBER 300004
00035 
00036 /** Returns the library current version.
00037  * \ingroup lib */
00038 const char* imVersion(void);
00039 
00040 /** Returns the library current version release date.
00041  * \ingroup lib */
00042 const char* imVersionDate(void);
00043 
00044 /** Returns the library current version number.
00045  * \ingroup lib */
00046 int imVersionNumber(void);
00047 
00048 
00049 #if defined(__cplusplus)
00050 }
00051 #endif
00052 
00053 
00054 /*! \mainpage IM
00055  * <CENTER>
00056  * <H3> Image Representation, Storage, Capture and Processing </H3>
00057  * Tecgraf: Computer Graphics Technology Group, PUC-Rio, Brazil \n
00058  * http://www.tecgraf.puc-rio.br/im \n
00059  * mailto:[email protected]
00060  * </CENTER>
00061  *
00062  * \section over Overview
00063  * \par
00064  * IM is a toolkit for Digital Imaging. 
00065  * \par
00066  * It provides support for image capture, several image file formats and many image processing operations. 
00067  * \par
00068  * Image representation includes scientific data types (like IEEE floating point data) 
00069  * and attributes (or metadata like GeoTIFF and Exif tags).
00070  * Animation, video and volumes are supported as image sequences, 
00071  * but there is no digital audio support.
00072  * \par
00073  * The main goal of the library is to provide a simple API and abstraction
00074  * of images for scientific applications.
00075  * \par
00076  * The toolkit API is written in C. 
00077  * The core library source code is implemented in C++ and it is very portable, 
00078  * it can be compiled in Windows and UNIX with no modifications. 
00079  * New image processing operations can be implemented in C or in C++.
00080  * \par
00081  * IM is free software, can be used for public and commercial applications.
00082  * \par
00083  * This work was developed at Tecgraf/PUC-Rio 
00084  * by means of the partnership with PETROBRAS/CENPES.
00085  *
00086  * \section author Author
00087  * \par
00088  * Basic Software Group @ Tecgraf/PUC-Rio
00089  * - Antonio Scuri [email protected]
00090  *
00091  * \section copyright Copyright Notice
00092 \verbatim
00093 
00094 ****************************************************************************
00095 * Copyright (C) 1994-2004 Tecgraf/PUC-Rio and PETROBRAS S/A.               *
00096 * All rights reserved.                                                     *
00097 *                                                                          *
00098 * Permission is hereby granted, free of charge, to any person obtaining    *
00099 * a copy of this software and associated documentation files (the          *
00100 * "Software"), to deal in the Software without restriction, including      *
00101 * without limitation the rights to use, copy, modify, merge, publish,      *
00102 * distribute, sublicense, and/or sell copies of the Software, and to       *
00103 * permit persons to whom the Software is furnished to do so, subject to    *
00104 * the following conditions:                                                *
00105 *                                                                          *
00106 * The above copyright notice and this permission notice shall be           *
00107 * included in all copies or substantial portions of the Software.          *
00108 *                                                                          *
00109 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,          *
00110 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF       *
00111 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
00112 * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY     *
00113 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,     *
00114 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE        *
00115 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.                   *
00116 ****************************************************************************
00117 \endverbatim
00118  */
00119 
00120 
00121 /** \defgroup imagerep Image Representation
00122  * \par
00123  * See \ref im.h
00124  */
00125 
00126 
00127 /** \defgroup file Image Storage
00128  * \par
00129  * See \ref im.h
00130  */
00131 
00132 
00133 /** \defgroup format File Formats
00134  * \par
00135  * See \ref im.h
00136  *
00137  * Internal Predefined File Formats:
00138  * \li "BMP" - Windows Device Independent Bitmap
00139  * \li "PCX" - ZSoft Picture
00140  * \li "GIF" - Graphics Interchange Format
00141  * \li "TIFF" - Tagged Image File Format
00142  * \li "RAS" - Sun Raster File
00143  * \li "SGI" - Silicon Graphics Image File Format
00144  * \li "JPEG" - JPEG File Interchange Format
00145  * \li "LED" - IUP image in LED
00146  * \li "TGA" - Truevision Targa
00147  * \li "RAW" - RAW File
00148  * \li "PNM" - Netpbm Portable Image Map 
00149  * \li "ICO" - Windows Icon 
00150  * \li "PNG" - Portable Network Graphic Format 
00151  *
00152  * Other Supported File Formats:
00153  * \li "JP2" - JPEG-2000 JP2 File Format 
00154  * \li "AVI" - Windows Audio-Video Interleaved RIFF
00155  * \li "WMV" -  Windows Media Video Format
00156  *          
00157  * Some Known Compressions:
00158  * \li "NONE" - No Compression.
00159  * \li "RLE"  - Run Lenght Encoding.
00160  * \li "LZW"  - Lempel, Ziff and Welsh.
00161  * \li "JPEG" - Join Photographics Experts Group.
00162  * \li "DEFLATE" - LZ77 variation (ZIP)
00163  *          
00164  * \ingroup file */
00165 
00166  
00167 /* Library Names Convention
00168  *
00169  *   Global Functions and Types - "im[Object][Action]"  using first capitals (imFileOpen)
00170  *   Local Functions and Types  -  "i[Object][Action]"  using first capitals (iTIFFGetCompIndex)
00171  *   Local Static Variables - same as local functions and types (iFormatCount)
00172  *   Local Static Tables - same as local functions and types with "Table" suffix (iTIFFCompTable)
00173  *   Variables and Members - no prefix, all lower case (width)
00174  *   Defines and Enumerations - all capitals (IM_ERR_NONE)
00175  *
00176  */
00177 
00178 
00179 #endif