ASCII 格式的DXF文件可以用java利用组码实现,每个部分可进行封装。组码的书写需要注意空格,每行组码结束不能有空格,不然无法解析
1.header实现,getBoundX getBoundY是定义当前画布的左上角XY坐标,getBoundWidth(),getBoundHeight()是画布长宽
private void writeHeader () throws IOException { writeBufferLine ( " 0" ) ; writeBufferLine ( "SECTION" ) ; writeBufferLine ( " 2" ) ; writeBufferLine ( "HEADER" ) ; writeBufferLine ( " 9" ) ; writeBufferLine ( "$EXTMIN" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( getBoundX () ).toString () ) ; writeBufferLine ( "20" ) ; writeBufferLine ( new Double ( getBoundY () ).toString () ) ; writeBufferLine ( "30" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 9" ) ; writeBufferLine ( "$EXTMAX" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( convertXToPaper ( getBoundX () + getBoundWidth () ) ). toString () ) ; writeBufferLine ( "20" ) ; writeBufferLine ( new Double ( convertYToPaper ( getBoundY () + getBoundHeight () ) ). toString () ) ; writeBufferLine ( " 9" ) ; writeBufferLine ( "$LIMMIN" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( convertXToPaper ( getBoundX () ) ).toString () ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( new Double ( convertYToPaper ( getBoundY () ) ).toString () ) ; writeBufferLine ( " 9" ) ; writeBufferLine ( "$LIMMAX" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( convertXToPaper ( getBoundX () + getBoundWidth () ) ). toString () ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( new Double ( convertYToPaper ( getBoundY () + getBoundHeight () ) ). toString () ) ; writeBufferLine ( " 9" ) ; writeBufferLine ( "$PEXTMIN" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( convertXToPaper ( getBoundX () ) ).toString () ) ; writeBufferLine ( "20" ) ; writeBufferLine ( new Double ( convertYToPaper ( getBoundY () ) ).toString () ) ; writeBufferLine ( "30" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 9" ) ; writeBufferLine ( "$PEXTMAX" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( convertXToPaper ( getBoundX () + getBoundWidth () ) ). toString () ) ; writeBufferLine ( "20" ) ; writeBufferLine ( new Double ( convertYToPaper( getBoundY () + getBoundHeight () ) ). toString () ) ; writeBufferLine ( "30" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 0" ) ; writeBufferLine ( "ENDSEC" ) ; }
2.定义图层和类型
private void writeTables () throws IOException { writeBufferLine ( " 0" ) ; writeBufferLine ( "SECTION" ) ; writeBufferLine ( " 2" ) ; writeBufferLine ( "TABLES" ) ; writeTableLAYER () ; writeTableLTYPE () ; writeBufferLine ( " 0" ) ; writeBufferLine ( "ENDSEC" ) ; }
3.具体的资源
资源一般是点,线,多条线,面,面资源也是无数条线组成,所以就点、线结构
可对写点,写线,和点线的标注进行封装,写入资源的方式很重要,1种是直接写入ENTITIES中,
这种写法当用mapinfo转成tab格式时,每个图层可用表展现,但是表里不会带入点、线的属性。
a:写线
private void writePolylineAD ( Point2D[] _pts , int _color , String _lineStyle , String _layerName ) throws IOException { if ( _pts.length > 2 ) { for ( int i = 0 ; i <= _pts.length - 1 ; i++ ) { if ( i < _pts.length - 1 ) { Point2D[] pts = new Point2D.Double[2 ] ; pts[ 0 ] = _pts[ i ] ; pts[ 1 ] = _pts[ i + 1 ] ; writePolylineAD ( pts , _color , _lineStyle , _layerName ) ; } } return ; } writeBufferLine ( " 0" ) ; writeBufferLine ( "POLYLINE" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( _layerName ) ; writeBufferLine ( " 62" ) ; writeBufferLine ( new Integer ( _color ).toString () ) ; writeBufferLine ( " 6" ) ; writeBufferLine ( _lineStyle ) ; writeBufferLine ( " 66" ) ; writeBufferLine ( " 1" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; for ( int j = 0 ; j < _pts.length ; j++ ) { writeBufferLine ( " 0" ) ; writeBufferLine ( "VERTEX" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( _layerName ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( _pts[ j ].getX () ).toString () ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( new Double ( _pts[ j ].getY () ).toString () ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; } writeBufferLine ( " 0" ) ; writeBufferLine ( "SEQEND" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( _layerName ) ; }
b:写标注
private void writeText ( double _x , double _y , double _fontSize , int _color , String _text , int Align , String _layerName , double _angle,double xOffset,double yOffset ) throws IOException { if(_text.contains("<br>")) { ArrayList<String> textA=splitBR(_text); for(int j=0;j<textA.size();j++) { double tY; tY=_y-j*_fontSize; writeText(_x,tY,_fontSize,_color,textA.get(j).toString(),Align,_layerName,_angle,xOffset,yOffset); } }else { Rectangle2D rect = new Rectangle2D.Double ( getBoundX () , getBoundY () , getBoundWidth () , getBoundHeight () ) ; int out = rect.outcode ( _x , _y ) ; if ( out != 0 ) { return ; } if ( _text == null || _text.equals ( "" ) ) return ; writeBufferLine ( " 0" ) ; writeBufferLine ( "TEXT" ) ; writeBufferLine ( " 8" ) ; // if ( m_bLabelMerge ) // writeBufferLine ( "label" ) ; // else writeBufferLine ( _layerName ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double ( convertX ( _x ) +xOffset).toString () ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( new Double ( convertY ( _y )+yOffset ).toString () ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 11" ) ; writeBufferLine ( new Double ( convertX ( _x ) +xOffset).toString () ) ; writeBufferLine ( " 21" ) ; writeBufferLine ( new Double ( convertY ( _y )+yOffset ).toString () ) ; writeBufferLine ( " 31" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 40" ) ; writeBufferLine ( new Double ( _fontSize ).toString () ) ; writeBufferLine ( " 41" ) ; writeBufferLine ( "0.78" ) ; writeBufferLine ( " 50" ) ; writeBufferLine ( new Double ( _angle ).toString () ) ; if ( false ) { //文字颜色,暂时不实现 writeBufferLine ( " 62" ) ; writeBufferLine ( new Integer ( _color ).toString () ) ; } writeBufferLine ( " 1" ) ; //去掉换行符,该版本不支持 _text = _text.replace ( "\r" , "" ) ; _text = _text.replace ( "\n" , "" ) ; writeBufferLine ( _text ) ; writeBufferLine ( " 72" ) ; writeBufferLine ( new Integer ( Align ).toString () ) ; writeBufferLine ( " 73" ) ; writeBufferLine ( "3" ) ; } }
第二种是把点线以BLOCKS包装,属于带属性的导出。
点属性导出
private void writeGisPointSingleAtt(IMapVertex v,String layerName,int blockNum,int objNum) throws IOException { writeBufferLine ( " 0" ) ; writeBufferLine ( "BLOCK" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( layerName ) ; writeBufferLine ( " 2" ) ; //组码 block 名称 writeBufferLine ( "BLKP"+String.valueOf(blockNum)+"p"+String.valueOf(objNum) ) ; writeBufferLine ( " 70" ) ; writeBufferLine ( " 2" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 0" ) ; writeBufferLine ( "POINT" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( layerName ) ; writeBufferLine ( " 62" ) ; writeBufferLine ( " 1" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double(v.getX()).toString() ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( new Double(v.getY()).toString() ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; ArrayList<String> attr=new ArrayList<String>(); attr.add("Name"); attr.add("Longitude"); attr.add("Latitude"); attr.add("Planid"); attr.add("IsVirtual"); attr.add("Isabpoint"); attr.add("Iskeyres"); attr.add("Cutpoints"); writeAttrInVertex(attr,layerName); writeBufferLine ( " 0" ) ; writeBufferLine ( "ENDBLK" ) ; }
//每个点带属性导出至DXF,便于mapinfo的转换 //20121221 private void writeGisPointWithAtt(ArrayList<IMapVertex> res,ArrayList<String> layerNameRes) throws IOException { for(int i=0;i<res.size();i++) { YVertexReduce v=(YVertexReduce)res.get(i).getID(); writeBufferLine ( " 0" ) ; writeBufferLine ( "BLOCK" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( layerNameRes.get(i) ) ; writeBufferLine ( " 2" ) ; //组码 block 名称 writeBufferLine ( "BLK"+String.valueOf(i) ) ; writeBufferLine ( " 70" ) ; writeBufferLine ( " 2" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; writeBufferLine ( " 0" ) ; writeBufferLine ( "POINT" ) ; writeBufferLine ( " 8" ) ; writeBufferLine ( layerNameRes.get(i) ) ; writeBufferLine ( " 62" ) ; writeBufferLine ( " 1" ) ; writeBufferLine ( " 10" ) ; writeBufferLine ( new Double(v.geoX).toString() ) ; writeBufferLine ( " 20" ) ; writeBufferLine ( new Double(v.geoY).toString() ) ; writeBufferLine ( " 30" ) ; writeBufferLine ( "0.0" ) ; ArrayList<String> attr=new ArrayList<String>(); attr.add("Name"); attr.add("Longitude"); attr.add("Latitude"); attr.add("Planid"); attr.add("IsVirtual"); attr.add("Isabpoint"); attr.add("Iskeyres"); attr.add("Cutpoints"); writeAttrInVertex(attr,layerNameRes.get(i)); writeBufferLine ( " 0" ) ; writeBufferLine ( "ENDBLK" ) ; } }
4.结尾
private void writeTail () throws IOException { writeBufferLine ( " 0" ) ; writeBufferLine ( "EOF" ) ; }
相关推荐
总之,通过理解DXF文件格式,编写Java程序生成DXF文件并不复杂,但需要注意兼容性和文件结构的正确性。利用开源库或自己实现相关功能,可以在没有AutocAD环境的情况下,实现与AutoCAD软件的数据交换。
这些接口允许Java代码创建、修改和读取CAD文件,比如.dxf格式,这是一种通用的CAD数据交换格式。 3. **SSM框架**:Spring、SpringMVC和MyBatis是三个开源的Java框架,它们共同构成了一个强大的后端开发框架。Spring...
在本主题中,我们关注的是如何利用Java解析DXF(Drawing Exchange Format)文件,这是一种由AutoCAD软件生成的二进制或ASCII格式的文件,用于存储二维图形数据。DXF文件通常包含各种几何实体,如圆(circle)、椭圆...
Java DXF(Drawing Exchange Format)读写涉及到的是在Java环境中处理AutoCAD的图形数据格式。DXF是一种基于ASCII或二进制的文件格式,用于在不同的CAD程序之间...理解DXF文件格式和Java I/O操作是实现这一功能的基础。
在IT行业中,转换图形文件格式是一项常见的任务,特别是在CAD(计算机辅助设计)和Web图形领域。本主题聚焦于使用Java编程语言将CAD的DXF(Drawing Exchange Format)格式转换为SVG(Scalable Vector Graphics)格式...
Kabeja是一个开源的Java库,专门用于解析和操作DXF文件,并支持将其转换为其他图形格式,如PDF、SVG、PNG和JPG。 Kabeja的核心功能包括: 1. **DXF解析**:Kabeja可以读取DXF文件的各个部分,包括图层、线型、实体...
DXF(Drawing Exchange Format)是AutoCAD开发的一种用于二维绘图数据交换的文件格式,它允许用户在不同的CAD软件之间交换图形数据。G代码,又称NC(Numerical Control)代码,是CNC(Computer Numerical Control)...
Parser dxfParser = ParserBuilder.createDefaultParser(); dxfParser.parse(in, "UTF-8"); DXFDocument doc = dxfParser.getDocument(); SAXGenerator generator = new SVGGenerator();
### 基于DXF文件格式的二维复杂图形数控代码自动生成法 #### 摘要 本文介绍了一种从二维图形DXF格式文件直接生成数控加工代码(G代码)的方法,这种方法为从计算机辅助设计(CAD)到计算机辅助制造(CAM)提供了一...
DXF文件通常由AutoCAD等CAD软件生成,但不同软件之间的兼容性问题时常困扰着数据共享。Kabeja的出现,解决了这一问题,使得开发人员可以通过编程接口(API)来解析和操作DXF文件,而不必依赖特定的CAD软件。 Kabeja...
在Java编程环境中,处理DXF文件通常需要借助特定的库或API,以便进行读取、写入和编辑操作。本项目“dxf-code-r42”就是为了解决这个问题,它提供了一个用Java编写的DXF文件处理框架。 一、DXF文件结构与解析 DXF...
本文通过分析AutoCAD的DXF文件格式特点,探讨了如何使用JAVA语言提取并处理这些图形数据,并通过实例验证了该方法的有效性和实用性。 #### 关键词 JAVA、AutoCAD、DXF文件、CAD/CAM #### 0 引言 AutoCAD是一种...
6. **文件导入导出**:CAD软件通常需要支持不同格式的文件导入和导出,如DXF、DWG或SVG。这就需要用到文件I/O操作和特定格式的解析器,以读取和写入图形数据。 7. **性能优化**:由于CAD程序可能涉及大量图形的实时...
DXF到PostGIS转换器是一种开源工具,专为IT专业人士设计,用于将Autodesk DXF文件格式的数据导入到PostGIS地理数据库中。DXF(Drawing Exchange Format)是AutoCAD广泛使用的二维图形数据交换格式,而PostGIS是...
java操作cad画图,想通过dxf文件生成通风网络拓扑图, 第一个问题是dxf文件的读取, 基于java的平台中寻入dxf文件的关键技巧 TWaver导入导出AutoCAD DXF图纸中提到了方法,但是效果不好,
1. **坐标提取**:能够从DWG或DXF格式的CAD文件中快速提取点的坐标信息。这包括图形中的各个顶点、中点、交点等,为后续的数据分析和处理提供原始数据。 2. **坐标转换**:支持多种坐标系之间的转换,例如从笛卡尔...
而CAD数据,特别是DWG和DXF格式,主要用于工程图的制作和交换。CAD格式的数据在GIS领域中应用受限,因此常常需要转换成更为通用的GIS数据格式,Shp数据因此成为了首选。 转换CAD数据到Shp数据有多种方法,常见的几...
DXFLib是一个开源的C++库,专门用于读写AutoCAD的.DXF文件格式。DXF(Drawing Exchange Format)是Autodesk公司为AutoCAD设计的一种数据交换格式,它允许不同软件之间交换图形数据。在本资源中,我们有一个已经使用...
- 输出CAD格式:完成设置后,点击转换,软件会生成DWG或DXF文件。 - 编辑和检查:转换完成后,在CAD软件中打开新文件,检查内容是否正确,可能需要进行一些手动调整以完善细节。 6. **兼容性和质量**:转换质量取...