>Java >java지도 시간 >16진수 데이터를 얻기 위한 Java 구문 분석 DICOM 다이어그램의 분석 예

16진수 데이터를 얻기 위한 Java 구문 분석 DICOM 다이어그램의 분석 예

黄舟
黄舟원래의
2017-10-18 09:51:161821검색

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이 나와야 합니다.

🎜🎜알겠습니다. 문제를 찾았습니다. 166+90=256 이것은 우연이 아닙니다. 간과되는 한 가지 문제는 바이트 배열의 최대값이 127에 불과하다는 점이다. 따라서 파일에서 읽은 배열이 127보다 크면 바이트 배열을 읽을 때 오류가 발생한다. 🎜🎜🎜🎜솔루션🎜🎜🎜🎜🎜🎜
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.