初学ArcEngine开发,看到这么多的类和接口有点让人望而生畏,不好好整理思路容易让人发晕,其实熟悉了ARCGIS各组件的功能,了解了各种操作的设计思路,拿着各种文档顺藤摸瓜,还是可以迅速进入开发角色的。整个SDK结构组成的分析留到后面,我们先学习一个最小的开发示例,例子来源于ArcEngine开发文档(HelloCentroid)。
例子的功能:
返回某shapefile文件第一个feature质心的坐标。
引用的包:
importcom.esri.ARCGIS.datasourcesfile.ShapefileWorkspaceFactory;
importcom.esri.ARCGIS.geodatabase.*;
importcom.esri.ARCGIS.geometry.*;
importcom.esri.ARCGIS.system.*;
每个包的具体用途与功能先不管,以后的学习中会慢慢涉及到并加以分析。
从文件路径中捕获shapefile特征类:
privateFeatureClass getShapefileFeatureClass(String path, String name)throwsIOException{
FeatureClass featureClass=null;
try{
ShapefileWorkspaceFactory shapefileWorkspaceFactory=newShapefileWorkspaceFactory();
Workspace workspace=(Workspace) shapefileWorkspaceFactory.openFromFile(path,0);
featureClass=newFeatureClass(workspace.openFeatureClass(name));
}
catch(IOException ex){
System.out.println("Could not open shapefile:"+name);
throwex;
}returnfeatureClass;
}
调用ShapefileWorkspaceFactory工厂类的对象的方法openFromFile,将指定的路径列为工作空间,然后打开工作空间中指定名称的特征类,参数传入FeatureClass的构造方法中,返回FeatureClass对象。
ShapefileWorkspaceFactory工厂类除了可以返回指定的工作空间外,还可以创建、移动、复制工作空间,以及得到工作空间相关的基本信息。
在com.esri.arcgis.geodatabase包中可以找到Workspace类,它的方法有许多,涉及和工作空间相关的许多功能,例如连接到工作空间的数据库名称、用户名称,开始/停止编辑工作空间,创建和删除注记类、特征类、特征数据集、关联类,判断工作空间中某种操作能否执行,工作空间的基本信息,判断对象是否注册为版本等等。代码中所用到的openFeatureClass用于打开已存在的特征类并返回为IFeatureClass。
FeatureClass类的构造方法接收workspace.openFeatureClass返回的参数,将对象的引用赋给featureClass对象并返回。
这个方法的核心应该关注Workspace类,它把握着Geodatabase数据的整体框架与功能导向,FeatureClass是Workspace组成部分,包含了FeatureClass特定的功能与方法。
得到特征类的质心位置:
privatevoidprintFirstFeatureCentroid(FeatureClass featureClass)throwsIOException{
////Get the first feature in the feature class.
//
IFeature feature=featureClass.getFeature(0);
////Get the shape of the feature, and if the shape is a polygon or ring,
//get its centroid by casting it to the interface common to both of them (IArea),
//which interface defines the getCentroid method.
//
IGeometry shape=feature.getShape();
if(!(shapeinstanceofPolygon||shapeinstanceofRing)){
System.out.println("Feature's shape is neither a polygon nor a ring. No centroid available.");
return;
} IArea area=(IArea) shape;
IPoint centroid=area.getCentroid();
System.out.println("Centroid:"+centroid.getX()+","+centroid.getY());
}
featureClass对象的getFeature(0)方法得到特征类中第一个feature,通过判断确定该feature为区或环,将该feature所对应的shape uppercast为IArea类型,由getCentroid方法得到area对象的质心点,getX()和getY()输出该点的坐标。IGeometry、IArea、IPoint都是com.esri.arcgis.geometry包中的接口,指定了不同的几何类型。由printFirstFeatureCentroid方法,我们可以扩展学习com.esri.arcgis.geometry包中典型接口的使用,例如示例中用到的接口,其包含的方法都很简单。
main方法:
publicstaticvoidmain(String[] args){
if(args.length!=2){
System.out.println("Usage: HelloCentroid shapefilePath shapefileName");
System.exit(1);
} System.out.println("Hello, Centroid!");
AoInitialize aoInitializer=null;
try{
EngineInitializer.initializeEngine();
aoInitializer=newAoInitialize();
aoInitializer.initialize(esriLicenseProductCode.esriLicenseProductCodeEngine);
HelloCentroid thisApp=newHelloCentroid();
////Get the feature class for the path and name specified,
//and get its first feature's centroid.
//
FeatureClass featureClass=thisApp.getShapefileFeatureClass(args[0], args[1]);
if(featureClass!=null){
thisApp.printFirstFeatureCentroid(featureClass);
} }
catch(IOException ex){
ex.printStackTrace();
System.out.println("App failed.");
}
finally{
try{
aoInitializer.shutdown();
}
catch(IOException ex){
ex.printStackTrace();
} }}
从前面的四行代码可以看出,java解释器运行该类文件编译后的字节码需要两个参数,一个是featureclass所在的路径,一个是该路径下featureclass名称。需要注意的是这三行代码:
EngineInitializer.initializeEngine();
aoInitializer=newAoInitialize();
aoInitializer.initialize(esriLicenseProductCode.esriLicenseProductCodeEngine);
com.esri.arcgis.system.EngineInitializer.initializeEngine(),在原始AO组件和Java Class之间建立联系,如果要使用ArcGIS Visual JavaBeans进行图形操作,则应使用initializeVisualBeans静态方法进行初始化。aoInitializer对象决定不同的授权和扩展,ESRI License Product codes参考下列表:
Eclipse运行测试,需要在"运行"中输入两个"自变量"作为参数,采用ArcGIS自带的数据,分别为
"ArcGISHome\ArcTutor\Getting_Started\project\City_share\land"、"parcel_1"
测试的结果,控制台输出为:
Hello, Centroid!
Centroid: 479049.62060511723, 3771922.345004217
这个例子描述了一个最简单AE开发的整个过程,从初始化、授权,到Workspace类、FeatureClass类方法,到com.esri.arcgis.geometry包中典型接口的使用,最后得到我们需要的结果,过程清晰明了,初学者可以通过这个例子顺藤摸瓜,敲开AE开发的大门,说的有点玄乎:)