Arcgis镶嵌数据集java代码操作

摘要:
为什么使用细分数据集?可扩展性海量图像管理重叠图像管理管理离散数据集大量空值区域多个传感器数据支持平滑图像更新在所有尺度上无缝显示保留有价值的元数据信息动态处理减少处理时间减少冗余存储减少重采样,提高图像质量开发代码使用java调用ArcEngine环境。首先初始化AE运行时环境[java]viewplatecopyprint?

转自:http://www.cdtarena.com/javapx/201307/9105.html

镶嵌数据集结合了之前arcgis管理影像的栅格目录和栅格数据集,为解决海量影像管理提供了很好的方案!
为什么要使用镶嵌数据集?
•可伸缩性海量影像管理 
•重叠影像管理
•管理离散数据集大量的空值区域
•多种传感器数据支持
•流畅的影像更新
•所有比例尺下无缝显示
•保留有价值的元数据信息
•动态处理减少处理时间
•减少冗余存储
•减少重采样,提升影像质量
开发代码使用java调用ArcEngine环境。
首先初始化AE运行环境

[java] view plaincopyprint?
01./** 
02.     * 初始化ArcgisEngine 
03.     */  
04.    public static void initializeAE() {  
05.        EngineInitializer.initializeVisualBeans();  
06.        EngineInitializer.initializeEngine();  
07.        try {  
08.            com.esri.arcgis.system.AoInitialize ao = new com.esri.arcgis.system.AoInitialize();  
09.            ao.initialize(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeArcInfo);  
10.            if (ao.isProductCodeAvailable(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeArcInfo) == com.esri.arcgis.system.esriLicenseStatus.esriLicenseAvailable)  
11.                ao.initialize(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeArcInfo);  
12.            else  
13.                System.out.println("license failed");  
14.            ao.checkOutExtension(com.esri.arcgis.system.esriLicenseExtensionCode.esriLicenseExtensionCode3DAnalyst);
15.            ao.checkOutExtension(com.esri.arcgis.system.esriLicenseExtensionCode.esriLicenseExtensionCodeSpatialAnalyst);  
16.            ao.checkOutExtension(com.esri.arcgis.system.esriLicenseExtensionCode.esriLicenseExtensionCodeSpatialAnalyst);  
17.            ao.initialize(esriLicenseProductCode.esriLicenseProductCodeEngine);  
18.            ao.initialize(esriLicenseProductCode.esriLicenseProductCodeEngineGeoDB);  
19.            ao.initialize(esriLicenseProductCode.esriLicenseProductCodeArcEditor);  
20.            ao.checkOutExtension(esriLicenseExtensionCode.esriLicenseExtensionCodeSpatialAnalyst);  
21.            System.out.println("arcgis初始化成功>>>...");  
22.        } catch (Exception e) {  
23.            e.printStackTrace();  
24.        }  
25.    }  
添加栅格影像到镶嵌数据集,本次测试的整个文件目录,存入镶嵌数据集

[java] view plaincopyprint?
01./** 
02.     * 添加镶嵌数据集栅格数据 
03.     * @param mosaicDataset 镶嵌数据集 
04.     * @param path 文件存储路径 
05.     */  
06.    public void addMosaicDataSet(String mosaicDataset, String path){  
07.        GeoProcessor geoprocessor;  
08.        try {  
09.            geoprocessor = new GeoProcessor();  
10.            geoprocessor.setOverwriteOutput(true);  
11.              
12.            AddRastersToMosaicDataset addMosaicDataSet = new AddRastersToMosaicDataset();  
13.            addMosaicDataSet.setInMosaicDataset(mosaicDataset);//1   
14.            addMosaicDataSet.setRasterType("Raster Dataset");//2   
15.            addMosaicDataSet.setInputPath(path);//待入库的文件目录   
16.            addMosaicDataSet.setFilter("*.tif");//匹配入镶嵌数据集中的文件类型   
17.            addMosaicDataSet.setUpdateOverviews("true");  
18.              
19.            /** ALLOW_DUPLICATES 全部添加 
20.             * EXCLUDE_DUPLICATES 只添加更新的 
21.             * OVERWRITE_DUPLICATES 重写以前添加的  
22.             * */  
23.            addMosaicDataSet.setDuplicateItemsAction("EXCLUDE_DUPLICATES");  
24.            GPTool pGPProcess = addMosaicDataSet;  
25.            geoprocessor.setOverwriteOutput(true);  
26.            //执行   
27.            geoprocessor.execute(pGPProcess, null);  
28.        } catch (UnknownHostException e) {  
29.            // TODO Auto-generated catch block   
30.            e.printStackTrace();  
31.        } catch (IOException e) {  
32.            // TODO Auto-generated catch block   
33.            e.printStackTrace();  
34.        }  
35.    }  
移除镶嵌数据中个别数据http://www.cdtarena.com/qrs.html

[java] view plaincopyprint?
01./** 
02. * 移除镶嵌数据集中的数据 
03. * @param mosaicDataset 镶嵌数据集 
04. * @param sql 删除命令  例如:name='004' 
05. *  
06. */  
07.public void remoMosaicDataSet (String mosaicDataset, String sql) {  
08.    GeoProcessor geoprocessor = null;  
09.    try {  
10.        geoprocessor = new GeoProcessor();  
11.        geoprocessor.setOverwriteOutput(true);  
12.          
13.        RemoveRastersFromMosaicDataset deleteFeatures = new RemoveRastersFromMosaicDataset();  
14.        deleteFeatures.setInMosaicDataset(mosaicDataset);  
15.        deleteFeatures.setWhereClause(sql);  
16.          
17.        GPTool pGPProcess = deleteFeatures;  
18.        geoprocessor.setOverwriteOutput(true);  
19.        //执行   
20.        geoprocessor.execute(pGPProcess, null);  
21.    } catch (AutomationException e) {  
22.        // TODO Auto-generated catch block   
23.        e.printStackTrace();  
24.    } catch (IOException e) {  
25.        // TODO Auto-generated catch block   
26.        e.printStackTrace();  
27.    }  
28.}  
构建金字塔

