ImfTileOffsets.h 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137
  1. ///////////////////////////////////////////////////////////////////////////
  2. //
  3. // Copyright (c) 2004, Industrial Light & Magic, a division of Lucas
  4. // Digital Ltd. LLC
  5. //
  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 are
  10. // met:
  11. // * Redistributions of source code must retain the above copyright
  12. // notice, this list of conditions and the following disclaimer.
  13. // * Redistributions in binary form must reproduce the above
  14. // copyright notice, this list of conditions and the following disclaimer
  15. // in the documentation and/or other materials provided with the
  16. // distribution.
  17. // * Neither the name of Industrial Light & Magic nor the names of
  18. // its contributors may be used to endorse or promote products derived
  19. // from this software without specific prior written permission.
  20. //
  21. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  22. // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  23. // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  24. // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  25. // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  26. // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  27. // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  28. // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  29. // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  30. // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  31. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  32. //
  33. ///////////////////////////////////////////////////////////////////////////
  34. #ifndef INCLUDED_IMF_TILE_OFFSETS_H
  35. #define INCLUDED_IMF_TILE_OFFSETS_H
  36. //-----------------------------------------------------------------------------
  37. //
  38. // class TileOffsets
  39. //
  40. //-----------------------------------------------------------------------------
  41. #include "ImfTileDescription.h"
  42. #include "ImfInt64.h"
  43. #include <vector>
  44. #include "ImfNamespace.h"
  45. #include "ImfForward.h"
  46. #include "ImfExport.h"
  47. OPENEXR_IMF_INTERNAL_NAMESPACE_HEADER_ENTER
  48. class TileOffsets
  49. {
  50. public:
  51. IMF_EXPORT
  52. TileOffsets (LevelMode mode = ONE_LEVEL,
  53. int numXLevels = 0,
  54. int numYLevels = 0,
  55. const int *numXTiles = 0,
  56. const int *numYTiles = 0);
  57. // --------
  58. // File I/O
  59. // --------
  60. IMF_EXPORT
  61. void readFrom (OPENEXR_IMF_INTERNAL_NAMESPACE::IStream &is, bool &complete,bool isMultiPart,bool isDeep);
  62. IMF_EXPORT
  63. void readFrom (std::vector<Int64> chunkOffsets,bool &complete);
  64. IMF_EXPORT
  65. Int64 writeTo (OPENEXR_IMF_INTERNAL_NAMESPACE::OStream &os) const;
  66. //-----------------------------------------------------------
  67. // Test if the tileOffsets array is empty (all entries are 0)
  68. //-----------------------------------------------------------
  69. IMF_EXPORT
  70. bool isEmpty () const;
  71. //-----------------------------------------------------------
  72. // populate 'list' with tiles coordinates in the order they appear
  73. // in the offset table (assumes full table!
  74. // each array myst be at leat totalTiles long
  75. //-----------------------------------------------------------
  76. IMF_EXPORT
  77. void getTileOrder(int dx_table[], int dy_table[], int lx_table[], int ly_table[]) const;
  78. //-----------------------
  79. // Access to the elements
  80. //-----------------------
  81. IMF_EXPORT
  82. Int64 & operator () (int dx, int dy, int lx, int ly);
  83. IMF_EXPORT
  84. Int64 & operator () (int dx, int dy, int l);
  85. IMF_EXPORT
  86. const Int64 & operator () (int dx, int dy, int lx, int ly) const;
  87. IMF_EXPORT
  88. const Int64 & operator () (int dx, int dy, int l) const;
  89. IMF_EXPORT
  90. bool isValidTile (int dx, int dy, int lx, int ly) const;
  91. IMF_EXPORT
  92. const std::vector<std::vector<std::vector <Int64> > >& getOffsets() const;
  93. private:
  94. void findTiles (OPENEXR_IMF_INTERNAL_NAMESPACE::IStream &is, bool isMultiPartFile,
  95. bool isDeep,
  96. bool skipOnly);
  97. void reconstructFromFile (OPENEXR_IMF_INTERNAL_NAMESPACE::IStream &is,bool isMultiPartFile,bool isDeep);
  98. bool readTile (OPENEXR_IMF_INTERNAL_NAMESPACE::IStream &is);
  99. bool anyOffsetsAreInvalid () const;
  100. LevelMode _mode;
  101. int _numXLevels;
  102. int _numYLevels;
  103. std::vector<std::vector<std::vector <Int64> > > _offsets;
  104. };
  105. OPENEXR_IMF_INTERNAL_NAMESPACE_HEADER_EXIT
  106. #endif