This function method returns a new grid definition with the same spatial extent as the original but in a different coordinate system. It preserves the spatial extent, rows, and columns from the original grid. Use this method to reproject a raster to a new coordinate system.
            Example
            
            e = ENVI()
             
            
            file = FILEPATH('qb_boulder_msi', ROOT_DIR=e.ROOT_DIR, $
              SUBDIRECTORY = ['data'])
            raster = e.OpenRaster(file)
             
            
            PixelSize = raster.SPATIALREF.PIXEL_SIZE
            CoordSysString = raster.SPATIALREF.COORD_SYS_STR
            NumRows = raster.NROWS
            NumCols = raster.NCOLUMNS
            TiePointMap = raster.SPATIALREF.TIE_POINT_MAP
            TiePointPixel = raster.SPATIALREF.TIE_POINT_PIXEL
            CoordSys = ENVICoordSys(COORD_SYS_STR=CoordSysString)
             
            
            GridDefGeo = ENVIGridDefinition(CoordSys, $
              PIXEL_SIZE=PixelSize, $
              NROWS=NumRows, $
              NCOLUMNS=NumCols, $
              TIE_POINT_MAP=TiePointMap, $
              TIE_POINT_PIXEL=TiePointPixel)
             
            
            UTMCoordSys = ENVICoordSys(COORD_SYS_CODE=32611)
            GridDefUTM = GridDefGeo.CreateGridFromCoordSys(UTMCoordSys)
            ReprojectedRaster = ENVISpatialGridRaster(raster, $
              GRID_DEFINITION=GridDefUTM)
             
            
            View = e.GetView()
            Layer = View.CreateLayer(ReprojectedRaster)
            Syntax
            Result = ENVIGridDefinition.CreateGridFromCoordSys(CoordSys) 
            Arguments
            CoordSys
            Specify an ENVICoordSys object indicating the coordinate system that the raster will reproject to.
            Keywords
            ERROR
            Set this keyword to a named variable that will contain any error message issued during execution of this routine. If no error occurs, the ERROR variable will be set to a null string (''). If an error occurs and the routine is a function, then the function result will be undefined.
            When this keyword is not set and an error occurs, ENVI returns to the caller and execution halts. In this case, the error message is contained within !ERROR_STATE and can be caught using IDL's CATCH routine. See IDL Help for more information on !ERROR_STATE and CATCH.
            See Manage Errors for more information on error handling in ENVI programming.
            Version History
            
            See Also
            ENVIGridDefinition, ENVICoordSys