溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Java解析DICOM圖之如何獲得16進制數(shù)據(jù)詳解

發(fā)布時間:2020-10-02 10:35:05 來源:腳本之家 閱讀:200 作者:Kerrigeng 欄目:編程語言

前言

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

首先找一個*.dcm文件。用編輯器打開可以看到如下界面。我是用的編輯器是UltraEdit

Java解析DICOM圖之如何獲得16進制數(shù)據(jù)詳解

紅字標注的是字節(jié)碼的標注,前面8行代碼是文件的頭信息一般沒用。從第九行開始的四個十六進制數(shù)“44,49,43,4D”是很重要的。用ASCll碼解釋就是DICM。表示這是一個DICOM文件,這四個16進制數(shù)如果丟失或損壞,這個DICOM圖片就無法打開了。

下面用java來讀取這些十六進制數(shù)

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萬個字節(jié),所以為了展示只循環(huán)1萬次。讀取前一萬個字節(jié))

上面的代碼很普通就是將文件流讀入byte數(shù)組中。用Integer.toHexString(b[i])將其轉化成十六進制。

問題出現(xiàn)了。

運行后:

Java解析DICOM圖之如何獲得16進制數(shù)據(jù)詳解

對照上面的編輯器打開的十六進制列表紅字處本該是a6可是卻打印出了ffffffa6。

查找問題

筆算出錯字節(jié)所在的位置是140。打印system.out.pritln(b[140]);結果是-90。為什么是-90?。

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

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

解決方法

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(", ");
   }
  }
 }

總結

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI