C#开发PACS医学影像处理系统(七):读取影像Dicom信息

C#开发PACS医学影像处理系统(七):读取影像Dicom信息

Dicom的文件信息一般是由设备信息、图像信息、病人信息等Tag标记组成的,用字节长度和偏移量来区分,

具体数据结构可以自行去参考Dicom文件解析,内容比较多,这里不赘述。

对于常用的Tag,可以简单的理解为两层结构,第一层是组,第二层是组包含的元素,每个组号和元素号用2个字节表示(Uint16),

例如常用的组有 0002组描述设备通讯,0008组描述特征参数,0010组描述患者信息,0028组描述图像信息参数,

例如 0010组里面又包含病人姓名、年龄、性别等。

同样的,按照上一篇文章,还是用fo-dicom来解析Dicom信息,可以直接通过DicomTag的类型感知来获取你想要的Tag值。

        //实例化文件处理对象并打开文件
            DicomFile dicomFile = DicomFile.Open(@"C:1011.dcm");
            //获取dicom图像对象
            DicomImage dicomImage = new DicomImage(dicomFile.Dataset);

            //接收变量
            string [] name;
            //读取病人姓名
            dicomFile.Dataset.TryGetValues<string>(DicomTag.PatientName, out name);
            if (name != null)
            {
                Console.WriteLine(name[0]);
            }

有时候我们并不知道某个Tag值对应的名称叫什么,例如 0x0010 0x0020, 所以去DicomTag 类型里面搜索将是一件很痛苦的事情,

这时候需要自己封装一个Tag值操作类,重载创建标签函数,不仅支持uint16,还支持string字符串的组号和元素带入并查询

 /// <summary>
    /// 标签管理器
    /// </summary>
    public static class TagManager
    {
        /// <summary>
        /// 设置一个标签
        /// </summary>
        /// <param name="alignment">标签方位</param>
        /// <param name="tagRow">标签所在行数(四个角1到10,上下左右只支持一行)</param>
        /// <param name="dicomTag">标签值</param>
        /// <param name="tagFont">标签样式</param>
        public static TagHandler CreateTag(TagAlignment alignment, int tagRow, DicomTag dicomTag, ImageTagFont tagFont = null)
        {
            TagHandler tag = new TagHandler
            {
                Alignment = alignment,
                DicomTag = dicomTag,
                TagRow = tagRow,
                TagType = TagType.TagValue,
                TagFont = tagFont
            };
            return tag;
        }


        /// <summary>
        /// 设置一个标签
        /// </summary>
        /// <param name="alignment">标签方位</param>
        /// <param name="tagRow">标签所在行数(四个角1到10,上下左右只支持一行)</param>
        /// <param name="group">标签组</param>
        /// <param name="element">标签元素</param>
        /// <param name="tagFont">标签样式</param>
        public static TagHandler CreateTag(TagAlignment alignment, int tagRow, ushort group, ushort element, ImageTagFont tagFont = null)
        {
            TagHandler tag = new TagHandler
            {
                Alignment = alignment,
                Group = group,
                Element = element,
                TagRow = tagRow,
                TagType = TagType.TagValue,
                TagFont = tagFont
            };
            return tag;
        }


        /// <summary>
        /// 设置一个标签
        /// </summary>
        /// <param name="alignment">标签方位</param>
        /// <param name="tagRow">标签所在行数(四个角1到10,上下左右只支持一行)</param>
        /// <param name="groupHexStr">标签组(16进制字符串)</param>
        /// <param name="elementHexStr">标签元素(16进制字符串)</param>
        /// <param name="tagFont">标签样式</param>
        public static TagHandler CreateTag(TagAlignment alignment, int tagRow, string groupHexStr, string elementHexStr, ImageTagFont tagFont = null)
        {
            TagHandler tag = new TagHandler
            {
                Alignment = alignment,
                GroupHexStr = groupHexStr,
                ElementHexStr = elementHexStr,
                TagRow = tagRow,
                TagType = TagType.TagValue,
                TagFont = tagFont
            };
            return tag;
        }


        /// <summary>
        /// 设置一个标签
        /// </summary>
        /// <param name="alignment">标签方位</param>
        /// <param name="tagRow">标签所在行数(四个角1到10,上下左右只支持一行)</param>
        /// <param name="tagText">标签内容</param>
        /// <param name="tagFont">标签样式</param>
        public static TagHandler CreateTag(TagAlignment alignment, int tagRow, string tagText, ImageTagFont tagFont = null)
        {
            TagHandler tag = new TagHandler
            {
                Alignment = alignment,
                TagText = tagText,
                TagRow = tagRow,
                TagType = TagType.UserData,
                TagFont = tagFont
            };
            return tag;
        }


        /// <summary>
        /// 设置一个标签
        /// </summary>
        /// <param name="alignment">标签方位</param>
        /// <param name="tagRow">标签所在行数(四个角1到10,上下左右只支持一行)</param>
        /// <param name="tagType">标签类型</param>
        /// <param name="tagFont">标签样式</param>
        public static TagHandler CreateTag(TagAlignment alignment, int tagRow, TagType tagType, ImageTagFont tagFont = null)
        {
            TagHandler tag = new TagHandler
            {
                Alignment = alignment,
                TagRow = tagRow,
                TagType = tagType,
                TagFont = tagFont
            };
            return tag;
        }
    }

同样,我们也可以设置自定义样式,例如颜色、字体、字号、透明度、自定义文本内容等等,

对于不同的挂片类型,配合对应的挂片协议即可自动显示医院阅片或胶片打印所需要的Tag。

TagManager.CreateTag(TagAlignment.RightBottom, 1, "By ET-Dicom", new ImageTagFont { TagColor = Color.Blue, TagSize = 18 })

这样单元格的边角标记就完成了,在设计器中,Tag控件用Textblock就可以了。

 

配合挂片协议后最终呈现效果:

 

 
原文地址:https://www.cnblogs.com/Uncle-Joker/p/13666034.html

posted on 2022-10-12 18:01  漫思  阅读(336)  评论(0编辑  收藏  举报

导航