Arcgis镶嵌数据集java代码操作
转自: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代码操作的更多相关文章
- Java代码操作HDFS测试类
1.Java代码操作HDFS需要用到Jar包和Java类 Jar包: hadoop-common-2.6.0.jar和hadoop-hdfs-2.6.0.jar Java类: java.net.URL ...
- 使用java代码操作Redis
1导入pom.xml依赖 <dependency> <groupId>redis.clients</groupId> <artifactId>jedis ...
- java代码操作Redis
1.导入需要的pom依赖 <properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEn ...
- Java代码操作zookeeper
.personSunflowerP { background: rgba(51, 153, 0, 0.66); border-bottom: 1px solid rgba(0, 102, 0, 1); ...
- 分享知识-快乐自己:java代码 操作 solr
POM 文件: <!-- solr客户端 --> <dependency> <groupId>org.apache.solr</groupId> < ...
- 大数据之路week07--day01(HDFS学习,Java代码操作HDFS,将HDFS文件内容存入到Mysql)
一.HDFS概述 数据量越来越多,在一个操作系统管辖的范围存不下了,那么就分配到更多的操作系统管理的磁盘中,但是不方便管理和维护,因此迫切需要一种系统来管理多台机器上的文件,这就是分布式文件管理系统 ...
- java:nginx(java代码操作ftp服务器)
1.检查是否安装了vsftpd [root@linux01 ~]# rpm -qa|grep vsftpd 2.安装vsftpd [root@linux01 ~]# yum -y install vs ...
- Java代码操作HDFS(在/user/root/下面創建目錄)
1.创建HDFS目录并打成jar包 package Hdfs; import java.io.IOException; import java.net.URI; import org.apache.h ...
- kerberos下JAVA代码操作hbase的方式(客户端方式,应用程序方式)
(一)如果部署JAVA 代码的主机用户获取了kerberos权限情况下 假设主机名是:client su - client 登录主机后 kinit -kt /keytab的路径/client.keyt ...
随机推荐
- linux下TUN/TAP虚拟网卡的使用
转载:http://wushank.blog.51cto.com/3489095/1306849 tun/tap 驱动程序实现了虚拟网卡的功能,tun表示虚拟的是点对点设备,tap表示虚拟的是以太网设 ...
- css精灵(css script 技术)
上班差不多有15天了,感觉每天都有写不完的也页面,每天都有不同的东西需要学习进步,很充实哦.今天接触到css精灵这个东西.其实之前有看过这种技术,但是没有操作过,只是听说这个技术很强大,能干嘛干嘛,但 ...
- Win7/8在用账户密码登录时, 设置成保留用户名, 只输入密码
修改注册表, 0表示保留用户名. 1表示每次都需要输入用户名密码. 位置: HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersio ...
- FtpManager类
public class FtpManager { /// <summary> /// 主机名 /// </summary> string ftpServerIP; /// & ...
- js this [转]
this是js的一个关键字,随着函数使用场合不同,this的值会发生变化.但是总有一个原则,那就是this指的是调用函数的那个对象. 1.纯粹函数调用. function test() { this. ...
- 基于原生js的图片延迟加载
当页面图片比较多的时候,我们通常会做一个延迟加载,避免页面打开时一下子的请求数太多,加载过慢影响用户体验. 如果项目用了jquery框架,则可以直接用 jquery.lazyload.可在jquery ...
- Tomcat中配置自定义404错误页面
404,50x这种错误经常遇到. 如果%CATALINA_HOME%\conf\web.xml和具体应用中都有设置%CATALINA_HOME%\webapps\ROOT\WEB-INF\web.xm ...
- Android最新源码4.3下载-教程 2013-11
Android最新源码4.3下载-教程 有的下载会出现问题: 需要 修改manifest.xml中的fetch: "git://Android.git.linaro.org/" ...
- java.lang.Math类,方法学习笔记
/**java.lang 包中的Math 类提供有常量 * 并包含有用于执行基本数学运算的 * 方法,如初等指数.对数.平方根 * 用于进行更高级的数学运算.由于 * 在Math 类的方法都是静态的, ...
- Hdu 5050 Divided Land
题目要求就是做求两个二进制数的gcd,如果是用java的话,这题很简单.但也可以用C++做,只能先给自己留下这个坑了,还在研究c++的做法. import java.math.BigInteger; ...