⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 用java读dxf文件.txt

📁 读取DXF文件的Java源码
💻 TXT
字号:
用java读DXF文件(ReadWorldmap.java)源码


//ReadWorldmap.java
//读取世界图对象
import java.io.*;
import java.util.*;
import java.net.*;

public class ReadWorldmap
{
private URL url;
private String FileName;
private InputStream inStream;
private InputStreamReader inStreamReader;
private BufferedReader bReader;

private String temp,temp1,temp2,temp3;
private int line;

public Worldmap worldmap=new Worldmap();

//构造函数,context是索引文件所在的URL,spec是世界图名
public ReadWorldmap(URL context,String SetName,String spec) 
{
line=0;
this.url=context;
FileName=spec+".NDX";
try
{
//inStream=(new URL(url,"\\"+SetName+"\\"+spec+"\\"+FileName)).openStream();
inStream=(new URL(url,SetName+"/"+spec+"/"+FileName)).openStream();
inStreamReader=new InputStreamReader(inStream);
bReader=new BufferedReader(inStreamReader);
// System.out.println(" :) Begin read file "+FileName);
}
catch(IOException e)
{
// System.out.println("Connection was not found."+"Can not read file "+FileName);
}
}
//****************************************************************************
private void error_report()
{
//System.out.println(" :< error appear at line "+line+"in file "+FileName);
}

//世界图初始化函数,返回一个世界图对象,在这个世界图对象中,仅包含世界图的基本属性,
//如坐标、放大倍数、层的信息等,而不包含具体的实体信息。
public Worldmap initialise()
{
boolean mainFlag=true;
double wmy1=0,wmy2=100; //临时变量

while(mainFlag)
{ 
try
{
line++;
temp=new String(bReader.readLine());
}
catch(IOException e) { error_report();}
temp=temp.trim();
StringTokenizer st=new StringTokenizer(temp,"<>,");
temp1=st.nextToken();

if(temp1.equals("NAME"))
{
temp2=st.nextToken();
temp2=temp2.trim();
worldmap._worldmap_name =temp2;

continue;
}

if(temp1.equals("DEC_COUNT"))
{

temp2=st.nextToken();
temp2=temp2.trim();
//worldmap.dec_count=Integer.valueOf(temp2).intValue();

continue;
}

if(temp1.equals("BEGIN_WC"))
{
temp2=st.nextToken();
temp2=temp2.trim();
temp3=st.nextToken();
temp3=temp3.trim();

worldmap._begin_world_coordinate_x=Double.valueOf(temp2).doubleValue();
// worldmap._begin_world_coordinate_y=Double.valueOf(temp3).doubleValue();
wmy2=Double.valueOf(temp3).doubleValue();

continue;
}

if(temp1.equals("END_WC"))
{

temp2=st.nextToken();
temp2=temp2.trim();
temp3=st.nextToken();
temp3=temp3.trim();

worldmap._end_world_coordinate_x=Double.valueOf(temp2).doubleValue();
// worldmap._end_world_coordinate_y=Double.valueOf(temp3).doubleValue();
wmy1=Double.valueOf(temp3).doubleValue();

continue;
}

if(temp1.equals("DECLUTTER"))
{
boolean dec_Flag=true; //标志变量
Declutter tempDeclutter=new Declutter();
double decy1=0,decy2=100; //临时变量

while(dec_Flag)
{
try
{
temp=new String(bReader.readLine());
}
catch(IOException e) { error_report(); }
temp=temp.trim();
StringTokenizer st1=new StringTokenizer(temp,"<>,");
temp1=st1.nextToken();
temp1=temp1.trim();

if(temp1.equals("NO"))
{
temp2=st1.nextToken();
temp2=temp2.trim();

// tempDeclutter.index=temp2;

continue;
}

if( temp1.equals("NAME"))
{
temp2=st1.nextToken();
temp2=temp2.trim();

tempDeclutter._declutter_name=temp2;
continue;
}

if(temp1.equals("SEG_COUNT"))
{
temp2=st1.nextToken();
temp2=temp2.trim();

// tempDeclutter.segment_number=Integer.valueOf(temp2).intValue();
continue;
}

if(temp1.equals("BEGIN_WC"))
{
temp2=st1.nextToken();
temp2=temp2.trim();
temp3=st1.nextToken();
temp3=temp3.trim();

tempDeclutter._begin_world_coordinate_x=Double.valueOf(temp2).doubleValue();
// tempDeclutter._begin_world_coordinate_y=Double.valueOf(temp3).doubleValue();
decy2=Double.valueOf(temp3).doubleValue();

continue;
}

if(temp1.equals("END_WC"))
{
temp2=st1.nextToken();
temp2=temp2.trim();
temp3=st1.nextToken();
temp3=temp3.trim();

tempDeclutter._end_world_coordinate_x=Double.valueOf(temp2).doubleValue();
// tempDeclutter._end_world_coordinate_y=Double.valueOf(temp3).doubleValue();
decy1=Double.valueOf(temp3).doubleValue();

continue;
}

if(temp1.equals("MAX_ZOOM"))
{
temp2=st1.nextToken();
temp2=temp2.trim();

tempDeclutter._display_zoomfactor_max=Double.valueOf(temp2).doubleValue();
continue;
}

if(temp1.equals("MIN_ZOOM"))
{
temp2=st1.nextToken();
temp2=temp2.trim();

tempDeclutter._display_zoomfactor_min=Double.valueOf(temp2).doubleValue()*1.1;
continue;
}

if(temp1.equals("SEGMENT"))
{
boolean seg_Flag=true;
Segment tempSegment=new Segment();
double segy1=0,segy2=100; //临时变量

while(seg_Flag)
{
try
{
temp=new String(bReader.readLine());
}
catch(IOException e) { error_report();}
temp=temp.trim();
StringTokenizer s_st=new StringTokenizer(temp,"<>,");
temp1=s_st.nextToken();
temp1=temp1.trim();

if(temp1.equals("NO"))
{
temp2=s_st.nextToken();
temp2=temp2.trim();

// tempSegment.index=Integer.valueOf(temp2).intValue();
continue;
}

if( temp1.equals("NAME"))
{
temp2=s_st.nextToken();
temp2=temp2.trim();

tempSegment._segment_name=temp2;
continue;
}

if(temp1.equals("BEGIN_WC"))
{
temp2=s_st.nextToken();
temp2=temp2.trim();
temp3=s_st.nextToken();
temp3=temp3.trim();

tempSegment._begin_world_coordinate_x=Double.valueOf(temp2).doubleValue();
// tempSegment._begin_world_coordinate_y=Double.valueOf(temp3).doubleValue();
segy2=Double.valueOf(temp3).doubleValue();

continue;
}

if(temp1.equals("END_WC"))
{
temp2=s_st.nextToken();
temp2=temp2.trim();
temp3=s_st.nextToken();
temp3=temp3.trim();

tempSegment._end_world_coordinate_x=Double.valueOf(temp2).doubleValue();
// tempSegment._end_world_coordinate_y=Double.valueOf(temp3).doubleValue();
segy1=Double.valueOf(temp3).doubleValue();

continue;
}

if(temp1.equals("MAX_ZOOM"))
{
temp2=s_st.nextToken();
temp2=temp2.trim();

tempSegment._display_zoomfactor_max=Double.valueOf(temp2).doubleValue();
continue;
}

if(temp1.equals("MIN_ZOOM"))
{
temp2=s_st.nextToken();
temp2=temp2.trim();

tempSegment._display_zoomfactor_min=Double.valueOf(temp2).doubleValue()*1.1;
continue;
}

if(temp1.equals("/SEGMENT"))
{
seg_Flag=false;

tempSegment._begin_world_coordinate_y=segy1;
tempSegment._end_world_coordinate_y=segy2;
tempDeclutter.add(tempSegment);
}
}

continue;
}

if(temp1.equals("/DECLUTTER"))
{
dec_Flag=false;
tempDeclutter._begin_world_coordinate_y =decy1;
tempDeclutter._end_world_coordinate_y =decy2;
worldmap.add(tempDeclutter);

continue;

}
}
continue;
} 

if(temp1.equals("/WORLDMAP"))
{
mainFlag=false;
worldmap._begin_world_coordinate_y =wmy1;
worldmap._end_world_coordinate_y =wmy2;

continue;
}
}

this.stop();
return worldmap;
}

//读层函数
/* public void fillDeclutter(int vector_index) throws NotFoundException
{
ReadSegment rp;
Declutter dec;
Segment seg;
int dec_index=vector_index;
String filename=new String();


dec=worldmap.getDeclutterByIndex(dec_index);

for(int i=0;i { 
seg=dec.getSegmentByIndex(i);
filename=worldmap._worldmap_name +"_"+dec._declutter_name +"_"+seg._segment_name +".dxf";
rp=new ReadSegment(url,seg,filename);

rp.execute();
}
} */

//私有函数。关闭所有打开的流,在initialise()函数结束时调用。
private void stop()
{
try
{
inStream.close();
inStreamReader.close();
bReader.close();
//System.out.println(" :) End read file "+FileName);
}
catch(IOException e) {}
}

}


