ImfTiledInputPart.cpp 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. ///////////////////////////////////////////////////////////////////////////
  2. //
  3. // Copyright (c) 2011, 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. #include "ImfTiledInputPart.h"
  35. #include "ImfNamespace.h"
  36. OPENEXR_IMF_INTERNAL_NAMESPACE_SOURCE_ENTER
  37. TiledInputPart::TiledInputPart(MultiPartInputFile& multiPartFile, int partNumber)
  38. {
  39. file = multiPartFile.getInputPart<TiledInputFile>(partNumber);
  40. }
  41. const char *
  42. TiledInputPart::fileName () const
  43. {
  44. return file->fileName();
  45. }
  46. const Header &
  47. TiledInputPart::header () const
  48. {
  49. return file->header();
  50. }
  51. int
  52. TiledInputPart::version () const
  53. {
  54. return file->version();
  55. }
  56. void
  57. TiledInputPart::setFrameBuffer (const FrameBuffer &frameBuffer)
  58. {
  59. file->setFrameBuffer(frameBuffer);
  60. }
  61. const FrameBuffer &
  62. TiledInputPart::frameBuffer () const
  63. {
  64. return file->frameBuffer();
  65. }
  66. bool
  67. TiledInputPart::isComplete () const
  68. {
  69. return file->isComplete();
  70. }
  71. unsigned int
  72. TiledInputPart::tileXSize () const
  73. {
  74. return file->tileXSize();
  75. }
  76. unsigned int
  77. TiledInputPart::tileYSize () const
  78. {
  79. return file->tileYSize();
  80. }
  81. LevelMode
  82. TiledInputPart::levelMode () const
  83. {
  84. return file->levelMode();
  85. }
  86. LevelRoundingMode
  87. TiledInputPart::levelRoundingMode () const
  88. {
  89. return file->levelRoundingMode();
  90. }
  91. int
  92. TiledInputPart::numLevels () const
  93. {
  94. return file->numLevels();
  95. }
  96. int
  97. TiledInputPart::numXLevels () const
  98. {
  99. return file->numXLevels();
  100. }
  101. int
  102. TiledInputPart::numYLevels () const
  103. {
  104. return file->numYLevels();
  105. }
  106. bool
  107. TiledInputPart::isValidLevel (int lx, int ly) const
  108. {
  109. return file->isValidLevel(lx, ly);
  110. }
  111. int
  112. TiledInputPart::levelWidth (int lx) const
  113. {
  114. return file->levelWidth(lx);
  115. }
  116. int
  117. TiledInputPart::levelHeight (int ly) const
  118. {
  119. return file->levelHeight(ly);
  120. }
  121. int
  122. TiledInputPart::numXTiles (int lx) const
  123. {
  124. return file->numXTiles(lx);
  125. }
  126. int
  127. TiledInputPart::numYTiles (int ly) const
  128. {
  129. return file->numYTiles(ly);
  130. }
  131. IMATH_NAMESPACE::Box2i
  132. TiledInputPart::dataWindowForLevel (int l) const
  133. {
  134. return file->dataWindowForLevel(l);
  135. }
  136. IMATH_NAMESPACE::Box2i
  137. TiledInputPart::dataWindowForLevel (int lx, int ly) const
  138. {
  139. return file->dataWindowForLevel(lx, ly);
  140. }
  141. IMATH_NAMESPACE::Box2i
  142. TiledInputPart::dataWindowForTile (int dx, int dy, int l) const
  143. {
  144. return file->dataWindowForTile(dx, dy, l);
  145. }
  146. IMATH_NAMESPACE::Box2i
  147. TiledInputPart::dataWindowForTile (int dx, int dy, int lx, int ly) const
  148. {
  149. return file->dataWindowForTile(dx, dy, lx, ly);
  150. }
  151. void
  152. TiledInputPart::readTile (int dx, int dy, int l)
  153. {
  154. file->readTile(dx, dy, l);
  155. }
  156. void
  157. TiledInputPart::readTile (int dx, int dy, int lx, int ly)
  158. {
  159. file->readTile(dx, dy, lx, ly);
  160. }
  161. void
  162. TiledInputPart::readTiles (int dx1, int dx2, int dy1, int dy2, int lx, int ly)
  163. {
  164. file->readTiles(dx1, dx2, dy1, dy2, lx, ly);
  165. }
  166. void
  167. TiledInputPart::readTiles (int dx1, int dx2, int dy1, int dy2, int l)
  168. {
  169. file->readTiles(dx1, dx2, dy1, dy2, l);
  170. }
  171. void
  172. TiledInputPart::rawTileData (int &dx, int &dy, int &lx, int &ly,
  173. const char *&pixelData, int &pixelDataSize)
  174. {
  175. file->rawTileData(dx, dy, lx, ly, pixelData, pixelDataSize);
  176. }
  177. OPENEXR_IMF_INTERNAL_NAMESPACE_SOURCE_EXIT