PostGIS  3.4.0dev-r@@SVN_REVISION@@

◆ rt_raster_from_band()

rt_raster rt_raster_from_band ( rt_raster  raster,
uint32_t *  bandNums,
int  count 
)

Construct a new rt_raster from an existing rt_raster and an array of band numbers.

Parameters
raster: the source raster
bandNums: array of band numbers to extract from source raster and add to the new raster (0 based)
count: number of elements in bandNums
Returns
a new rt_raster or NULL on error

Definition at line 1463 of file rt_raster.c.

1463  {
1464  rt_raster rast = NULL;
1465  int i = 0;
1466  int j = 0;
1467  int idx;
1468  int32_t flag;
1469  double gt[6] = {0.};
1470 
1471  assert(NULL != raster);
1472  assert(NULL != bandNums);
1473 
1474  RASTER_DEBUGF(3, "rt_raster_from_band: source raster has %d bands",
1476 
1477  /* create new raster */
1478  rast = rt_raster_new(raster->width, raster->height);
1479  if (NULL == rast) {
1480  rterror("rt_raster_from_band: Out of memory allocating new raster");
1481  return NULL;
1482  }
1483 
1484  /* copy raster attributes */
1487 
1488  /* srid */
1489  rt_raster_set_srid(rast, raster->srid);
1490 
1491  /* copy bands */
1492  for (i = 0; i < count; i++) {
1493  idx = bandNums[i];
1494  flag = rt_raster_copy_band(rast, raster, idx, i);
1495 
1496  if (flag < 0) {
1497  rterror("rt_raster_from_band: Could not copy band");
1498  for (j = 0; j < i; j++) rt_band_destroy(rast->bands[j]);
1500  return NULL;
1501  }
1502 
1503  RASTER_DEBUGF(3, "rt_raster_from_band: band created at index %d",
1504  flag);
1505  }
1506 
1507  RASTER_DEBUGF(3, "rt_raster_from_band: new raster has %d bands",
1509  return rast;
1510 }
void rterror(const char *fmt,...)
Wrappers used for reporting errors and info.
Definition: rt_context.c:219
#define RASTER_DEBUGF(level, msg,...)
Definition: librtcore.h:306
void rt_band_destroy(rt_band band)
Destroy a raster band.
Definition: rt_band.c:340
int count
Definition: genraster.py:57
raster
Be careful!! Zeros function's input parameter can be a (height x width) array, not (width x height): ...
Definition: rtrowdump.py:121
gt
Definition: window.py:78
void rt_raster_set_geotransform_matrix(rt_raster raster, double *gt)
Set raster's geotransform using 6-element array.
Definition: rt_raster.c:731
void rt_raster_destroy(rt_raster raster)
Release memory associated to a raster.
Definition: rt_raster.c:86
rt_raster rt_raster_new(uint32_t width, uint32_t height)
Construct a raster with given dimensions.
Definition: rt_raster.c:52
uint16_t rt_raster_get_num_bands(rt_raster raster)
Definition: rt_raster.c:376
void rt_raster_set_srid(rt_raster raster, int32_t srid)
Set raster's SRID.
Definition: rt_raster.c:367
int rt_raster_copy_band(rt_raster torast, rt_raster fromrast, int fromindex, int toindex)
Copy one band from one raster to another.
Definition: rt_raster.c:1398
void rt_raster_get_geotransform_matrix(rt_raster raster, double *gt)
Get 6-element array of raster geotransform matrix.
Definition: rt_raster.c:710

References genraster::count, window::gt, rtpixdump::rast, rtrowdump::raster, RASTER_DEBUGF, rt_band_destroy(), rt_raster_copy_band(), rt_raster_destroy(), rt_raster_get_geotransform_matrix(), rt_raster_get_num_bands(), rt_raster_new(), rt_raster_set_geotransform_matrix(), rt_raster_set_srid(), and rterror().

Referenced by RASTER_addBandRasterArray(), RASTER_band(), RASTER_InterpolateRaster(), RASTER_union_finalfn(), rt_raster_clone(), and test_raster_from_band().

Here is the call graph for this function:
Here is the caller graph for this function: