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),把以前的类图生成了一张。

image

posted @ 2011-09-03 10:57  申龙斌的程序人生  阅读(7039)  评论(2编辑  收藏  举报