OpenJPH
Open-source implementation of JPEG2000 Part-15
Loading...
Searching...
No Matches
ojph_codestream.h
Go to the documentation of this file.
1//***************************************************************************/
2// This software is released under the 2-Clause BSD license, included
3// below.
4//
5// Copyright (c) 2019, Aous Naman
6// Copyright (c) 2019, Kakadu Software Pty Ltd, Australia
7// Copyright (c) 2019, The University of New South Wales, Australia
8//
9// Redistribution and use in source and binary forms, with or without
10// modification, are permitted provided that the following conditions are
11// met:
12//
13// 1. Redistributions of source code must retain the above copyright
14// notice, this list of conditions and the following disclaimer.
15//
16// 2. Redistributions in binary form must reproduce the above copyright
17// notice, this list of conditions and the following disclaimer in the
18// documentation and/or other materials provided with the distribution.
19//
20// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
21// IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
22// TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
23// PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24// HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
26// TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
27// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
28// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
29// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31//***************************************************************************/
32// This file is part of the OpenJPH software implementation.
33// File: ojph_codestream.h
34// Author: Aous Naman
35// Date: 28 August 2019
36//***************************************************************************/
37
38
39#ifndef OJPH_CODESTREAM_H
40#define OJPH_CODESTREAM_H
41
42#include <cstdlib>
43
44#include "ojph_arch.h"
45#include "ojph_defs.h"
46
47namespace ojph {
48
50 //local prototyping
51 namespace local {
52 class codestream;
53 };
54
56 //defined elsewhere
57 class param_siz;
58 class param_cod;
59 class param_qcd;
60 class param_nlt;
61 class comment_exchange;
63 struct point;
64 class line_buf;
65 class outfile_base;
66 class infile_base;
67
69
89 {
90 public:
98 codestream();
99
106 ~codestream();
107
122 void restart();
123
138 void set_planar(bool planar);
139
151 void set_profile(const char* s);
152
173 void set_tilepart_divisions(bool at_resolutions, bool at_components);
174
183
192
200 void request_tlm_marker(bool needed);
201
210
211 bool is_tlm_requested();
212
229 void write_headers(outfile_base *file,
230 const comment_exchange* comments = NULL,
231 ui32 num_comments = 0);
232
254
255 line_buf* exchange(line_buf* line, ui32& next_component);
256
264 void flush();
265
273 void enable_resilience(); // before read_headers
274
285 void read_headers(infile_base *file); // before resolution restrictions
286
305 void restrict_input_resolution(ui32 skipped_res_for_data,
306 ui32 skipped_res_for_recon); //before create
307
313 void create();
314
326 line_buf* pull(ui32 &comp_num);
327
333 void close();
334
343
353
362
371
379 bool is_planar() const;
380
381 private:
383 };
384
385}
386
387#endif // !OJPH_CODESTREAM_H
param_siz access_siz()
Returns the underlying SIZ marker segment object.
param_cod access_cod()
Returns the underlying COD marker segment object.
bool is_tilepart_division_at_resolutions()
Query if the tile will be partitioned at resolution boundary.
local::codestream * state
void close()
Call this function to close the underlying file; works for both encoding and decoding codestreams.
void set_planar(bool planar)
Sets the sequence of pushing or pull rows from the machinery.
line_buf * exchange(line_buf *line, ui32 &next_component)
This call is used to send image data rows to the library. We expect to send one row from a single com...
void request_tlm_marker(bool needed)
Request the addition of the optional TLM marker segment. This request should occur before writing cod...
codestream()
default constructor
void set_profile(const char *s)
Sets the codestream profile.
param_qcd access_qcd()
Returns the underlying QCD marker segment object.
bool is_tilepart_division_at_components()
Query if the tile will be partitioned at component boundary.
void read_headers(infile_base *file)
This call reads the headers of a codestream. It is for a reading (or decoding) codestream,...
void set_tilepart_divisions(bool at_resolutions, bool at_components)
Sets the locations where a tile is partitioned into tile parts.
bool is_tlm_requested()
Query if the optional TLM marker segment is to be added.
void write_headers(outfile_base *file, const comment_exchange *comments=NULL, ui32 num_comments=0)
Writes codestream headers when the codestream is used for writing. This function should be called aft...
void create()
This call is for a decoding (or reading) codestream. Call this function after calling restrict_input_...
param_nlt access_nlt()
Returns the underlying NLT marker segment object.
bool is_planar() const
Query if the codestream extraction is planar or not. See the documentation for ojph::codestream::set_...
void flush()
This is the last call to a writing (encoding) codestream. This will write encoded bitstream data to t...
void restart()
Restarts the codestream.
line_buf * pull(ui32 &comp_num)
This call is to pull one row from the codestream, being decoded. The returned line_buf object holds o...
non-linearity point transformation object (implements NLT marker segment)
Quantization parameters object.
uint32_t ui32
Definition ojph_defs.h:54
#define OJPH_EXPORT
Definition ojph_arch.h:119
EMSCRIPTEN_KEEPALIVE void enable_resilience(j2k_struct *j2c)
EMSCRIPTEN_KEEPALIVE void restrict_input_resolution(j2k_struct *j2c, int skipped_res_for_read, int skipped_res_for_recon)