附录:

如何读取DXF格式文件?
 
 
    OpenGL是美国SGI公司最新推出的一套开放式的三维图形软件接口,适用于广
泛的计算机环境,从个人计算机到工作站,OpenGL都能实现高性能的三维图形功
能。OpenGL本身不仅提供对简单图元的操作和控制,还提供了许多函数用于复杂
物体的建模。但是,我们通常喜欢使用AutoCAD和3DS及3Dmax等工具来建立模型,
并且我们已经有了很多这样的模型,那么我们如何才能资源共享,避免重复劳动
呢?利用CAD图形标准数据交换格式—DXF格式,我们就能很容易地实现资源共享
,而不需要重复建模。

 

  DXF文件的结构很清楚,具体如下:

  1. 标题段(HEADER )

  有关图形的一般信息都可以DXF 文件的这一节找到,每一个参数具有一个变
量名和一个相关值。

  2. 表段

  这一段包含的指定项的定义,它包括:

  a、

  线形表(LTYPE)

  b、

  层表(LYER)

  c、

  字体表(STYLE)

  d、

  视图表(VIEW)

  e、

  用户坐标系统表(UCS)

  f、

  视窗配置表(VPORT)

  g、

  标注字体表(DIMSTYLE)

  h、

  申请符号表(APPID)

  3. 块段(BLOCKS)

  这一段含有块定义实体,这些实体描述了图形种组成每个块的实体。

  4. 实体段(ENTITIES )

  这一段含有实体,包括任何块的调用。

  5. END OF FILE(文件结束)

 

  下面是对DXF的基本结构举一实例进行说明:

  0 0 后接SECTION

  SECTION 表明这是一个段的开始

  2 2 后接的是段名

  HEADER 说明该段是HEADER 段(标题段)

  9

  $ACADVER 文件是由AUTOCAD 产生的

  1

  AC1008

  9 9 后接 $UCSORG

  $UCSORG 用户坐标系原点在世界坐标系中的坐标

  10 10 对应 X

  0.0 X 的值

  20 20 对应 Y

  0.0 Y 的值

  30 30 对应 Z

  0.0 Z 的值

  9

  $UCSXDIR 这是一段不太相关的部分,略去

  10

  1.0

  ... ....

  9 9 后接 $EXTMIN

  $EXTMIN 说明三维实体模型在世界坐标系中的最小值

  10 10 对应 X

  -163.925293 X 的值

  20 20 对应 Y

  -18.5415860.0 Y 的值

  30 30 对应 Z

  78.350945 Z 的值

  9 9 后接 $EXTMAN

  $EXTMAX 说明三维实体模型在世界坐标系中的最大值

  10 10 对应 X

  202.492279 X 的值

  20 20 对应 Y

  112.634300 Y 的值

  30 30 对应 Z

  169.945602 Z 的值

  0 0 后接 ENDSEC

  ENDSEC 说明这一段结束了

  0 0 后接SECTION

  SECTION 表明这是一个段的开始

  2 2 后接的是段名

  TABLES 说明该段是TABLES 段(表段)

  ... ... ... ... 该段对我们不太相关,此处略去不进行说明

  0 0 后接 ENDSEC

  ENDSEC 说明这一段结束了

  0 0 后接SECTION

  SECTION 表明这是一个段的开始

  2 2 后接的是段名

  ENTITIES 说明该段是ENTITIES 段(实体段)这是我

  0 们要详细说明的段,该段包含了所有实体的

  POLYLINE 点的坐标和组成面的点序。0后接POLYLINE

  8 表明以下数据是对于一个新的实体;

  OBJECT01 8后接的字符串是这个实体的名称

  66

  1

  70 从66 1 到70 64

  64 说明该实体是由许多小平面组成的

  71

  38 71 38说明该实体共有38 个点

  72

  72 72 72 说明该实体由72 个三角形构成

  0 0 VERTEX

  VERTEX 表明后面紧跟着的是实体的数据

  8

  OBJECT01

  10 对应X 坐标

  -163.925293 X 的值

  20 对应Y 坐标

  -17.772665 Y 的值

  30 对应Z 坐标

  128.929947 Z 的值

  70 70 192

  192 表明上面的数据信息是点的坐标

  0 每一个从0 VERTEX 到70 192 之间

  VERTEX 的一小段是点的坐标

  ... ... ...

  70

  192

  0

  VERTEX

  8

  OBJECT01

  10

  0

  20

  0

  30

  0 当70 后跟128 时,表明该实体的每个点的坐标数据已经记录

  70 完了,下面紧跟着的是记录这些点是以什么样的方式组合成各

  128 个三角形。

  71 71、72、73 后面跟着的值表明某一个三角形是第二个、第

  2 一个、第四个点构成的,点的顺序是按照记入DXF 文件的顺

  72 序。当某一值为负数时,则表明该点到下一点的线不要画出,

  1 如果要画三维实体的线型图,就必须使用这一特性,否则线条

  73 将会出现紊乱。

  -4

  0

  VERTEX

  ... ... ... ...

  0 0 后接SEQEND 表明该实体的数据已经全部记录完了

  SEQEND

  8

  OBJECT01

  0

  POLYLINE 0 后接POLYLINE 表明以下又是一个新的实体

  ... ... ... ...

  0

  ENDSEC 0 后接ENDSEC 表明这是该段的结尾

  0

  EOF 0后接EOF 表明这个DXF 文件结束了

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -