1 function S = mha_read_slice(info, num_slice)
2 % Function for reading the volume of a Insight Meta-Image (.mha, .mhd) file
4 % volume = tk_read_volume(file-header)
7 % 1: info = mha_read_header()
8 % V = mha_read_volume(info);
9 % imshow(squeeze(V(:,:,round(end/2))),[]);
11 % 2: V = mha_read_volume('test.mha');
13 if(~isstruct(info)), info=mha_read_header(info); end
16 switch(lower(info.DataFile))
20 info.Filename=fullfile(fileparts(info.Filename),info.DataFile);
24 switch(info.ByteOrder(1))
26 fid=fopen(info.Filename,'rb','ieee-be');
28 fid=fopen(info.Filename,'rb','ieee-le');
31 switch(lower(info.DataFile))
34 fseek(fid,info.HeaderSize,'bof');
40 datasize=prod(info.Dimensions)*info.BitDepth/8; % in bytes
41 slicesize=info.Dimensions(1)*info.Dimensions(2)*info.BitDepth/8;
42 OffsetToSelectedSlice=(num_slice-1)*slicesize;
43 fseek(fid, OffsetToSelectedSlice, 'cof');
46 switch(info.CompressedData(1))
51 S = int8(fread(fid,slicesize,'char'));
53 S = uint8(fread(fid,slicesize,'uchar'));
55 S = int16(fread(fid,slicesize,'short'));
57 S = uint16(fread(fid,slicesize,'ushort'));
59 S = int32(fread(fid,slicesize,'int'));
61 S = uint32(fread(fid,slicesize,'uint'));
63 S = single(fread(fid,info.Dimensions(1)*info.Dimensions(2),'float'));
65 S = double(fread(fid,slicesize,'double'));
69 case 'char', DataType='int8';
70 case 'uchar', DataType='uint8';
71 case 'short', DataType='int16';
72 case 'ushort', DataType='uint16';
73 case 'int', DataType='int32';
74 case 'uint', DataType='uint32';
75 case 'float', DataType='single';
76 case 'double', DataType='double';
78 Z = fread(fid,inf,'uchar=>uint8');
79 S = zlib_decompress(Z,DataType);
84 S = reshape(S,[info.Dimensions(1), info.Dimensions(2)]);
86 function M = zlib_decompress(Z,DataType)
87 import com.mathworks.mlwidgets.io.InterruptibleStreamCopier
88 a=java.io.ByteArrayInputStream(Z);
89 b=java.util.zip.InflaterInputStream(a);
90 isc = InterruptibleStreamCopier.getInterruptibleStreamCopier;
91 c = java.io.ByteArrayOutputStream;
93 M=typecast(c.toByteArray,DataType);