Create valid polygons
arcgissamples\geometry\CreateValidPolygons.java
/* Copyright 2012 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.geometry;

import com.esri.arcgis.geometry.*;
import com.esri.arcgis.system.*;

/**
 * This class demonstrates how to create valid polygons efficiently.
 */
public class CreateValidPolygons
{
  public CreateValidPolygons()
  {
    
  }
  
  public static void main(String[] args)
  {
    System.out.println("Starting CreateValidPolygons - An ArcObjects Java SDK Developer Sample");
    try
    {
      // Initialize the engine and licenses.
      EngineInitializer.initializeEngine();

      AoInitialize aoInit = new AoInitialize();
      initializeArcGISLicenses(aoInit);
      
      CreateValidPolygons polygons = new CreateValidPolygons();
      polygons.CreateRectanglePolygonFromEnvelope();
      polygons.createMultipartPolygonRingSegmentCollection();
      polygons.createMultipartPolygonRingPointCollection();
      polygons.createSinglepartPolygonPointCollection();
      polygons.createSinglepartPolygonSegmentCollection();

      aoInit.shutdown();
    }
    catch(Exception e)
    {
      e.printStackTrace();
    }
    
    System.out.println("Done!");
  }
  
  /**
   * Initializes the lowest available ArcGIS License
   */
  private static void initializeArcGISLicenses(AoInitialize aoInit)
  {
    try
    {
      if (aoInit.isProductCodeAvailable(esriLicenseProductCode.esriLicenseProductCodeEngine) == esriLicenseStatus.esriLicenseAvailable)
      {
        aoInit.initialize(esriLicenseProductCode.esriLicenseProductCodeEngine);
      }
      else if (aoInit.isProductCodeAvailable(esriLicenseProductCode.esriLicenseProductCodeBasic) == esriLicenseStatus.esriLicenseAvailable)
      {
        aoInit.initialize(esriLicenseProductCode.esriLicenseProductCodeBasic);
      }
      else
      {
        System.err.println("Could not initialize an Engine or Basic License. Exiting application.");
        System.exit(-1);
      }
    }
    catch (Exception e)
    {
      e.printStackTrace();
    }
  }
  
  /**
   * Create a multipart polygon using rings via an array of Line segments
   */
  private void createMultipartPolygonRingSegmentCollection() throws Exception
  {
    Ring[] ringColl = new Ring[2];
    Line line0[] = new Line[4];
    Line line1[] = new Line[4];
    Line seg0[] = new Line[4];
    Line seg1[] = new Line[4];
    Ring geometry[] = new Ring[2];
    GeometryBag gonColl = new GeometryBag();

    // *********************************************************
    // THE SPATIAL REFERENCE SHOULD BE SET HERE ON THE POLYGON
    // Here the spatial reference is created in memory but could also come from various sources:
    // IMap, IGeodataset, IGeometry etc...
    UnknownCoordinateSystem pspref = new UnknownCoordinateSystem();

    // Set the false origin and units.
    // The XYUnits value is equivalent to the precision specified when creating a feature class
    pspref.setFalseOriginAndUnits(-10000, -10000, 100000);

    gonColl.setSpatialReferenceByRef(pspref);

    // *********************************************************
    // Initialize offset values
    double d0X0 = 0, d0Y0 = 0, d0X1 = 0, d0Y1 = 0, d0X2 = 0, d0Y2 = 0, d0X3 = 0, d0Y3 = 0, d1X0 = 10000, d1Y0 = 10000, d1X1 = 10000, d1Y1 = 10000, d1X2 = 10000, d1Y2 = 10000, d1X3 = 10000, d1Y3 = 10000;

    // Initialize the points

    Point[] pointsRing0 = new Point[4];
    Point[] pointsRing1 = new Point[4];

    for (int k = 0; k <= 3; k++)
    {
      pointsRing0[k] = new Point();
      pointsRing1[k] = new Point();
    }

    // Loop to change the coordinates of the points
    for (int i = 0; i <= 1000; i++)
    {
      ringColl[0] = new Ring();
      ringColl[1] = new Ring();

      // Lines are passed by reference to the polygon
      // so a new line has to be instantiated to avoid the polygon being degenerated
      for (int k = 0; k <= 3; k++)
      {
        line0[k] = new Line();
        line1[k] = new Line();
        seg0[k] = line0[k];
        seg1[k] = line1[k];
      }
      geometry[0] = ringColl[0];
      geometry[1] = ringColl[1];
      d0X0 = d0X0 - 5;
      d0Y0 = d0Y0 - 5;
      d0X1 = d0X1 + 5;
      d0Y1 = d0Y1 - 5;
      d0X2 = d0X2 + 5;
      d0Y2 = d0Y2 + 5;
      d0X3 = d0X3 - 5;
      d0Y3 = d0Y3 + 5;

      // Put the coordinates of the points to use in the first ring
      pointsRing0[0].putCoords(d0X0, d0Y0);
      pointsRing0[1].putCoords(d0X1, d0Y1);
      pointsRing0[2].putCoords(d0X2, d0Y2);
      pointsRing0[3].putCoords(d0X3, d0Y3);
      d1X0 = d1X0 - 5;
      d1Y0 = d1Y0 - 5;
      d1X1 = d1X1 + 5;
      d1Y1 = d1Y1 - 5;
      d1X2 = d1X2 + 5;
      d1Y2 = d1Y2 + 5;
      d1X3 = d1X3 - 5;
      d1Y3 = d1Y3 + 5;

      // Put the coordinates of the points to use in the second ring
      pointsRing1[0].putCoords(d1X0, d1Y0);
      pointsRing1[1].putCoords(d1X1, d1Y1);
      pointsRing1[2].putCoords(d1X2, d1Y2);
      pointsRing1[3].putCoords(d1X3, d1Y3);

      // Put the coordinates of the lines
      line0[0].putCoords(pointsRing0[0], pointsRing0[1]);
      line0[1].putCoords(pointsRing0[1], pointsRing0[2]);
      line0[2].putCoords(pointsRing0[2], pointsRing0[3]);
      line0[3].putCoords(pointsRing0[3], pointsRing0[0]);
      line1[0].putCoords(pointsRing1[0], pointsRing1[1]);
      line1[1].putCoords(pointsRing1[1], pointsRing1[2]);
      line1[2].putCoords(pointsRing1[2], pointsRing1[3]);
      line1[3].putCoords(pointsRing1[3], pointsRing1[0]);

      GeometryEnvironment gBridge = new GeometryEnvironment();

      // Add the segments to the rings
      gBridge.addSegments(ringColl[0], seg0);
      gBridge.addSegments(ringColl[1], seg1);

      // Add the rings to the polygon
      gBridge.addGeometries(gonColl, geometry);
    }

    // You can draw, store or use the polygon (gonColl) in other geometry operations at this point
  }

