An Outline has contains the polygon describing the outline and an image associated with the outline.
David Sterratt
retistruct::OutlineCommon
-> Outline
P
A N-by-2 matrix of points of the Outline
arranged in anticlockwise order
scale
The length of one unit of P
in the X-Y plane in arbitrary units
scalez
The length of one unit of P
in the Z-direction in arbitrary units
units
String giving units of scaled P, e.g. “um”
gf
For each row of P
, the index of P
that
is next in the outline travelling anticlockwise (forwards)
gb
For each row of P
, the index of P
that
is next in the outline travelling clockwise (backwards)
h
For each row of P
, the cut of that
point (which will be to itself initially)
im
An image as a raster
object
dm
Depthmap, with same dimensions as im
, which indicates
height of each pixel in Z-direction
A.fragments
Areas of fragments
dm.inferna.window.min
Minimum window size (in pixels) for inferring missing values in depthmaps
dm.inferna.window.max
Minimum window size (in pixels) for inferring missing values in depthmaps
new()
Construct an outline object. This sanitises the
input points P
.
Outline$new(
fragments = list(),
scale = NA,
im = NULL,
scalez = NA,
dm = NULL,
units = NA
)
fragments
A list of N-by-2 matrix of points for each fragment of the Outline
scale
The length of one unit of P
in arbitrary units
im
The image as a raster
object
scalez
The length of one unit of P
in the Z-direction in arbitrary units. If NA
, the depthmap is ignored.
dm
Depthmap, with same dimensions as im
, which indicates
height of each pixel in Z-direction
units
String giving units of scaled P, e.g. “um”
getImage()
Image accessor
Outline$getImage()
An image as a raster
object
replaceImage()
Image setter
Outline$replaceImage(im)
im
An image as a raster
object
mapFragment()
Map the point IDs of a Fragment on the point IDs of this Outline
Outline$mapFragment(fragment, pids)
fragment
Fragment to map
pids
Point IDs in Outline of points in Fragment
mapPids()
Map references to points
Outline$mapPids(x, y, pids)
x
References to point indices in source
y
References to existing point indices in target
pids
IDs of points in point register
New references to point indices in target
getDepth()
Get depth of points P
Outline$getDepth(P)
P
matrix containing unscaled X-Y coordinates of points
Vector of unscaled Z coordinates of points P
addPoints()
Add points to the outline register of points
Outline$addPoints(P, fid)
P
2 or 3 column matrix of points to add
fid
ID of fragment to which to add the points
The ID of each added point in the register. If points already exist a point will not be created in the register, but an ID will be returned
getFragmentPointIDs()
Get the point IDs in a fragment
Outline$getFragmentPointIDs(fid)
fid
fragment id of the points
Vector of point IDs, i.e. indices of the rows in
the matrices returned by getPoints
and
getPointsScaled
getFragmentPoints()
Get the points in a fragment
Outline$getFragmentPoints(fid)
fid
fragment id of the points
Vector of points
getFragment()
Get fragment
Outline$getFragment(fid)
fid
Fragment ID
The Fragment
object with ID fid
getFragmentIDsFromPointIDs()
Get fragment IDs from point IDS
Outline$getFragmentIDsFromPointIDs(pids)
pids
Vector of point IDs
The Fragment ID to which each point belongs
getFragmentIDs()
Get fragment IDs
Outline$getFragmentIDs()
IDs of all fragments
getPoints()
Get unscaled mesh points
Outline$getPoints(pids = NULL)
pids
IDs of point to return
Matrix with columns X
, Y
and Z
getPointsXY()
Get X-Y coordinates of unscaled mesh points
Outline$getPointsXY(pids = NULL)
pids
IDs of point to return
Matrix with columns X
and Y
getPointsScaled()
Get scaled mesh points
Outline$getPointsScaled()
Matrix with columns X
and Y
which is
exactly scale
times the matrix returned by getPoints
getRimSet()
Get set of points on rim
Outline$getRimSet()
Vector of point IDs, i.e. indices of the rows in
the matrices returned by getPoints
and
getPointsScaled
getOutlineSet()
Get points on the edge of the outline
Outline$getOutlineSet()
Vector of points IDs on outline
getOutlineLengths()
Get lengths of edges of the outline
Outline$getOutlineLengths()
Vector of lengths of edges connecting neighbouring points
addFeatureSet()
Add a FeatureSet, e.g. a PointSet or LandmarkSet
Outline$addFeatureSet(fs)
fs
FeatureSet to add
clone()
The objects of this class are cloneable with this method.
Outline$clone(deep = FALSE)
deep
Whether to make a deep clone.