[java] view plaincopyprint?
01./** 
02.     * 创建金字塔 
03.     * @param mosaicDataset 镶嵌数据集路径 
04.     * @param whereSql 查询条件,wheresql可以为空 
05.     */  
06.    public void buildOverviewsMosaicDataSet (String mosaicDataset, String whereSql) {  
07.        GeoProcessor geoprocessor = null;  
08.        try {  
09.            geoprocessor = new GeoProcessor();//初始化gp工具   
10.            geoprocessor.setOverwriteOutput(true);  
11.              
12.            BuildOverviews buildPryramids = new BuildOverviews();  
13.            buildPryramids.setInMosaicDataset(mosaicDataset);  
14.            if (whereSql != null && whereSql.equals("") == false) {  
15.                buildPryramids.setWhereClause(whereSql);  
16.            }  
17.            GPTool pGPProcess = buildPryramids;  
18.            geoprocessor.setOverwriteOutput(true);  
19.            //执行   
20.            geoprocessor.execute(pGPProcess, null);  
21.            Constant.printLnData("切割金字塔成功 :"+pGPProcess.getParameterValues()[0]);  
22.        } catch (AutomationException e) {  
23.            // TODO Auto-generated catch block   
24.            e.printStackTrace();  
25.            Constant.printLnData("切割金字塔失败 " + e.getMessage());  
26.        } catch (IOException e) {  
27.            // TODO Auto-generated catch block   
28.            e.printStackTrace();  
29.            Constant.printLnData("切割金字塔失败 "+ e.getMessage());  
30.        }  
31.    }  
创建轮廓

[java] view plaincopyprint?
01./** 
02.     * 创建轮廓 
03.     * @param mosaicDataset 镶嵌数据集 
04.     */  
05.    public void buildFootprints (String mosaicDataset) {  
06.        GeoProcessor geoprocessor = null;  
07.        try {  
08.            geoprocessor = new GeoProcessor();  
09.            geoprocessor.setOverwriteOutput(true);  
10.  
11.            BuildFootprints buildPryramids = new BuildFootprints();  
12.            buildPryramids.setInMosaicDataset(mosaicDataset);  
13.              
14.            GPTool pGPProcess = buildPryramids;  
15.            geoprocessor.setOverwriteOutput(true);  
16.            //执行   
17.            geoprocessor.execute(pGPProcess, null);  
18.            Constant.printLnData("构建轮廓成功 :"+pGPProcess.getParameterValues()[0]);  
19.        } catch (AutomationException e) {  
20.            // TODO Auto-generated catch block   
21.            e.printStackTrace();  
22.            Constant.printLnData("构建轮廓失败" + e.getMessage());  
23.        } catch (IOException e) {  
24.            // TODO Auto-generated catch block   
25.            e.printStackTrace();  
26.            Constant.printLnData("构建轮廓失败"+ e.getMessage());  
27.        }  
28.    }  
/
上述就是基本操作代码。

免责声明:文章转载自《Arcgis镶嵌数据集java代码操作》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇Ubuntu16.04上使用git[心得体会]mysql复习下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

arcgis 如何改变字段的别名

public void ChangeFieldAliasName(ITable pTable, string pOriFieldName, string pDesFieldName){IClassSchemaEdit pClassSchemaEdit = (IClassSchemaEdit)pTable;//给对象加上锁ISchemaLock pSchem...

(四)WebGIS中通过行列号来换算出多种瓦片的URL 之离线地图

文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.前言 在前面我花了两个篇幅来讲解行列号的获取,也解释了为什么要获取行列号。在这一章,我将把常见的几种请求瓦片时的URL样式罗列出来,并且给出大致的解释。 我在这里将地图分为离线地图和在线地图。所谓离线地图,即保存在本地而没有发...

ArcGIS之通过Model Builder执行地理处理

ArcGIS中模型构建器是一个用来创建、编辑和管理模型的应用程序。模型是将一系列地理处理工具串联在一起的工作流,它将其中一个工具的输出作为另一个工具的输入。也可以将模型构建器看成是用于构建工作流的可视化编程语言。现根据国外某示例数据,在ArcGIS10.1演示一下Model Builder的使用方法。 1.打开示例数据(mxd文档) 2.从主菜单中,打开...

ArcGIS 获得三角形内切圆

如何求三角形的内心坐标来自:https://zhidao.baidu.com/question/158982463.html 三角形边长为a,b,c,顶点为A(x1,y1)B(x2,y2)C(x3,y3),并给出证明 内心是角平分线的交点,到三边距离相等. 设:在三角形ABC中,三顶点的坐标为:A(x1,y1),B(x2,y2),C(x3,y3) BC=...

arcgis 要素服务增删改查

两种方式: 第一种 要素服务的增删改操作,在ArcGIS API for JS中给我们提供了三个类用于要素的增Add,删Delete,改Update 添加draw和要素服务 //用于操作的要素图层,注意我们是操作的宿舍楼图层 var featureLayer = new FeatureLayer("http://lo...

etopo1 arcmap 制图

下载地址 https://www.ngdc.noaa.gov/mgg/global/global.html 下载的flt格式的etopo1文件转换成arcmap中的raster格式. (应有flt格式数据文件和头文件hdr格式的文件,共2个,否则转换报错) (1)格式转换 (a)python import arcpyarcpy.FloatToRaster_...