首頁  >  文章  >  Java  >  Java解析DICOM圖取得16進位資料的實例分析

Java解析DICOM圖取得16進位資料的實例分析

黄舟
黄舟原創
2017-10-18 09:51:161774瀏覽

DICOM就是醫學數位影像和通信,是醫學影像和相關資訊的國際標準(ISO 12052),以下這篇文章主要給大家介紹了關於Java解析DICOM圖之如何獲得16進位資料的相關資料,文中透過範例程式碼介紹的非常詳細,需要的朋友可以參考下。

前言

在最近的一個計畫需要用JAVA來解析DICOM圖片,DICOM被廣泛應用於放射醫療,心血管影像以及放射診療診斷設備(X射線,CT,核磁共振,超音波等),並且在眼科和牙科等其它醫學領域得到越來越深入廣泛的應用,在實現中遇到一些問題下面做一些記錄。

先找一個*.dcm檔。用編輯器開啟可以看到如下介面。我是用的編輯器是UltraEdit

紅字標註的是字節碼的標註,前面8行程式碼是檔案的頭資訊一般沒用。從第九行開始的四個十六進制數「44,49,43,4D」是很重要的。用ASCll碼解釋就是DICM。表示這是一個DICOM文件,這四個16進位數如果遺失或損壞,這個DICOM圖片就無法開啟了。

下面用java讀取這些十六進位數


#
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;

public class My_DICOM {

 static FileInputStream input;
 static byte[] b;
 public static void main(String[] args) {
  try {
   File file = new File("G:/zzz.dcm");
   input = new FileInputStream(file);
   b = new byte[(int) file.length()];
   input.read(b);
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }
  init();
 }
 public static void init(){
  System.out.println("b.length="+b.length);
  for (int i =0;i<10000;i++) {
    System.out.print(Integer.toHexString(b[i]));  
   if (i%16==15) {
    System.out.println();
   }else{
    System.out.print(", ");
   }
  }
 }
}

(因為檔案太大有13萬個字節,所以為了展示只循環1萬次。用
Integer.toHexString(b[i])

將其轉換成十六進位。

問題出現了。

執行後:


對照上面的編輯器開啟的十六進位清單紅字處本應是a6可是卻印出了ffffffa6。

找出問題

筆算出錯位元組所在的位置是140。印system.out.pritln(b[140]);

結果是-90。為什麼是-90?。

反向推到a6轉化為十進位應該是166。

好了這些找到問題了。 166+90=256這不是巧合。忽略了一個問題就是byte數組的最大值只有127.所以文件中讀到的數組大於127時byte數組的讀取就會出錯。

解決方法

#
public static void init(){
  System.out.println("b.length="+b.length);
  for (int i =0;i<10000;i++) {
  if (b[i]<0) {
    int temp=b[i]+256;
    System.out.print(Integer.toHexString(temp));
   }else{
    System.out.print(Integer.toHexString(b[i]));
   }

   if (i%16==15) {
    System.out.println();
   }else{
    System.out.print(", ");
   }
  }
 }


總結

########################### ##

以上是Java解析DICOM圖取得16進位資料的實例分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn