CGM格式解析
无意中从网上看到有人想解析CGM,就想起来把几年前做的一个小项目简单总结几句。
石油行业常用CGM(Computer Graphics Metafile)计算机图形元文件格式来保存一些图件,从参加工作没多久就遇到过许多的CGM读取和输出软件或工具。像SDI公司的cgmoffice等都可以很好的编辑cgm文件。由于cgm格式设计得较早,虽然许多理念很不错,设计的图形元素复杂,但还是有一些先天不足,其中最大的问题是对中文的支持,再就是支持多种版本(V1到V4),并且还可以定制,称为profile,而一些公司出于成本的考虑,通常只支持V1或V2,一些复杂的元素就不再考虑了。
这些CGM文件的版本低一些也是好事,至少我们做编程的可以少花些时间就可以读取一些构造图了。在石油行业应用中常用的CGM版本实际上还是V1,在构造图里,用到的CGM命令并不多,统计后可以有一些惊异的发现。所以自己用C#编程来解析CGM也是一个可能的任务了。
看到许多刚刚参加工作的学生很快就会遇到此类问题,估计也要动手尝试自己解析CGM格式,这里把一些主要思路介绍一下。
CGM的官方文档实际上就是三个,
(1)ISO_IEC_8632-1_1999(E).pdf,CGM的ISO规范part1,总体介绍
(2)ISO_IEC_8632-3_1999(E).pdf,CGM的ISO规范part3(注意第2部分被ISO组织作废了),二进制格式介绍
(3)ISO_IEC_8632-4_1999(E).pdf,CGM的ISO规范part4(文本格式介绍,实际应用中很少用,一般不用看)
另外军方的有一个规范(MIL-STD-2301-1993-CGM.doc )写得比较细,把二进制编码的排列方式都写出来了。
值得一提的是CGM PIP规范,如果要显示带地震剖面的图形的这类CGM文件时,这个PIP也要能读才行。
可以从网上借鉴的一些相关源代码有:
(1)cgmviewer-1.00-java.rar,一个人用JAVA的Applet写的浏览cgm的小程序,功能很弱
(2)ralcgm.rar 这个源代码内容很多很全,但确实不容易看懂,也不容易移植
(3)胜利油田的一个朋友在工作站上用c语言写的读写cgm的程序,代码较乱,注释也很少,可以输出cgm
(4)Larson的CGMLibrary,1998 larson公司做的一个开放源码的cgm library,从1998年后好像就不免费了,但源代码还是可以参考的,还有一个cgmlib3.pdf的API手册有200多页。
另外还可以参考的就是发表在期刊杂志上的与CGM有关的几篇论文,这些论文篇幅都不长,可以作为入门手册来读读。
CGM的测试文件由NIST提供过2个版本,一个是2.0,一个是3.0,见这个网址http://www.itl.nist.gov/div897/ctg/cgm_form.htm,谁能把这些内容都正确显示了,才能算是一个cgm的商业软件。
自己解析CGM的过程还是相当曲折的,最后用INT公司的Carnac.NET来显示所有解析出来的图元(Carnac里面可以输出CGM文件,但不能读CGM),把以前的类图生成了一张。
----==== Email: slofslb (GTD) qq.com 请将(GTD)换成@ ====----
版权声明:自由转载-非商用-非衍生-保持署名(创意共享3.0许可证)
作者:申龙斌的程序人生
---- 魔方、桥牌、象棋、游戏人生...
---- BASIC、C++、JAVA、C#、Haskell、Objective-C、Open Inventor、程序人生...
---- GTD伴我实现人生目标
---- 区块链生存训练
---- 用欧拉计划学Rust编程
---- 申龙斌的读书笔记(2011-2019)
----