openjp3d: Convert ISO-8859 to UTF-8
[openjpeg.git] / src / lib / openjp3d / t2.h
1 /*
2  * The copyright in this software is being made available under the 2-clauses
3  * BSD License, included below. This software may be subject to other third
4  * party and contributor rights, including patent rights, and no such rights
5  * are granted under this license.
6  *
7  * Copyright (c) 2001-2003, David Janssens
8  * Copyright (c) 2002-2003, Yannick Verschueren
9  * Copyright (c) 2003-2005, Francois Devaux and Antonin Descampe
10  * Copyright (c) 2005, Herve Drolon, FreeImage Team
11  * Copyright (c) 2002-2005, Communications and remote sensing Laboratory, Universite catholique de Louvain, Belgium
12  * Copyright (c) 2006, Mónica Díez García, Image Processing Laboratory, University of Valladolid, Spain
13  * All rights reserved.
14  *
15  * Redistribution and use in source and binary forms, with or without
16  * modification, are permitted provided that the following conditions
17  * are met:
18  * 1. Redistributions of source code must retain the above copyright
19  *    notice, this list of conditions and the following disclaimer.
20  * 2. Redistributions in binary form must reproduce the above copyright
21  *    notice, this list of conditions and the following disclaimer in the
22  *    documentation and/or other materials provided with the distribution.
23  *
24  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS `AS IS'
25  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
26  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
27  * ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
28  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
29  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
30  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
31  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
32  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
33  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
34  * POSSIBILITY OF SUCH DAMAGE.
35  */
36 #ifndef __T2_H
37 #define __T2_H
38 /**
39 @file t2.h
40 @brief Implementation of a tier-2 coding (packetization of code-block data) (T2)
41
42 */
43
44 /** @defgroup T2 T2 - Implementation of a tier-2 coding */
45 /*@{*/
46
47 /**
48 Tier-2 coding
49 */
50 typedef struct opj_t2 {
51     /** Codec context */
52     opj_common_ptr cinfo;
53     /** Encoding: pointer to the src volume. Decoding: pointer to the dst volume. */
54     opj_volume_t *volume;
55     /** Pointer to the volume coding parameters */
56     opj_cp_t *cp;
57 } opj_t2_t;
58
59 /** @name Funciones generales */
60 /*@{*/
61 /* ----------------------------------------------------------------------- */
62
63 /**
64 Encode the packets of a tile to a destination buffer
65 @param t2 T2 handle
66 @param tileno number of the tile encoded
67 @param tile the tile for which to write the packets
68 @param maxlayers maximum number of layers
69 @param dest the destination buffer
70 @param len the length of the destination buffer
71 @param volume_info structure to create an index file
72 @return Number of bytes written from packets
73 */
74 int t2_encode_packets(opj_t2_t* t2, int tileno, opj_tcd_tile_t *tile,
75                       int maxlayers, unsigned char *dest, int len, opj_volume_info_t *volume_info);
76
77 /**
78 Decode the packets of a tile from a source buffer
79 @param t2 T2 handle
80 @param src the source buffer
81 @param len length of the source buffer
82 @param tileno number that identifies the tile for which to decode the packets
83 @param tile tile for which to decode the packets
84 @return Number of bytes read from packets
85  */
86 int t2_decode_packets(opj_t2_t *t2, unsigned char *src, int len, int tileno,
87                       opj_tcd_tile_t *tile);
88
89 /**
90 Create a T2 handle
91 @param cinfo Codec context info
92 @param volume Source or destination volume
93 @param cp Volume coding parameters
94 @return Returns a new T2 handle if successful, returns NULL otherwise
95 */
96 opj_t2_t* t2_create(opj_common_ptr cinfo, opj_volume_t *volume, opj_cp_t *cp);
97 /**
98 Destroy a T2 handle
99 @param t2 T2 handle to destroy
100 */
101 void t2_destroy(opj_t2_t *t2);
102
103 /* ----------------------------------------------------------------------- */
104 /*@}*/
105
106 /*@}*/
107
108 #endif /* __T2_H */