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

◆ rt_band_load_offline_data()

rt_errorstate rt_band_load_offline_data ( rt_band  band)

Load offline band's data.

Loaded data is internally owned and should not be released by the caller. Data will be released when band is destroyed with rt_band_destroy().

Parameters
band: the band who's data to get
Returns
ES_NONE if success, ES_ERROR if failure

Definition at line 588 of file rt_band.c.

588 {
589 GDALDatasetH hdsSrc = NULL;
590 int nband = 0;
591 VRTDatasetH hdsDst = NULL;
592 VRTSourcedRasterBandH hbandDst = NULL;
593 double ogt[6] = {0};
594 double offset[2] = {0};
595
596 rt_raster _rast = NULL;
597 rt_band _band = NULL;
598 int aligned = 0;
599 int err = ES_NONE;
600
601 assert(band != NULL);
602 assert(band->raster != NULL);
603
604 if (!band->offline) {
605 rterror("rt_band_load_offline_data: Band is not offline");
606 return ES_ERROR;
607 }
608 else if (!strlen(band->data.offline.path)) {
609 rterror("rt_band_load_offline_data: Offline band does not a have a specified file");
610 return ES_ERROR;
611 }
612
613 /* offline_data is disabled */
615 rterror("rt_band_load_offline_data: Access to offline bands disabled");
616 return ES_ERROR;
617 }
618
620 hdsSrc = rt_util_gdal_open(band->data.offline.path, GA_ReadOnly, 1);
621 if (hdsSrc == NULL) {
622 rterror("rt_band_load_offline_data: Cannot open offline raster: %s", band->data.offline.path);
623 return ES_ERROR;
624 }
625
626 /* # of bands */
627 nband = GDALGetRasterCount(hdsSrc);
628 if (!nband) {
629 rterror("rt_band_load_offline_data: No bands found in offline raster: %s", band->data.offline.path);
630 GDALClose(hdsSrc);
631 return ES_ERROR;
632 }
633 /* bandNum is 0-based */
634 else if (band->data.offline.bandNum + 1 > nband) {
635 rterror("rt_band_load_offline_data: Specified band %d not found in offline raster: %s", band->data.offline.bandNum, band->data.offline.path);
636 GDALClose(hdsSrc);
637 return ES_ERROR;
638 }
639
640 /* get offline raster's geotransform */
641 if (GDALGetGeoTransform(hdsSrc, ogt) != CE_None) {
642 RASTER_DEBUG(4, "Using default geotransform matrix (0, 1, 0, 0, 0, -1)");
643 ogt[0] = 0;
644 ogt[1] = 1;
645 ogt[2] = 0;
646 ogt[3] = 0;
647 ogt[4] = 0;
648 ogt[5] = -1;
649 }
650 RASTER_DEBUGF(3, "Offline geotransform (%f, %f, %f, %f, %f, %f)",
651 ogt[0], ogt[1], ogt[2], ogt[3], ogt[4], ogt[5]);
652
653 /* are rasters aligned? */
654 _rast = rt_raster_new(1, 1);
656 rt_raster_set_srid(_rast, band->raster->srid);
657 err = rt_raster_same_alignment(band->raster, _rast, &aligned, NULL);
658 rt_raster_destroy(_rast);
659
660 if (err != ES_NONE) {
661 rterror("rt_band_load_offline_data: Could not test alignment of in-db representation of out-db raster");
662 GDALClose(hdsSrc);
663 return ES_ERROR;
664 }
665 else if (!aligned) {
666 rtwarn("The in-db representation of the out-db raster is not aligned. Band data may be incorrect");
667 }
668
669 /* get offsets */
671 band->raster,
672 ogt[0], ogt[3],
673 &(offset[0]), &(offset[1]),
674 NULL
675 );
676
677 RASTER_DEBUGF(4, "offsets: (%f, %f)", offset[0], offset[1]);
678
679 /* create VRT dataset */
680 hdsDst = VRTCreate(band->width, band->height);
681 GDALSetGeoTransform(hdsDst, ogt);
682 /*
683 GDALSetDescription(hdsDst, "/tmp/offline.vrt");
684 */
685
686 /* add band as simple sources */
687 GDALAddBand(hdsDst, rt_util_pixtype_to_gdal_datatype(band->pixtype), NULL);
688 hbandDst = (VRTSourcedRasterBandH) GDALGetRasterBand(hdsDst, 1);
689
690 if (band->hasnodata)
691 GDALSetRasterNoDataValue(hbandDst, band->nodataval);
692
693 VRTAddSimpleSource(
694 hbandDst, GDALGetRasterBand(hdsSrc, band->data.offline.bandNum + 1),
695 fabs(offset[0]), fabs(offset[1]),
696 band->width, band->height,
697 0, 0,
698 band->width, band->height,
699 "near", VRT_NODATA_UNSET
700 );
701
702 /* make sure VRT reflects all changes */
703 VRTFlushCache(hdsDst);
704
705 /* convert VRT dataset to rt_raster */
706 _rast = rt_raster_from_gdal_dataset(hdsDst);
707
708 GDALClose(hdsDst);
709 GDALClose(hdsSrc);
710 /*
711 {
712 FILE *fp;
713 fp = fopen("/tmp/gdal_open_files.log", "w");
714 GDALDumpOpenDatasets(fp);
715 fclose(fp);
716 }
717 */
718
719 if (_rast == NULL) {
720 rterror("rt_band_load_offline_data: Cannot load data from offline raster: %s", band->data.offline.path);
721 return ES_ERROR;
722 }
723
724 _band = rt_raster_get_band(_rast, 0);
725 if (_band == NULL) {
726 rterror("rt_band_load_offline_data: Cannot load data from offline raster: %s", band->data.offline.path);
727 rt_raster_destroy(_rast);
728 return ES_ERROR;
729 }
730
731 /* band->data.offline.mem not NULL, free first */
732 if (band->data.offline.mem != NULL) {
733 rtdealloc(band->data.offline.mem);
734 band->data.offline.mem = NULL;
735 }
736
737 band->data.offline.mem = _band->data.mem;
738
739 rtdealloc(_band); /* cannot use rt_band_destroy */
740 rt_raster_destroy(_rast);
741
742 return ES_NONE;
743}
void rterror(const char *fmt,...) __attribute__((format(printf
Wrappers used for reporting errors and info.
#define RASTER_DEBUG(level, msg)
Definition librtcore.h:304
int rt_util_gdal_register_all(int force_register_all)
Definition rt_util.c:444
#define RASTER_DEBUGF(level, msg,...)
Definition librtcore.h:308
void rt_raster_set_geotransform_matrix(rt_raster raster, double *gt)
Set raster's geotransform using 6-element array.
Definition rt_raster.c:609
void void void rtwarn(const char *fmt,...) __attribute__((format(printf
rt_errorstate rt_raster_geopoint_to_cell(rt_raster raster, double xw, double yw, double *xr, double *yr, double *igt)
Convert an xw, yw map point to a xr, yr raster point.
Definition rt_raster.c:686
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
GDALDataType rt_util_pixtype_to_gdal_datatype(rt_pixtype pt)
Convert rt_pixtype to GDALDataType.
Definition rt_util.c:213
rt_raster rt_raster_from_gdal_dataset(GDALDatasetH ds)
Return a raster from a GDAL dataset.
Definition rt_raster.c:2175
GDALDatasetH rt_util_gdal_open(const char *fn, GDALAccess fn_access, int shared)
Definition rt_util.c:491
@ ES_NONE
Definition librtcore.h:182
@ ES_ERROR
Definition librtcore.h:183
void rt_raster_set_srid(rt_raster raster, int32_t srid)
Set raster's SRID.
Definition rt_raster.c:367
void rtdealloc(void *mem)
Definition rt_context.c:206
rt_errorstate rt_raster_same_alignment(rt_raster rast1, rt_raster rast2, int *aligned, char **reason)
rt_band rt_raster_get_band(rt_raster raster, int bandNum)
Return Nth band, or NULL if unavailable.
Definition rt_raster.c:385
nband
Definition pixval.py:56
bool enable_outdb_rasters
Definition rt_band.c:576
union rt_band_t::@12 data
void * mem
Definition librtcore.h:2529

References rt_band_t::data, enable_outdb_rasters, ES_ERROR, ES_NONE, rt_band_t::mem, RASTER_DEBUG, RASTER_DEBUGF, rt_raster_destroy(), rt_raster_from_gdal_dataset(), rt_raster_geopoint_to_cell(), rt_raster_get_band(), rt_raster_new(), rt_raster_same_alignment(), rt_raster_set_geotransform_matrix(), rt_raster_set_srid(), rt_util_gdal_open(), rt_util_gdal_register_all(), rt_util_pixtype_to_gdal_datatype(), rtdealloc(), rterror(), and rtwarn().

Referenced by rt_band_get_data(), and test_band_metadata().

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