PostGIS 3.0.6dev-r@@SVN_REVISION@@
Loading...
Searching...
No Matches

◆ wkblify_raster()

raster2pgsql.wkblify_raster (   options,
  infile,
  i,
  previous_gt = None 
)
Writes given raster dataset using GDAL features into HEX-encoded of
WKB for WKT Raster output.

Definition at line 916 of file raster2pgsql.py.

916def wkblify_raster(options, infile, i, previous_gt = None):
917 """Writes given raster dataset using GDAL features into HEX-encoded of
918 WKB for WKT Raster output."""
919
920 assert infile is not None, "Input file is none, expected file name"
921 assert options.version == g_rt_version, "Error: invalid WKT Raster protocol version"
922 assert options.endian == NDR, "Error: invalid endianness, use little-endian (NDR) only"
923 assert options.srid >= -1, "Error: do you really want to specify SRID = %d" % options.srid
924
925 # Open source raster file
926 ds = gdal.Open(infile, gdalc.GA_ReadOnly);
927 if ds is None:
928 sys.exit('Error: Cannot open input file: ' + str(infile))
929
930 # By default, translate all raster bands
931
932 # Calculate range for single-band request
933 if options.band is not None and options.band > 0:
934 band_range = ( options.band, options.band + 1 )
935 else:
936 band_range = ( 1, ds.RasterCount + 1 )
937
938 # Compare this px size with previous one
939 current_gt = get_gdal_geotransform(ds)
940 if previous_gt is not None:
941 if previous_gt[1] != current_gt[1] or previous_gt[5] != current_gt[5]:
942 sys.exit('Error: Cannot load raster with different pixel size in the same raster table')
943
944 # Generate requested overview level (base raster if level = 1)
945 summary = wkblify_raster_level(options, ds, options.overview_level, band_range, infile, i)
946 SUMMARY.append( summary )
947
948 # Cleanup
949 ds = None
950
951 return current_gt
952
#define str(s)