jp2.h 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177
  1. /*
  2. * Copyright (c) 2002-2007, Communications and Remote Sensing Laboratory, Universite catholique de Louvain (UCL), Belgium
  3. * Copyright (c) 2002-2007, Professor Benoit Macq
  4. * Copyright (c) 2002-2003, Yannick Verschueren
  5. * Copyright (c) 2005, Herve Drolon, FreeImage Team
  6. * All rights reserved.
  7. *
  8. * Redistribution and use in source and binary forms, with or without
  9. * modification, are permitted provided that the following conditions
  10. * are met:
  11. * 1. Redistributions of source code must retain the above copyright
  12. * notice, this list of conditions and the following disclaimer.
  13. * 2. Redistributions in binary form must reproduce the above copyright
  14. * notice, this list of conditions and the following disclaimer in the
  15. * documentation and/or other materials provided with the distribution.
  16. *
  17. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
  18. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
  19. * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
  20. * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
  21. * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  22. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  23. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  24. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  25. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  26. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  27. * POSSIBILITY OF SUCH DAMAGE.
  28. */
  29. #ifndef __JP2_H
  30. #define __JP2_H
  31. /**
  32. @file jp2.h
  33. @brief The JPEG-2000 file format Reader/Writer (JP2)
  34. */
  35. /** @defgroup JP2 JP2 - JPEG-2000 file format reader/writer */
  36. /*@{*/
  37. #define JPIP_JPIP 0x6a706970
  38. #define JP2_JP 0x6a502020 /**< JPEG 2000 signature box */
  39. #define JP2_FTYP 0x66747970 /**< File type box */
  40. #define JP2_JP2H 0x6a703268 /**< JP2 header box */
  41. #define JP2_IHDR 0x69686472 /**< Image header box */
  42. #define JP2_COLR 0x636f6c72 /**< Colour specification box */
  43. #define JP2_JP2C 0x6a703263 /**< Contiguous codestream box */
  44. #define JP2_URL 0x75726c20 /**< URL box */
  45. #define JP2_DBTL 0x6474626c /**< ??? */
  46. #define JP2_BPCC 0x62706363 /**< Bits per component box */
  47. #define JP2_JP2 0x6a703220 /**< File type fields */
  48. /* ----------------------------------------------------------------------- */
  49. /**
  50. JP2 component
  51. */
  52. typedef struct opj_jp2_comps {
  53. int depth;
  54. int sgnd;
  55. int bpcc;
  56. } opj_jp2_comps_t;
  57. /**
  58. JPEG-2000 file format reader/writer
  59. */
  60. typedef struct opj_jp2 {
  61. /** codec context */
  62. opj_common_ptr cinfo;
  63. /** handle to the J2K codec */
  64. opj_j2k_t *j2k;
  65. unsigned int w;
  66. unsigned int h;
  67. unsigned int numcomps;
  68. unsigned int bpc;
  69. unsigned int C;
  70. unsigned int UnkC;
  71. unsigned int IPR;
  72. unsigned int meth;
  73. unsigned int approx;
  74. unsigned int enumcs;
  75. unsigned int precedence;
  76. unsigned int brand;
  77. unsigned int minversion;
  78. unsigned int numcl;
  79. unsigned int *cl;
  80. opj_jp2_comps_t *comps;
  81. unsigned int j2k_codestream_offset;
  82. unsigned int j2k_codestream_length;
  83. } opj_jp2_t;
  84. /**
  85. JP2 Box
  86. */
  87. typedef struct opj_jp2_box {
  88. int length;
  89. int type;
  90. int init_pos;
  91. } opj_jp2_box_t;
  92. /** @name Exported functions */
  93. /*@{*/
  94. /* ----------------------------------------------------------------------- */
  95. /**
  96. Write the JP2H box - JP2 Header box (used in MJ2)
  97. @param jp2 JP2 handle
  98. @param cio Output buffer stream
  99. */
  100. void jp2_write_jp2h(opj_jp2_t *jp2, opj_cio_t *cio);
  101. /**
  102. Read the JP2H box - JP2 Header box (used in MJ2)
  103. @param jp2 JP2 handle
  104. @param cio Input buffer stream
  105. @return Returns true if successful, returns false otherwise
  106. */
  107. bool jp2_read_jp2h(opj_jp2_t *jp2, opj_cio_t *cio);
  108. /**
  109. Creates a JP2 decompression structure
  110. @param cinfo Codec context info
  111. @return Returns a handle to a JP2 decompressor if successful, returns NULL otherwise
  112. */
  113. opj_jp2_t* jp2_create_decompress(opj_common_ptr cinfo);
  114. /**
  115. Destroy a JP2 decompressor handle
  116. @param jp2 JP2 decompressor handle to destroy
  117. */
  118. void jp2_destroy_decompress(opj_jp2_t *jp2);
  119. /**
  120. Setup the decoder decoding parameters using user parameters.
  121. Decoding parameters are returned in jp2->j2k->cp.
  122. @param jp2 JP2 decompressor handle
  123. @param parameters decompression parameters
  124. */
  125. void jp2_setup_decoder(opj_jp2_t *jp2, opj_dparameters_t *parameters);
  126. /**
  127. Decode an image from a JPEG-2000 file stream
  128. @param jp2 JP2 decompressor handle
  129. @param cio Input buffer stream
  130. @param cstr_info Codestream information structure if required, NULL otherwise
  131. @return Returns a decoded image if successful, returns NULL otherwise
  132. */
  133. opj_image_t* opj_jp2_decode(opj_jp2_t *jp2, opj_cio_t *cio, opj_codestream_info_t *cstr_info);
  134. /**
  135. Creates a JP2 compression structure
  136. @param cinfo Codec context info
  137. @return Returns a handle to a JP2 compressor if successful, returns NULL otherwise
  138. */
  139. opj_jp2_t* jp2_create_compress(opj_common_ptr cinfo);
  140. /**
  141. Destroy a JP2 compressor handle
  142. @param jp2 JP2 compressor handle to destroy
  143. */
  144. void jp2_destroy_compress(opj_jp2_t *jp2);
  145. /**
  146. Setup the encoder parameters using the current image and using user parameters.
  147. Coding parameters are returned in jp2->j2k->cp.
  148. @param jp2 JP2 compressor handle
  149. @param parameters compression parameters
  150. @param image input filled image
  151. */
  152. void jp2_setup_encoder(opj_jp2_t *jp2, opj_cparameters_t *parameters, opj_image_t *image);
  153. /**
  154. Encode an image into a JPEG-2000 file stream
  155. @param jp2 JP2 compressor handle
  156. @param cio Output buffer stream
  157. @param image Image to encode
  158. @param cstr_info Codestream information structure if required, NULL otherwise
  159. @return Returns true if successful, returns false otherwise
  160. */
  161. bool opj_jp2_encode(opj_jp2_t *jp2, opj_cio_t *cio, opj_image_t *image, opj_codestream_info_t *cstr_info);
  162. /* ----------------------------------------------------------------------- */
  163. /*@}*/
  164. /*@}*/
  165. #endif /* __JP2_H */