arcgissamples\raster\CreateFGDBRasterCatalog.java
/* Copyright 2015 ESRI * * All rights reserved under the copyright laws of the United States * and applicable international laws, treaties, and conventions. * * You may freely redistribute and use this sample code, with or * without modification, provided you include the original copyright * notice and use restrictions. * * See the use restrictions at <your ArcGIS install location>/DeveloperKit10.4/userestrictions.txt. * */ /* Copyright 2010 ESRI * * All rights reserved under the copyright laws of the United States * and applicable international laws, treaties, and conventions. * * You may freely redistribute and use this sample code, with or * without modification, provided you include the original copyright * notice and use restrictions. * * See the use restrictions at <your ArcGIS install location>/DeveloperKit10.0/userestrictions.txt. * */ package arcgissamples.raster; import java.io.File; import com.esri.arcgis.datasourcesGDB.FileGDBWorkspaceFactory; import com.esri.arcgis.datasourcesraster.RasterWorkspace; import com.esri.arcgis.datasourcesraster.RasterWorkspaceFactory; import com.esri.arcgis.geodatabase.*; import com.esri.arcgis.geometry.ISpatialReference; import com.esri.arcgis.geometry.UnknownCoordinateSystem; import com.esri.arcgis.geometry.esriGeometryType; import com.esri.arcgis.system.AoInitialize; import com.esri.arcgis.system.EngineInitializer; import com.esri.arcgis.system.esriLicenseProductCode; import com.esri.arcgis.system.esriLicenseStatus; public class CreateFGDBRasterCatalog { public CreateFGDBRasterCatalog() { } public static void main(String[] args) { System.out.println("Starting CreateFGDBRasterCatalog - An ArcObjects Java SDK Developer Sample"); try { // Initialize the engine and licenses. EngineInitializer.initializeEngine(); AoInitialize aoInit = new AoInitialize(); initializeArcGISLicenses(aoInit); //Get DEVKITHOME Home String devKitHome = System.getenv("AGSDEVKITJAVA"); String outputPath = getOutputDir(); String catalogName = "rastercatalog"; String rasterWorkspace = devKitHome + "java" + File.separator + "samples" + File.separator + "data" + File.separator + "raster" + File.separator + "rasterworkspace"; CreateFGDBRasterCatalog convert = new CreateFGDBRasterCatalog(); convert.convertFileRasterToGDBRaster(rasterWorkspace, outputPath, catalogName); aoInit.shutdown(); } catch(Exception e) { e.printStackTrace(); } } /** * Converts a file based raster to FGDB based raster * @param rasterWorkspace * @param catalogPath * @throws Exception */ public void convertFileRasterToGDBRaster(String rasterWorkspace, String outputPath, String catalogName) throws Exception { // create a file GDB String fgdbName = "CreateFGDBRasterCatalog.gdb"; try { createFileGDB(outputPath, fgdbName); } catch (Exception e) { System.out.println("ERROR while creating File GDB. Please check if it already exists.\n" + e.getMessage()); } //init a rasterworkspaceex FileGDBWorkspaceFactory fileGDBFactory = new FileGDBWorkspaceFactory(); IWorkspace fgdbWorkspace = fileGDBFactory.openFromFile(outputPath + File.separator + fgdbName, 0); Workspace rasterWS = new Workspace(fgdbWorkspace); if (rasterWS == null) { throw new Exception("Invalid Workspace"); } //create a raster catalog RasterCatalog rasterCatalog = new RasterCatalog(rasterWS.createRasterCatalog(catalogName, createFields(false, null, null), "shape", "raster", "defaults")); // Get the Raster datasets to be loaded RasterWorkspaceFactory inputRasterWSFactory = new RasterWorkspaceFactory(); RasterWorkspace inputRasterWorkspace = new RasterWorkspace(inputRasterWSFactory.openFromFile(rasterWorkspace, 0)); IEnumDataset edatasets = inputRasterWorkspace.getDatasets(esriDatasetType.esriDTRasterDataset); IDataset raster = edatasets.next(); int rasterFieldIndex = rasterCatalog.getRasterFieldIndex(); FeatureClass featureClass = new FeatureClass(rasterCatalog); FeatureCursor cursor = new FeatureCursor(featureClass.IFeatureClass_insert(false)); // Load each raster into the catalog while (raster != null) { IRasterDataset ds = new IRasterDatasetProxy(raster); System.out.print("Loading " + ds.getCompleteName() + "..."); IFeatureBuffer featureBuffer = featureClass.createFeatureBuffer(); // Create a RasterValue... RasterStorageDef rasterStorageDef = new RasterStorageDef(); rasterStorageDef.setCompressionType(esriRasterSdeCompressionTypeEnum.esriRasterSdeCompressionTypeRunLength); rasterStorageDef.setPyramidResampleType(rstResamplingTypes.RSP_BilinearInterpolation); rasterStorageDef.setPyramidLevel(-1); RasterValue rv = new RasterValue(); rv.setRasterDatasetByRef(ds); rv.setRasterStorageDefByRef(rasterStorageDef); // Add the raster to the catalog featureBuffer.setValue(rasterFieldIndex, rv); cursor.insertFeature(featureBuffer); raster = (edatasets.next()); System.out.println("done."); } System.out.println("\nAll rasters in " + rasterWorkspace + " loaded into " + outputPath + File.separator + fgdbName + + File.separatorChar + rasterCatalog.getName()+ "."); } /** * Creates a File Geodatabase * @param fgdbPath String * @param fgdbName String * @throws Exception */ public void createFileGDB(String fgdbPath, String fgdbName) throws Exception { if(fgdbPath == null || fgdbName == null || fgdbName.equalsIgnoreCase(" ")) { throw new Exception("\n**Error in createFileGDB(): One of the following errors has occured: " + "\n1. One or more parameters are null. " + "\n2. Supplied FGDBName has nothing but spaces. " + "\n3. Supplied FGDBPath is invalid or the directory does not exist\n"); } //Create a local FGDB. Don't, if it already exists. IWorkspaceFactory wFactory = new FileGDBWorkspaceFactory(); if(!wFactory.isWorkspace(fgdbPath + File.separator + fgdbName)) { wFactory.create(fgdbPath, fgdbName, null, 0); } } /** * Creates fields to be used in Raster table in gdb * @param bIsByRef boolean * @return IFields * @throws Exception */ public Fields createFields(boolean isByRef, ISpatialReference rasterSpatRef, ISpatialReference geoSpatRef) throws Exception { // ++ if fields are missing from input, create default Fields fields = new Fields(); // add OID field fields.addField(createOIDField("ObjectID")); // add NAME field fields.addField(createNameField("name")); // add RASTER field fields.addField(createRasterField("raster", isByRef, rasterSpatRef)); // add SHAPE field fields.addField(createShapeField("shape", geoSpatRef)); return fields; } /** * Creates NAME field * @param name String * @return IField * @throws Exception */ public IField createNameField(String name) throws Exception { Field field = new Field(); field.setName(name); field.setType(esriFieldType.esriFieldTypeString); return field; } /** * Creates Object ID field * @param oidFieldName String * @return IField * @throws Exception */ public Field createOIDField(String oidFieldName) throws Exception { Field field = new Field(); field.setName(oidFieldName); field.setType(esriFieldType.esriFieldTypeOID); return field; } /** * Creates a Raster column * @param rasterFieldName String * @param isManagedByGDB boolean * @param spatRef ISpatialReference * @return Field * @throws Exception */ public Field createRasterField(String rasterFieldName, boolean isManagedByGDB, ISpatialReference spatRef) throws Exception { Field rasterField = new Field(); rasterField.setName(rasterFieldName); rasterField.setType(esriFieldType.esriFieldTypeRaster); RasterDef rasterDef = new RasterDef(); rasterDef.setDescription("This is a test catalog"); rasterDef.setIsManaged(!isManagedByGDB); if (spatRef == null) { spatRef = new UnknownCoordinateSystem(); } rasterDef.setSpatialReferenceByRef(spatRef); rasterField.setRasterDefByRef(rasterDef); return rasterField; } /** * Creates SHAPE field * @param shapeFieldName String * @param spatRef ISpatialReference * @return IField * @throws Exception */ public Field createShapeField(String shapeFieldName, ISpatialReference spatRef) throws Exception { Field field = new Field(); field.setName(shapeFieldName); field.setType(esriFieldType.esriFieldTypeGeometry); GeometryDef geometryDef = new GeometryDef(); geometryDef.setGeometryType(esriGeometryType.esriGeometryPolygon); if (spatRef == null) { spatRef = new UnknownCoordinateSystem(); spatRef.setDomain(-10000, 10000, -10000, 10000); } geometryDef.setSpatialReferenceByRef(spatRef); geometryDef.setAvgNumPoints(2); geometryDef.setGridCount(1); geometryDef.setGridSize(0, 1000); field.setGeometryDefByRef(geometryDef); return field; } /** * Initializes the lowest available ArcGIS License */ static void initializeArcGISLicenses(AoInitialize ao) { try { if (ao.isProductCodeAvailable(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeEngine) == com.esri.arcgis.system.esriLicenseStatus.esriLicenseAvailable) ao.initialize(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeEngine); else if (ao.isProductCodeAvailable(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeBasic) == com.esri.arcgis.system.esriLicenseStatus.esriLicenseAvailable) ao.initialize(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeBasic); else if (ao.isProductCodeAvailable(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeStandard) == com.esri.arcgis.system.esriLicenseStatus.esriLicenseAvailable) ao.initialize(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeStandard); else if (ao.isProductCodeAvailable(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeAdvanced) == com.esri.arcgis.system.esriLicenseStatus.esriLicenseAvailable) ao.initialize(com.esri.arcgis.system.esriLicenseProductCode.esriLicenseProductCodeAdvanced); else { System.err.println("Could not initialize an Engine, Basic, Standard, or Advanced License. Exiting application."); System.exit(-1); } } catch (Exception e) { e.printStackTrace(); } } /** * Retrieves output directory * @return */ private static String getOutputDir() { String userDir; if (System.getProperty("os.name").toLowerCase().indexOf("win") > -1) { userDir = System.getenv("UserProfile"); } else { userDir = System.getenv("HOME"); } String outputDir = userDir + File.separator + "arcgis_sample_output"; System.out.println("Creating output directory - " + outputDir); new File(outputDir).mkdir(); return outputDir; } }