4119 if (PG_ARGISNULL(0))
4125 elog(ERROR,
"RASTER_colorMap: Could not initialize argument structure");
4130 pgraster = (
rt_pgraster *) PG_DETOAST_DATUM(PG_GETARG_DATUM(0));
4136 PG_FREE_IF_COPY(pgraster, 0);
4137 elog(ERROR,
"RASTER_colorMap: Could not deserialize raster");
4142 if (!PG_ARGISNULL(1))
4143 arg->
nband = PG_GETARG_INT32(1);
4148 elog(NOTICE,
"Raster does not have band at index %d. Returning empty raster", arg->
nband);
4153 PG_FREE_IF_COPY(pgraster, 0);
4154 elog(ERROR,
"RASTER_colorMap: Could not create empty raster");
4159 PG_FREE_IF_COPY(pgraster, 0);
4163 if (pgraster == NULL)
4166 SET_VARSIZE(pgraster, ((
rt_pgraster*) pgraster)->size);
4167 PG_RETURN_POINTER(pgraster);
4172 if (arg->
band == NULL) {
4175 PG_FREE_IF_COPY(pgraster, 0);
4176 elog(ERROR,
"RASTER_colorMap: Could not get band at index %d",
nband);
4181 if (!PG_ARGISNULL(3)) {
4182 char *method = NULL;
4183 char *tmp = text_to_cstring(PG_GETARG_TEXT_P(3));
4190 if (strcmp(method,
"INTERPOLATE") == 0)
4192 else if (strcmp(method,
"EXACT") == 0)
4194 else if (strcmp(method,
"NEAREST") == 0)
4197 elog(NOTICE,
"Unknown value provided for method. Defaulting to INTERPOLATE");
4207 if (PG_ARGISNULL(2)) {
4209 PG_FREE_IF_COPY(pgraster, 0);
4210 elog(ERROR,
"RASTER_colorMap: Value must be provided for colormap");
4215 char *colormap = text_to_cstring(PG_GETARG_TEXT_P(2));
4224 if (!strlen(colormap)) {
4226 PG_FREE_IF_COPY(pgraster, 0);
4227 elog(ERROR,
"RASTER_colorMap: Value must be provided for colormap");
4235 PG_FREE_IF_COPY(pgraster, 0);
4236 elog(ERROR,
"RASTER_colorMap: Could not process the value provided for colormap");
4244 PG_FREE_IF_COPY(pgraster, 0);
4245 elog(ERROR,
"RASTER_colorMap: Could not allocate memory for colormap entries");
4251 for (i = 0; i < arg->
nentry; i++) {
4265 if (!strlen(_entry)) {
4275 PG_FREE_IF_COPY(pgraster, 0);
4276 elog(ERROR,
"RASTER_colorMap: Could not process colormap entry %d", i + 1);
4280 elog(NOTICE,
"More than five elements in colormap entry %d. Using at most five elements", i + 1);
4289 for (j = 0; j < arg->
nelement; j++) {
4298 char *percent = NULL;
4302 strcmp(_element,
"NV") == 0 ||
4303 strcmp(_element,
"NULL") == 0 ||
4304 strcmp(_element,
"NODATA") == 0
4309 elog(NOTICE,
"More than one NODATA entry found. Using only the first one");
4318 else if ((percent = strchr(_element,
'%')) != NULL) {
4330 PG_FREE_IF_COPY(pgraster, 0);
4331 elog(ERROR,
"RASTER_colorMap: Could not get band's summary stats to process percentages");
4337 tmp = palloc(
sizeof(
char) * (percent - _element + 1));
4341 PG_FREE_IF_COPY(pgraster, 0);
4342 elog(ERROR,
"RASTER_colorMap: Could not allocate memory for value of percentage");
4346 memcpy(tmp, _element, percent - _element);
4347 tmp[percent - _element] =
'\0';
4352 value = strtod(tmp, NULL);
4354 if (errno != 0 || _element == junk) {
4357 PG_FREE_IF_COPY(pgraster, 0);
4358 elog(ERROR,
"RASTER_colorMap: Could not process percent string to value");
4364 elog(NOTICE,
"Percentage values cannot be less than zero. Defaulting to zero");
4367 else if (
value > 100.) {
4368 elog(NOTICE,
"Percentage values cannot be greater than 100. Defaulting to 100");
4380 if (errno != 0 || _element == junk) {
4383 PG_FREE_IF_COPY(pgraster, 0);
4384 elog(ERROR,
"RASTER_colorMap: Could not process string to value");
4395 value = (int) strtod(_element, &junk);
4396 if (errno != 0 || _element == junk) {
4399 PG_FREE_IF_COPY(pgraster, 0);
4400 elog(ERROR,
"RASTER_colorMap: Could not process string to value");
4405 elog(NOTICE,
"RGBA value cannot be greater than 255. Defaulting to 255");
4408 else if (
value < 0) {
4409 elog(NOTICE,
"RGBA value cannot be less than zero. Defaulting to zero");
4418 POSTGIS_RT_DEBUGF(4,
"colormap->entry[%d] (isnodata, value, R, G, B, A) = (%d, %f, %d, %d, %d, %d)",
4439 PG_FREE_IF_COPY(pgraster, 0);
4440 elog(ERROR,
"RASTER_colorMap: Could not create new raster with applied colormap");
4445 PG_FREE_IF_COPY(pgraster, 0);
4451 if (pgraster == NULL)
4454 SET_VARSIZE(pgraster, ((
rt_pgraster*) pgraster)->size);
4455 PG_RETURN_POINTER(pgraster);
rt_raster rt_raster_colormap(rt_raster raster, int nband, rt_colormap colormap)
Returns a new raster with up to four 8BUI bands (RGBA) from applying a colormap to the user-specified...
void rt_raster_destroy(rt_raster raster)
Release memory associated to a raster.
int rt_raster_has_band(rt_raster raster, int nband)
Return TRUE if the raster has a band of this number.
void * rt_raster_serialize(rt_raster raster)
Return this raster in serialized form.
rt_raster rt_raster_clone(rt_raster raster, uint8_t deep)
Clone an existing raster.
rt_bandstats rt_band_get_summary_stats(rt_band band, int exclude_nodata_value, double sample, int inc_vals, uint64_t *cK, double *cM, double *cQ)
Compute summary statistics for a band.
rt_raster rt_raster_deserialize(void *serialized, int header_only)
Return a raster from a serialized form.
rt_band rt_raster_get_band(rt_raster raster, int bandNum)
Return Nth band, or NULL if unavailable.
raster
Be careful!! Zeros function's input parameter can be a (height x width) array, not (width x height): ...
char * rtpg_strtoupper(char *str)
char * rtpg_trim(const char *input)
char ** rtpg_strsplit(const char *str, const char *delimiter, uint32_t *n)
char * rtpg_strreplace(const char *str, const char *oldstr, const char *newstr, int *count)
static void rtpg_colormap_arg_destroy(rtpg_colormap_arg arg)
static rtpg_colormap_arg rtpg_colormap_arg_init()
#define POSTGIS_RT_DEBUG(level, msg)
#define POSTGIS_RT_DEBUGF(level, msg,...)
enum rt_colormap_t::@10 method