gis
gis
管理员
管理员
  • 注册日期2003-07-16
  • 发帖数15947
  • QQ554730525
  • 铜币25339枚
  • 威望15364点
  • 贡献值0点
  • 银元0个
  • GIS帝国居民
  • 帝国沙发管家
  • GIS帝国明星
  • GIS帝国铁杆
阅读:5604回复:15

用java读DXF文件(ReadWorldmap.java)源码

楼主#
更多 发布于:2003-11-06 12:03
//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) {}
}

}
喜欢0 评分0
zhengfeifeiyndx
路人甲
路人甲
  • 注册日期2006-06-21
  • 发帖数26
  • QQ
  • 铜币194枚
  • 威望0点
  • 贡献值0点
  • 银元0个
1楼#
发布于:2008-04-05 21:44
<P>貌似太冗余了</P>
举报 回复(0) 喜欢(0)     评分
jixg1800
路人甲
路人甲
  • 注册日期2006-06-05
  • 发帖数15
  • QQ
  • 铜币158枚
  • 威望0点
  • 贡献值0点
  • 银元0个
2楼#
发布于:2008-04-05 09:37
<P>读dwg的文件怎么办呢!我现在做的是Eclipse+Arcgis Engine把CAD的dwg文件转到shp!</P>
举报 回复(0) 喜欢(0)     评分
whmwxhanshan123
路人甲
路人甲
  • 注册日期2006-06-17
  • 发帖数3108
  • QQ
  • 铜币6445枚
  • 威望0点
  • 贡献值0点
  • 银元0个
3楼#
发布于:2007-10-05 16:42
<img src="images/post/smile/dvbbs/em04.gif" /><img src="images/post/smile/dvbbs/em03.gif" />真厉害
举报 回复(0) 喜欢(0)     评分
whmwxhanshan123
路人甲
路人甲
  • 注册日期2006-06-17
  • 发帖数3108
  • QQ
  • 铜币6445枚
  • 威望0点
  • 贡献值0点
  • 银元0个
4楼#
发布于:2007-09-17 19:22
<img src="images/post/smile/dvbbs/em01.gif" /><img src="images/post/smile/dvbbs/em02.gif" />
举报 回复(0) 喜欢(0)     评分
renxiaohun
路人甲
路人甲
  • 注册日期2004-01-03
  • 发帖数36
  • QQ28542378
  • 铜币100枚
  • 威望0点
  • 贡献值0点
  • 银元0个
5楼#
发布于:2007-09-17 15:03
<P>太感谢了,我一直在寻求用JAVA在autocad里二次开发呢!</P>
###
举报 回复(0) 喜欢(0)     评分
whmwxhanshan123
路人甲
路人甲
  • 注册日期2006-06-17
  • 发帖数3108
  • QQ
  • 铜币6445枚
  • 威望0点
  • 贡献值0点
  • 银元0个
6楼#
发布于:2006-11-11 20:59
<img src="images/post/smile/dvbbs/em03.gif" /><img src="images/post/smile/dvbbs/em03.gif" />
举报 回复(0) 喜欢(0)     评分
zhao521
路人甲
路人甲
  • 注册日期2006-11-09
  • 发帖数1
  • QQ
  • 铜币105枚
  • 威望0点
  • 贡献值0点
  • 银元0个
7楼#
发布于:2006-11-10 10:08
<img src="images/post/smile/dvbbs/em01.gif" />
举报 回复(0) 喜欢(0)     评分
renxiaohun
路人甲
路人甲
  • 注册日期2004-01-03
  • 发帖数36
  • QQ28542378
  • 铜币100枚
  • 威望0点
  • 贡献值0点
  • 银元0个
8楼#
发布于:2006-10-13 16:46
<P><IMG src="http://www.gisempire.com/bbs/Skins/Default/emot/em01.gif"><IMG src="http://www.gisempire.com/bbs/Skins/Default/emot/em02.gif"><IMG src="http://www.gisempire.com/bbs/Skins/Default/emot/em05.gif">xiexie!</P>
###
举报 回复(0) 喜欢(0)     评分
shawxm
路人甲
路人甲
  • 注册日期2005-07-07
  • 发帖数7
  • QQ
  • 铜币121枚
  • 威望0点
  • 贡献值0点
  • 银元0个
9楼#
发布于:2005-12-15 13:44
<img src="images/post/smile/dvbbs/em05.gif" /><img src="images/post/smile/dvbbs/em01.gif" />
举报 回复(0) 喜欢(0)     评分
上一页
游客

返回顶部