When you write an ImageIO, you're not dealing directly with ITK images.  The ImageIO is called by the ImageFileReader and ImageFileWriter.  Your ImageIO class is responsible for initializing its own dimensions, spacing, pixel type and orientation in the ReadImageInformation method.
<br><br>Then, the Read function of your ImageIO class will get called to read the file and put its data into the supplied buffer.&nbsp; This is, in effect, a linear array of pixels, organized as reported in the dimensions reported by your ImageIO class.&nbsp; If for some reason your file format doesn&#39;t arange the pixels on disk the way that ITK expects, you will have to read the file and rearrange the pixels appropriately when you copy them into the read buffer.
<br><br>But the more usual way things work is the on-disk pixel ordering matches the ITK ordering, so you can just read your file directly into the passed-in buffer in the ImageIO::Read function.<br><br>ITK doesn&#39;t understand non-uniform spacing -- the spacing is given one value per dimension.&nbsp; So you need a way to pass your array of volume times out to your application.&nbsp; You can do this by using the MetaDataDictionary. 
<br><br>Each descendent of itk::Object has a MetaDataDictionary, including your ImageIO class.&nbsp; Anything you put in the MetaDataDictionary for the ImageIO class will be copied out to the Image returned from itk::ImageFileReader.&nbsp; So you can create a MetaDataObject templated over a vector type, and put your volume times in the vector.&nbsp; If you look at 
itkMetaDataObject.h, there are some convenience template functions EncapsulateMetaData and ExposeMetaData for adding and retrieving values from MetaDataDictionaries.<br><br>The various transform types supported by ITK don&#39;t always support dimensions greater than three, so if you want to transform 3d sub-volumes of a 4D Image, you pretty much have to use an ExtractImageFilter to get the volumes, do the transformations, and then put the sub-volumes back into the 4D image.
<br><br><br><div><span class="gmail_quote">On 2/9/07, <b class="gmail_sendername">Geoff Topping</b> &lt;<a href="mailto:g_topping@hotmail.com">g_topping@hotmail.com</a>&gt; wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
I&#39;m writing a custom ImageIO class to read a file format that has multiple<br>3D volumes in one file, with each volume corresponding to a different time<br>frame.&nbsp;&nbsp;I am unsure how I should store this information to be compatible and
<br>consistent with the rest if ITK...<br><br>The frames are of different durations, so I can&#39;t use a single m_Spacing<br>value for that dimension.&nbsp;&nbsp;Also, I don&#39;t want the time dimension to be<br>treated as if it was a spatial dimension when doing registrations on the
<br>volumes...&nbsp;&nbsp;In particular, I&#39;d like to be able to apply a spatial<br>transformation to each 3D&nbsp;&nbsp;frame volume as if it was a separate 3D image.<br><br>That said, it is essentially a 4D data set, so it would seem natural to
<br>treat it as a 4D image, if this is possible.&nbsp;&nbsp;I&#39;m also not sure how to<br>properly read and store multiple 3D volumes from a single ::Read() call.<br><br>I haven&#39;t been able to find any indication online of how this sort of
<br>situation should be dealt in ITK.&nbsp;&nbsp;Are there any existing multi-frame<br>variable-duration image reading classes I can base my work off of?&nbsp;&nbsp;Any help<br>would be appreciated.<br><br>Geoff Topping<br><br>_________________________________________________________________
<br>Find out the restaurants participating in Winterlicious<br><a href="http://local.live.com/default.aspx?v=2&amp;cp=43.658648~-79.383962&amp;style=r&amp;lvl=15&amp;tilt=-90&amp;dir=0&amp;alt=-1000&amp;scene=3702663&amp;cid=7ABE80D1746919B4!1329">
http://local.live.com/default.aspx?v=2&amp;cp=43.658648~-79.383962&amp;style=r&amp;lvl=15&amp;tilt=-90&amp;dir=0&amp;alt=-1000&amp;scene=3702663&amp;cid=7ABE80D1746919B4!1329</a><br>&gt;From January 26 to February 8, 2007
<br><br>_______________________________________________<br>Insight-users mailing list<br><a href="mailto:Insight-users@itk.org">Insight-users@itk.org</a><br><a href="http://www.itk.org/mailman/listinfo/insight-users">http://www.itk.org/mailman/listinfo/insight-users
</a><br></blockquote></div><br>