`
kl720
  • 浏览: 10407 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

java生成DXF格式文件

    博客分类:
  • gis
 
阅读更多

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" ) ;
    }

 

 

分享到:
评论
1 楼 liu495777263 2014-10-21  
正在学导出dxf文件,学习下

相关推荐

    dxf文件java写入程序源代码

    总之,通过理解DXF文件格式,编写Java程序生成DXF文件并不复杂,但需要注意兼容性和文件结构的正确性。利用开源库或自己实现相关功能,可以在没有AutocAD环境的情况下,实现与AutoCAD软件的数据交换。

    java_to_cad.rar(最后生成.dxf文件)

    这些接口允许Java代码创建、修改和读取CAD文件,比如.dxf格式,这是一种通用的CAD数据交换格式。 3. **SSM框架**:Spring、SpringMVC和MyBatis是三个开源的Java框架,它们共同构成了一个强大的后端开发框架。Spring...

    用java解析DXF文件中的实体信息

    在本主题中,我们关注的是如何利用Java解析DXF(Drawing Exchange Format)文件,这是一种由AutoCAD软件生成的二进制或ASCII格式的文件,用于存储二维图形数据。DXF文件通常包含各种几何实体,如圆(circle)、椭圆...

    java实现cad(dxf格式)转svg

    在IT行业中,转换图形文件格式是一项常见的任务,特别是在CAD(计算机辅助设计)和Web图形领域。本主题聚焦于使用Java编程语言将CAD的DXF(Drawing Exchange Format)格式转换为SVG(Scalable Vector Graphics)格式...

    dxf文件解析,使用kabeja实现dxf文件对pdf,svg,png,jpg 的转换,内含完整的kabeja的jar包含kab

    Kabeja是一个开源的Java库,专门用于解析和操作DXF文件,并支持将其转换为其他图形格式,如PDF、SVG、PNG和JPG。 Kabeja的核心功能包括: 1. **DXF解析**:Kabeja可以读取DXF文件的各个部分,包括图层、线型、实体...

    java dxf读写

    Java DXF(Drawing Exchange Format)读写涉及到的是在Java环境中处理AutoCAD的图形数据格式。DXF是一种基于ASCII或二进制的文件格式,用于在不同的CAD程序之间...理解DXF文件格式和Java I/O操作是实现这一功能的基础。

    kabeja0.4 java解析Autodesk的dxf生成svg,pdf等

    Parser dxfParser = ParserBuilder.createDefaultParser(); dxfParser.parse(in, "UTF-8"); DXFDocument doc = dxfParser.getDocument(); SAXGenerator generator = new SVGGenerator();

    dxf文件转化成G代码

    ### 基于DXF文件格式的二维复杂图形数控代码自动生成法 #### 摘要 本文介绍了一种从二维图形DXF格式文件直接生成数控加工代码(G代码)的方法,这种方法为从计算机辅助设计(CAD)到计算机辅助制造(CAM)提供了一...

    kabeja-0.4.7z

    DXF文件通常由AutoCAD等CAD软件生成,但不同软件之间的兼容性问题时常困扰着数据共享。Kabeja的出现,解决了这一问题,使得开发人员可以通过编程接口(API)来解析和操作DXF文件,而不必依赖特定的CAD软件。 Kabeja...

    dxf-code-r42_DXF读写_DXFJAVA_

    在Java编程环境中,处理DXF文件通常需要借助特定的库或API,以便进行读取、写入和编辑操作。本项目“dxf-code-r42”就是为了解决这个问题,它提供了一个用Java编写的DXF文件处理框架。 一、DXF文件结构与解析 DXF...

    用JAVA语言处理AutoCAD图形数据的研究

    本文通过分析AutoCAD的DXF文件格式特点,探讨了如何使用JAVA语言提取并处理这些图形数据,并通过实例验证了该方法的有效性和实用性。 #### 关键词 JAVA、AutoCAD、DXF文件、CAD/CAM #### 0 引言 AutoCAD是一种...

    java绘图程序(CAD)

    6. **文件导入导出**:CAD软件通常需要支持不同格式的文件导入和导出,如DXF、DWG或SVG。这就需要用到文件I/O操作和特定格式的解析器,以读取和写入图形数据。 7. **性能优化**:由于CAD程序可能涉及大量图形的实时...

    DXF to PostGIS converter-开源

    DXF到PostGIS转换器是一种开源工具,专为IT专业人士设计,用于将Autodesk DXF文件格式的数据导入到PostGIS地理数据库中。DXF(Drawing Exchange Format)是AutoCAD广泛使用的二维图形数据交换格式,而PostGIS是...

    open_dxf_lib.rar

    java操作cad画图,想通过dxf文件生成通风网络拓扑图, 第一个问题是dxf文件的读取, 基于java的平台中寻入dxf文件的关键技巧 TWaver导入导出AutoCAD DXF图纸中提到了方法,但是效果不好,

    CAD坐标提取与转换工具

    1. **坐标提取**:能够从DWG或DXF格式的CAD文件中快速提取点的坐标信息。这包括图形中的各个顶点、中点、交点等,为后续的数据分析和处理提供原始数据。 2. **坐标转换**:支持多种坐标系之间的转换,例如从笛卡尔...

    基于GDAL的CAD数据向Shp数据转换.pdf

    而CAD数据,特别是DWG和DXF格式,主要用于工程图的制作和交换。CAD格式的数据在GIS领域中应用受限,因此常常需要转换成更为通用的GIS数据格式,Shp数据因此成为了首选。 转换CAD数据到Shp数据有多种方法,常见的几...

    采用vs2019编译好的DXFLib文件,含源代码

    DXFLib是一个开源的C++库,专门用于读写AutoCAD的.DXF文件格式。DXF(Drawing Exchange Format)是Autodesk公司为AutoCAD设计的一种数据交换格式,它允许不同软件之间交换图形数据。在本资源中,我们有一个已经使用...

    pdf转换成cad文件

    - 输出CAD格式:完成设置后,点击转换,软件会生成DWG或DXF文件。 - 编辑和检查:转换完成后,在CAD软件中打开新文件,检查内容是否正确,可能需要进行一些手动调整以完善细节。 6. **兼容性和质量**:转换质量取...

    dxflib类库-2.5.0.0

    为了更好地利用DXFLib,开发者需要熟悉DXF文件格式,理解其层次结构和元素定义。同时,掌握C++编程基础也是必不可少的。通过研究“test”文件夹中的源码,可以快速上手并开始自己的DXF处理项目。在遇到问题时,查阅...

Global site tag (gtag.js) - Google Analytics