PostGIS  3.3.9dev-r@@SVN_REVISION@@

◆ ptarray_affine()

void ptarray_affine ( POINTARRAY pa,
const AFFINE a 
)

Affine transform a pointarray.

Definition at line 1877 of file ptarray.c.

1878 {
1879  if (FLAGS_GET_Z(pa->flags))
1880  {
1881  for (uint32_t i = 0; i < pa->npoints; i++)
1882  {
1883  POINT4D *p4d = (POINT4D *)(getPoint_internal(pa, i));
1884  double x = p4d->x;
1885  double y = p4d->y;
1886  double z = p4d->z;
1887  p4d->x = a->afac * x + a->bfac * y + a->cfac * z + a->xoff;
1888  p4d->y = a->dfac * x + a->efac * y + a->ffac * z + a->yoff;
1889  p4d->z = a->gfac * x + a->hfac * y + a->ifac * z + a->zoff;
1890  }
1891  }
1892  else
1893  {
1894  for (uint32_t i = 0; i < pa->npoints; i++)
1895  {
1896  POINT2D *pt = (POINT2D *)(getPoint_internal(pa, i));
1897  double x = pt->x;
1898  double y = pt->y;
1899  pt->x = a->afac * x + a->bfac * y + a->xoff;
1900  pt->y = a->dfac * x + a->efac * y + a->yoff;
1901  }
1902  }
1903 }
#define FLAGS_GET_Z(flags)
Definition: liblwgeom.h:180
static uint8_t * getPoint_internal(const POINTARRAY *pa, uint32_t n)
Definition: lwinline.h:77
double gfac
Definition: liblwgeom.h:347
double zoff
Definition: liblwgeom.h:347
double bfac
Definition: liblwgeom.h:347
double ifac
Definition: liblwgeom.h:347
double xoff
Definition: liblwgeom.h:347
double dfac
Definition: liblwgeom.h:347
double afac
Definition: liblwgeom.h:347
double ffac
Definition: liblwgeom.h:347
double cfac
Definition: liblwgeom.h:347
double hfac
Definition: liblwgeom.h:347
double efac
Definition: liblwgeom.h:347
double yoff
Definition: liblwgeom.h:347
double y
Definition: liblwgeom.h:405
double x
Definition: liblwgeom.h:405
double x
Definition: liblwgeom.h:429
double z
Definition: liblwgeom.h:429
double y
Definition: liblwgeom.h:429
lwflags_t flags
Definition: liblwgeom.h:446
uint32_t npoints
Definition: liblwgeom.h:442

References AFFINE::afac, AFFINE::bfac, AFFINE::cfac, AFFINE::dfac, AFFINE::efac, AFFINE::ffac, POINTARRAY::flags, FLAGS_GET_Z, getPoint_internal(), AFFINE::gfac, AFFINE::hfac, AFFINE::ifac, POINTARRAY::npoints, POINT2D::x, POINT4D::x, pixval::x, AFFINE::xoff, POINT2D::y, POINT4D::y, pixval::y, AFFINE::yoff, POINT4D::z, and AFFINE::zoff.

Referenced by lwgeom_affine().

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