好的,我正在做的是为现有的DICOM文件添加一个新的Overlay&保存它(DICOM文件现在有两个叠加)。一切都保存没有错误&两个DICOM观众Sante& ClearCanvas-Workstation打开文件,但只有Sante显示两个叠加层。 现在,当我查看DICOM文件中的标签时,OverlayData(6000)'VR'是'OW'和& OverlayData(6002)'VR'是'OB'。 所以我的问题是如何创建一个'VR'为'OW'的新标签,因为这是用于OverlayData的正确标签。
以下是我用于将新Overlay添加到DicomFile.DataSet的代码:: 注意,在我创建叠加后,我会将可见像素数据写入其中。
void AddOverlay()
{
int newOverlayIndex = 0;
for(int i = 0; i != 16; ++i)
{
if(!DicomFile.DataSet.Contains(GetOverlayTag(i, 0x3000)))
{
newOverlayIndex = i;
break;
}
}
//Columns
uint columnsTag = GetOverlayTag(newOverlayIndex, 0x0011);
DicomFile.DataSet[columnsTag].SetUInt16(0, (ushort)CurrentData.Width);
//Rows
uint rowTag = GetOverlayTag(newOverlayIndex, 0x0010);
DicomFile.DataSet[rowTag].SetUInt16(0, (ushort)CurrentData.Height);
//Type
uint typeTag = GetOverlayTag(newOverlayIndex, 0x0040);
DicomFile.DataSet[typeTag].SetString(0, "G");
//Origin
uint originTag = GetOverlayTag(newOverlayIndex, 0x0050);
DicomFile.DataSet[originTag].SetUInt16(0, 1);
DicomFile.DataSet[originTag].SetUInt16(1, 1);
//Bits Allocted
uint bitsAllocatedTag = GetOverlayTag(newOverlayIndex, 0x0100);
DicomFile.DataSet[bitsAllocatedTag].SetUInt16(0, 1);
//Bit Position
uint bitPositionTag = GetOverlayTag(newOverlayIndex, 0x0100);
DicomFile.DataSet[bitPositionTag].SetUInt16(0, 0);
//Data
uint dataTag = GetOverlayTag(newOverlayIndex, 0x3000);
DicomFile.DataSet[dataTag].SetNullValue();//<<< Needs to be something else
byte[] bits = new byte[(CurrentData.Width*CurrentData.Height)/8];
for(int i = 0; i != bits.Length; ++i) bits[i] = 0;
DicomFile.DataSet[dataTag].Values = bits;
}
public static uint GetOverlayTag(int overlayIndex, short element)
{
short group = (short)(0x6000 + (overlayIndex*2));
byte[] groupBits = BitConverter.GetBytes(group);
byte[] elementBtis = BitConverter.GetBytes(element);
return BitConverter.ToUInt32(new byte[]{elementBtis[0], elementBtis[1], groupBits[0], groupBits[1]}, 0);
}
所以在我看来会有一些方法,比如'DicomFile.DataSet [dataTag] .SetNullValue();'创建'VR'为'OW'的标签。或者也许是在ClearCanvas idk中添加叠加层的完全不同的方式...
答案 0 :(得分:1)
好吧,我的混乱是由我的程序中的错误引起的。 我试图通过使用元素“0x0100”而不是“0x0102”来创建“位位置”标记。 OW与OB无关。
对此感到抱歉......