DICOM은 의료 영상 및 관련 정보에 대한 국제 표준입니다(ISO 12052). 다음 기사에서는 DICOM 다이어그램을 Java로 구문 분석하여 관련 정보를 주로 소개합니다. 샘플 코드가 아주 자세하게 소개되어 있어 도움이 필요한 친구들이 참고할 수 있습니다.
머리말
최근 프로젝트에서 DICOM 이미지를 구문 분석하기 위해 JAVA가 필요했습니다. DICOM은 방사선 의학, 심혈관 영상, 방사선 진단 및 치료 장비(X-ray, CT, MRI, 초음파, 등), 안과, 치과 등 다른 의료 분야에서 점점 더 널리 사용되고 있습니다. 구현 중에 발생하는 일부 문제는 아래에 기록되어 있습니다.
먼저 *.dcm 파일을 찾으세요. 편집기로 열면 다음 인터페이스가 표시됩니다. 제가 사용하는 편집기는 UltraEdit입니다.
빨간색 글자는 바이트코드 주석입니다. 코드의 처음 8줄은 파일의 헤더 정보이며 일반적으로 쓸모가 없습니다. 9번째 줄부터 시작하는 4개의 16진수 "44,49,43,4D"가 중요합니다. ASCll 코드 설명은 DICM입니다. DICOM 파일임을 나타냅니다. 이 4개의 16진수 숫자가 손실되거나 손상된 경우 DICOM 사진을 열 수 없습니다.
다음은 java를 사용하여 이러한 16진수를 읽습니다
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(", "); } } } }
(파일이 너무 크고 130,000바이트이므로 표시를 위해 10,000회만 반복합니다. 첫 번째 읽기 10,000바이트)
위 코드는 파일 스트림을 바이트 배열로 읽는 매우 일반적인 코드입니다. Integer.toHexString(b[i])
를 사용하여 16진수로 변환합니다. Integer.toHexString(b[i])
将其转化成十六进制。
问题出现了。
运行后:
对照上面的编辑器打开的十六进制列表红字处本该是a6可是却打印出了ffffffa6。
查找问题
笔算出错字节所在的位置是140。打印system.out.pritln(b[140]);
제어 위의 편집기에서 열린 16진수 목록의 빨간색 텍스트는 a6이어야 하는데 ffffffa6이 인쇄됩니다.
문제 찾기
잘못된 바이트의 위치는 140입니다. system.out.pritln(b[140]);
을 인쇄하면 결과는 -90입니다. 왜 -90인가요?. a6을 거꾸로 밀고 십진수로 환산하면 166이 나와야 합니다.
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(", "); } } }🎜🎜🎜요약🎜🎜🎜
위 내용은 16진수 데이터를 얻기 위한 Java 구문 분석 DICOM 다이어그램의 분석 예의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!