Java解析DICOM圖之如何獲得16進(jìn)制數(shù)據(jù)詳解
前言
在最近的一個(gè)項(xiàng)目需要用JAVA來解析DICOM圖片,DICOM被廣泛應(yīng)用于放射醫(yī)療,心血管成像以及放射診療診斷設(shè)備(X射線,CT,核磁共振,超聲等),并且在眼科和牙科等其它醫(yī)學(xué)領(lǐng)域得到越來越深入廣泛的應(yīng)用,在實(shí)現(xiàn)中遇到一些問題下面做一些記錄。
首先找一個(gè)*.dcm文件。用編輯器打開可以看到如下界面。我是用的編輯器是UltraEdit

紅字標(biāo)注的是字節(jié)碼的標(biāo)注,前面8行代碼是文件的頭信息一般沒用。從第九行開始的四個(gè)十六進(jìn)制數(shù)“44,49,43,4D”是很重要的。用ASCll碼解釋就是DICM。表示這是一個(gè)DICOM文件,這四個(gè)16進(jìn)制數(shù)如果丟失或損壞,這個(gè)DICOM圖片就無法打開了。
下面用java來讀取這些十六進(jìn)制數(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(", ");
}
}
}
}
(因?yàn)槲募笥?3萬個(gè)字節(jié),所以為了展示只循環(huán)1萬次。讀取前一萬個(gè)字節(jié))
上面的代碼很普通就是將文件流讀入byte數(shù)組中。用Integer.toHexString(b[i])將其轉(zhuǎn)化成十六進(jìn)制。
問題出現(xiàn)了。
運(yùn)行后:

對(duì)照上面的編輯器打開的十六進(jìn)制列表紅字處本該是a6可是卻打印出了ffffffa6。
查找問題
筆算出錯(cuò)字節(jié)所在的位置是140。打印system.out.pritln(b[140]);結(jié)果是-90。為什么是-90?。
反向推到a6轉(zhuǎn)化為十進(jìn)制應(yīng)該是166。
好了這些找到問題了。166+90=256這不是巧合。忽略了一個(gè)問題就是byte數(shù)組的最大值只有127.所以文件中讀到的數(shù)組大于127時(shí)byte數(shù)組的讀取就會(huì)出錯(cuò)。
解決方法
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(", ");
}
}
}
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
SpringBoot整合SpringTask實(shí)現(xiàn)定時(shí)任務(wù)的流程
這篇文章主要介紹了SpringBoot整合SpringTask實(shí)現(xiàn)定時(shí)任務(wù)的流程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
全面詳解java代碼重構(gòu)與設(shè)計(jì)模式
這篇文章主要為大家介紹了全面詳解java代碼重構(gòu)與設(shè)計(jì)模式的全面詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06
java集合類arraylist循環(huán)中刪除特定元素的方法
下面小編就為大家?guī)硪黄狫ava集合類ArrayList循環(huán)中刪除特定元素的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-11-11
MyBatis?Generator?ORM層面的代碼自動(dòng)生成器(推薦)
Mybatis?Generator是一個(gè)專門為?MyBatis和?ibatis框架使用者提供的代碼生成器,也可以快速的根據(jù)數(shù)據(jù)表生成對(duì)應(yīng)的pojo類、Mapper接口、Mapper文件,甚至生成QBC風(fēng)格的查詢對(duì)象,這篇文章主要介紹了MyBatis?Generator?ORM層面的代碼自動(dòng)生成器,需要的朋友可以參考下2023-01-01
Java四舍五入時(shí)保留指定小數(shù)位數(shù)的五種方式
這篇文章主要介紹了Java四舍五入時(shí)保留指定小數(shù)位數(shù)的五種方式,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2020-09-09
MyBatis?Plus實(shí)現(xiàn)中文排序的兩種有效方法
在MyBatis?Plus項(xiàng)目開發(fā)中,針對(duì)中文數(shù)據(jù)的排序需求是一個(gè)常見的挑戰(zhàn),尤其是在需要按照拼音或特定語言邏輯排序時(shí),本文整合了兩種有效的方法,旨在幫助開發(fā)者克服MyBatis?Plus在處理中文排序時(shí)遇到的障礙,需要的朋友可以參考下2024-08-08
談?wù)凷pring Boot 數(shù)據(jù)源加載及其多數(shù)據(jù)源簡(jiǎn)單實(shí)現(xiàn)(小結(jié))
這篇文章主要介紹了談?wù)凷pring Boot 數(shù)據(jù)源加載及其多數(shù)據(jù)源簡(jiǎn)單實(shí)現(xiàn),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2019-04-04
mybatis-plus批量更新updateBatchById問題
這篇文章主要介紹了mybatis-plus批量更新updateBatchById問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07