  /**
   * Create a multipart polygon using rings via a collection of Points
   */

  private void createMultipartPolygonRingPointCollection() throws Exception
  {
    Point pointsRing0[] = new Point[5];
    Point pointsRing1[] = new Point[5];
    Ring ringsColl[] = new Ring[2];
    IGeometry[] geometry = new IGeometry[2];

    // Create the resulting polygon
    Polygon gonColl = new Polygon();

    // *********************************************************
    // THE SPATIAL REFERENCE SHOULD BE SET HERE ON THE POLYGON
    // Here the spatial reference is created in memory but could also come from various sources:
    // IMap, IGeodataset, IGeometry etc...
    ISpatialReference pspref = new UnknownCoordinateSystem();

    // Set the false origin and units.
    // The XYUnits value is equivalent to the precision specified when creating a feature class
    pspref.setFalseOriginAndUnits(-10000, -10000, 100000);
    gonColl.setSpatialReferenceByRef(pspref);

    // *********************************************************
    double d0X0 = 0, d0Y0 = 0, d0X1 = 0, d0Y1 = 0, d0X2 = 0, d0Y2 = 0, d0X3 = 0, d0Y3 = 0, d1X0 = 10000, d1Y0 = 10000, d1X1 = 10000, d1Y1 = 10000, d1X2 = 10000, d1Y2 = 10000, d1X3 = 10000, d1Y3 = 10000;
    // Loop to change the coordinates of the points
    for (int i = 0; i <= 1000; i++)
    {
      ringsColl[0] = new Ring();
      ringsColl[1] = new Ring();
      geometry[0] = ringsColl[0];
      geometry[1] = ringsColl[1];

      // Create the new points
      for (int k = 0; k <= 4; k++)
      {
        pointsRing0[k] = new Point();
        pointsRing1[k] = new Point();
      }
      d0X0 = d0X0 - 5;
      d0Y0 = d0Y0 - 5;
      d0X1 = d0X1 + 5;
      d0Y1 = d0Y1 - 5;
      d0X2 = d0X2 + 5;
      d0Y2 = d0Y2 + 5;
      d0X3 = d0X3 - 5;
      d0Y3 = d0Y3 + 5;

      // Put the coordinates of the points to use in the first ring
      pointsRing0[0].putCoords(d0X0, d0Y0);
      pointsRing0[1].putCoords(d0X1, d0Y1);
      pointsRing0[2].putCoords(d0X2, d0Y2);
      pointsRing0[3].putCoords(d0X3, d0Y3);
      pointsRing0[4].putCoords(d0X0, d0Y0);
      IGeometryBridge gBridge = new GeometryEnvironment();

      // Add the points to the ring
      gBridge.addPoints(ringsColl[0], pointsRing0);
      d1X0 = d1X0 - 5;
      d1Y0 = d1Y0 - 5;
      d1X1 = d1X1 + 5;
      d1Y1 = d1Y1 - 5;
      d1X2 = d1X2 + 5;
      d1Y2 = d1Y2 + 5;
      d1X3 = d1X3 - 5;
      d1Y3 = d1Y3 + 5;

      // Put the coordinates of the points to use in the second ring
      pointsRing1[0].putCoords(d1X0, d1Y0);
      pointsRing1[1].putCoords(d1X1, d1Y1);
      pointsRing1[2].putCoords(d1X2, d1Y2);
      pointsRing1[3].putCoords(d1X3, d1Y3);
      pointsRing1[4].putCoords(d1X0, d1Y0);

      // Add the points to the ring
      gBridge.addPoints(ringsColl[1], pointsRing1);

      // Add the rings to the polygon
      gBridge.addGeometries(gonColl, geometry);
    }
    // You can draw, store or use the polygon (gonColl) in other geometry operations at this point
  }

