Copy one band from one raster to another.
Bands are duplicated from fromrast to torast using rt_band_duplicate. The caller will need to ensure that the copied band's data or path remains allocated for the lifetime of the copied bands.
- Parameters
-
torast | : raster to copy band to |
fromrast | : raster to copy band from |
fromindex | : index of band in source raster, 0-based |
toindex | : index of new band in destination raster, 0-based |
- Returns
- The band index of the second raster where the new band is copied. -1 if error
Definition at line 1370 of file rt_raster.c.
1377 assert(NULL != torast);
1378 assert(NULL != fromrast);
1382 rtwarn(
"rt_raster_copy_band: Attempting to add a band with different width or height");
1388 rtwarn(
"rt_raster_copy_band: Second raster has no band");
1391 else if (fromindex < 0) {
1392 rtwarn(
"rt_raster_copy_band: Band index for second raster < 0. Defaulted to 0");
1395 else if (fromindex >= fromrast->
numBands) {
1396 rtwarn(
"rt_raster_copy_band: Band index for second raster > number of bands, truncated from %u to %u", fromindex, fromrast->
numBands - 1);
1397 fromindex = fromrast->
numBands - 1;
1401 rtwarn(
"rt_raster_copy_band: Band index for first raster < 0. Defaulted to 0");
1404 else if (toindex > torast->
numBands) {
1405 rtwarn(
"rt_raster_copy_band: Band index for first raster > number of bands, truncated from %u to %u", toindex, torast->
numBands);
rt_band rt_band_duplicate(rt_band band)
Create a new band duplicated from source band.
void rtwarn(const char *fmt,...)
int rt_raster_add_band(rt_raster raster, rt_band band, int index)
Add band data to a raster.
rt_band rt_raster_get_band(rt_raster raster, int n)
Return Nth band, or NULL if unavailable.
References rt_raster_t::height, rt_raster_t::numBands, rt_band_duplicate(), rt_raster_add_band(), rt_raster_get_band(), rtwarn(), and rt_raster_t::width.
Referenced by RASTER_addBandRasterArray(), RASTER_copyBand(), RASTER_mapAlgebraExpr(), RASTER_union_finalfn(), and rt_raster_from_band().