Create Buffer custom Java geoprocessing tool
arcgissamples\geoprocessing\customtool\CreateBuffer.java
/* 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.
* 
*/
package arcgissamples.geoprocessing.customtool;

import java.io.IOException;
import java.io.File;

import com.esri.arcgis.interop.AutomationException;
import com.esri.arcgis.system.IArray;
import com.esri.arcgis.system.IName;
import com.esri.arcgis.system.ITrackCancel;
import com.esri.arcgis.system.Array;
import com.esri.arcgis.datasourcesfile.DELayerType;
import com.esri.arcgis.geoprocessing.*;
import com.esri.arcgis.geodatabase.*;
import com.esri.arcgis.system.*;

public class CreateBuffer extends BaseGeoprocessingTool {
  /**
   * 
   */
  private static final long serialVersionUID = 1L;
  private String toolName = "CreateBuffer";
  private String displayName = "Java Create Buffer Tool";
  private String metadataFileName = toolName + ".xml";
  private static String sw = null;
  private GeoProcessor gp = null;

  public CreateBuffer() {
    try {
      /*
       * Initialize Geoprocessor. The Geoprocessor object represents the
       * Geoprocessing Framework and will be used to execute the system GP tool.
       */
      gp = new GeoProcessor();
      gp.setOverwriteOutput(true);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }

  /**
   * Returns name of the tool This name appears when executing the tool at the
   * command line or in scripting. This name should be unique to each toolbox
   * and must not contain spaces.
   */
  public String getName() throws IOException, AutomationException {
    return toolName;
  }

  /**
   * Returns Display Name of the tool, as seen in ArcToolbox.
   */
  public String getDisplayName() throws IOException, AutomationException {
    return displayName;
  }

  /**
   * Returns the full name of the tool
   */
  public IName getFullName() throws IOException, AutomationException {
    return (IName) new CBFunctionFactory().getFunctionName(toolName);
  }

  /**
   * Returns an array of paramInfo This is the location where the parameters to
   * the Function Tool are defined. This property returns an IArray of parameter
   * objects (IGPParameter). These objects define the characteristics of the
   * input and output parameters.
   */
  public IArray getParameterInfo() throws IOException, AutomationException {
    IArray parameters = new Array();

    GPCompositeDataType composite = new GPCompositeDataType();
    composite.addDataType(new GPFeatureLayerType());
    composite.addDataType(new DEFeatureClassType());
    composite.addDataType(new GPLayerType());
    composite.addDataType(new DELayerType());
    composite.addDataType(new GPFeatureRecordSetLayerType());

    GPParameter parameter1 = new GPParameter();
    parameter1.setName("in_features");
    parameter1.setDirection(esriGPParameterDirection.esriGPParameterDirectionInput);
    parameter1.setDisplayName("Input Features");
    parameter1.setParameterType(esriGPParameterType.esriGPParameterTypeRequired);
    parameter1.setDataTypeByRef(composite);
    parameter1.setValueByRef(new GPFeatureLayer());
    parameters.add(parameter1);

    GPParameter parameter2 = new GPParameter();
    parameter2.setName("in_distance");
    parameter2.setDirection(esriGPParameterDirection.esriGPParameterDirectionInput);
    parameter2.setDisplayName("Buffer Distance");
    parameter2.setParameterType(esriGPParameterType.esriGPParameterTypeRequired);
    parameter2.setDataTypeByRef(new GPLinearUnitType());
    parameter2.setValueByRef(new GPLinearUnit());
    parameters.add(parameter2);

    GPParameter parameter4 = new GPParameter();
    parameter4.setName("out_featureclass");
    parameter4.setDirection(esriGPParameterDirection.esriGPParameterDirectionOutput);
    parameter4.setDisplayName("Output Feature Class");
    parameter4.setParameterType(esriGPParameterType.esriGPParameterTypeRequired);
    parameter4.setDataTypeByRef(new DEFeatureClassType());
    parameter4.setValueByRef(new DEFeatureClass());
    parameters.add(parameter4);

    return parameters;
  }

  /**
   * Called each time the user changes a parameter in the tool dialog or Command
   * Line. This updates the output data of the tool, which extremely useful for
   * building models. After returning from UpdateParameters(), the GP framework
   * calls its internal validation routine to check that a given set of
   * parameter values are of the appropriate number, DataType, and value.
   */
  public void updateParameters(IArray paramvalues, IGPEnvironmentManager envMgr) {
    try {
      // Retrieve the Input Feature Set parameter
      IGPParameter inputFeatureSetParameter = (IGPParameter) paramvalues.getElement(0);
      IGPValue inputFeatureSetValue = gpUtilities.unpackGPValue(inputFeatureSetParameter);
      String inputFS = inputFeatureSetValue.getAsText();

      // retrieve the environment value for scratch workspace
      sw = gp.getEnvironmentValue("scratchWorkspace").toString();
      String outputFC = "";
      if (inputFS != null) {
        File f = new File(inputFS);
        String fileName = f.getName();
        if (fileName.contains(".")) {
          fileName = fileName.substring(0, fileName.lastIndexOf("."));
        }
        outputFC = fileName + "_buffer.shp";
      }

      // Retrieve Output Feature Class Parameter
      IGPParameter parameter4 = (IGPParameter) paramvalues.getElement(2);
      IGPValue parameter4Value = gpUtilities.unpackGPValue(parameter4);
      parameter4Value.setAsText(sw + File.separator + outputFC);
    } catch (Exception e) {
      e.printStackTrace();
    }
  }

  /**
   * Called after returning from the internal validation routine. You can
   * examine the messages created from internal validation and change them if
   * desired.
   */
  public void updateMessages(IArray paramvalues, IGPEnvironmentManager envMgr, IGPMessages gpMessages) {
    try {
      if (gpMessages.getMaxSeverity() == esriGPMessageSeverity.esriGPMessageSeverityError) {
        for (int i = 0; i < gpMessages.getCount(); i++) {
          System.out.println(gpMessages.getMessage(i).getDescription());
        }
      }
    } catch (Exception e) {
      e.printStackTrace();
    }
  }

  /**
   * Executes the tool
   */
  public void execute(IArray paramvalues, ITrackCancel trackcancel, IGPEnvironmentManager envMgr, IGPMessages messages)
    throws IOException, AutomationException {
    // Retrieve Input feature class parameter
    IGPParameter parameter1 = (IGPParameter) paramvalues.getElement(0);
    IGPValue parameter1Value = gpUtilities.unpackGPValue(parameter1);
    messages.addMessage("\nSpecified parameter1 value: " + parameter1Value.getAsText());

    // Retrieve Distance parameter
    IGPParameter parameter2 = (IGPParameter) paramvalues.getElement(1);
    IGPValue parameter2Value = gpUtilities.unpackGPValue(parameter2);
    messages.addMessage("\nSpecified parameter2 value: " + parameter2Value.getAsText());

    // Retrieve Output Parameter
    IGPParameter outputParameter = (IGPParameter) paramvalues.getElement(2);
    IGPValue outputValue = gpUtilities.unpackGPValue(outputParameter);
    if (gpUtilities.exists(outputValue)) {
      messages.addMessage("\nOutput already exists. Overwriting it...");
      gpUtilities.delete(outputValue);
    }
    String output = outputValue.getAsText();

    // Use the System GP tool to create a buffer
    VarArray array = new VarArray();
    array.add(parameter1Value.getAsText());// input features
    array.add(output);// output
    array.add(parameter2Value.getAsText());// distance
    array.add("FULL");
    array.add("ROUND");
    array.add("NONE");
    array.add("#");

    // execute buffer tool using geoprocessor
    gp.execute("Buffer_analysis", array, trackcancel);

    messages.addMessage("Output: " + output);
  }

  /**
   * Returns metadata file
   */
  public String getMetadataFile() throws IOException, AutomationException {
    return metadataFileName;
  }

  /**
   * Returns status of license
   */
  public boolean isLicensed() throws IOException, AutomationException {
    // no license checking is being done in this sample.
    return true;
  }
}