  /**
   * Create a single part polygon via a collection of Points
   */
  private void createSinglepartPolygonPointCollection() throws Exception
  {
    Point pt[] = new Point[5];
    Polygon gonColl = new Polygon();

    // *********************************************************
    // THE SPATIAL REFERENCE SHOULD BE SET HERE ON THE POLYGON
    // Here the spatial reference is created in memory but could also come from various sources:
    // IMap, IGeodataset, IGeometry etc...
    UnknownCoordinateSystem pspref = new UnknownCoordinateSystem();

    // Set the false origin and units.
    // The XYUnits value is equivalent to the precision specified when creating a feature class
    pspref.setFalseOriginAndUnits(-10000, -10000, 100000);
    gonColl.setSpatialReferenceByRef(pspref);

    // *********************************************************
    // Initialize the points
    for (int i = 0; i <= 4; i++)
    {
      pt[i] = new Point();
    }
    pt[0].putCoords(0, 0);
    pt[1].putCoords(10, 0);
    pt[2].putCoords(10, 10);
    pt[3].putCoords(0, 10);
    pt[4].putCoords(0, 0);
    GeometryEnvironment gBridge = new GeometryEnvironment();

    // Add the points to the polygon
    gBridge.addPoints(gonColl, pt);

    // You can draw, store or use the polygon (gonColl) in other geometry operations at this point
  }

  /**
   * Create a single part polygon via a collection of Line segments.
   */
  private void createSinglepartPolygonSegmentCollection() throws Exception
  {
    Point pt[] = new Point[5];
    Line[] line = new Line[4];
    Line[] segment = new Line[4];
    Polygon gonColl = new Polygon();
    // *********************************************************
    // THE SPATIAL REFERENCE SHOULD BE SET HERE ON THE POLYGON
    // Here the spatial reference is created in memory but could also come from various sources:
    // IMap, IGeodataset, IGeometry etc...
    UnknownCoordinateSystem pspref = new UnknownCoordinateSystem();
    pspref.setFalseOriginAndUnits(-10000, -10000, 100000);
    // Set the false origin and units.
    // The XYUnits value is equivalent to the precision specified when creating a feature class
    gonColl.setSpatialReferenceByRef(pspref);

    // *********************************************************
    // Initialize things
    for (int i = 0; i <= 3; i++)
    {
      line[i] = new Line();
      pt[i] = new Point();
      segment[i] = line[i];
    }
    // Put the coordinates of the points
    pt[0].putCoords(0, 0);
    pt[1].putCoords(10, 0);
    pt[2].putCoords(10, 10);
    pt[3].putCoords(0, 10);
    // Put the coordinates of the line
    line[0].putCoords(pt[0], pt[1]);
    line[1].putCoords(pt[1], pt[2]);
    line[2].putCoords(pt[2], pt[3]);
    line[3].putCoords(pt[3], pt[0]);
    GeometryEnvironment gBridge = new GeometryEnvironment();
    // Add the segments in the polygon via the ISegmentCollection
    gBridge.addSegments(gonColl, segment);
    // You can draw or store the polygon (gonColl)
  }

  /**
   * Convert an envelope to a polygon
   */
  private void CreateRectanglePolygonFromEnvelope() throws Exception
  {
    Envelope pEnvelope = new Envelope();

    // *********************************************************
    // THE SPATIAL REFERENCE SHOULD BE SET HERE ON THE ENVELOPE
    // Here the spatial reference is created in memory but could also come from various sources:
    // IMap, IGeodataset, IGeometry etc...
    UnknownCoordinateSystem pspref = new UnknownCoordinateSystem();

    // Set the false origin and units.
    // The XYUnits value is equivalent to the precision specified when creating a feature class
    pspref.setFalseOriginAndUnits(-10000, -10000, 100000);

    pEnvelope.setSpatialReferenceByRef(pspref);

    // *********************************************************
    pEnvelope.putCoords(0, 0, 100, 100);
    Polygon segmentColl = new Polygon();
    segmentColl.setRectangle(pEnvelope);
    // This is transferring the spatial reference
    // You can draw or store the polygon (segmentColl)
  }

}