[R] Plot polygon in 3D with rgl
Remko Duursma
remkoduursma at gmail.com
Mon May 10 00:41:07 CEST 2010
Dear R-helpers, an rgl-ers in particular,
what is the easiest way to plot a section of a plane in 3D, that is
given by the xyz coordinates of the outline?
Suppose I have a polygon - which I know for sure is a set of
coordinates on the same plane. One method I found is to use surf.tri
from the geometry package, and then plot the triangles with
rgl.triangles. This method is not perfect though, because it makes the
convex hull - no good for the polygon below.
thanks for your help,
Remko
# Example polygon in 3D (matrix with tree columns x,y,z)
m <- structure(c(-24.71, -36.45, -59.54, -83.97, -112.63, -126.66,
-152.79, -171.04, -178.92, -183.71, -189.27, -191.56, -195.98,
-203.09, -207.89, -212.12, -216.92, -221.73, -210.58, -199.43,
-195.58, -175.38, -161.72, -152.09, -140.75, -123.63, -97.87,
-79.04, -69.63, -61.75, -54.08, -38.34, -30.47, -24.71, -15.44,
-13.33, -14.26, -17.39, -24.5, -31.92, -52.3, -70.45, -79.41,
-89.16, -102.08, -111.61, -119.76, -125.55, -128.56, -132.55,
-135.55, -138.55, -132.93, -127.31, -124.91, -125.78, -126.69,
-127.42, -124.38, -117.74, -105.69, -88.52, -79.94, -70.97, -59.43,
-34.75, -25.78, -15.44, 689.49, 686.54, 680.81, 674.79, 667.78,
664.42, 658.27, 654.05, 652.25, 651.22, 650.06, 649.66, 648.7,
647.04, 645.89, 644.91, 643.77, 642.63, 645.3, 647.98, 648.89,
653.93, 657.35, 659.75, 662.52, 666.66, 672.86, 677.25, 679.44,
681.24, 682.95, 686.44, 688.24, 689.49), .Dim = c(34L, 3L))
# One (wrong) way
library(geometry)
tm <- t(surf.tri(m, delaunayn(m)))
plot3d(m[,1],m[,2],m[,3], type='l', col="black", size=2)
rgl.triangles(m[tm, 1], m[tm, 2], m[tm, 3], col="green")
-------------------------------------------------
Remko Duursma
Research Lecturer
Centre for Plants and the Environment
University of Western Sydney
Hawkesbury Campus
Richmond NSW 2753
Dept of Biological Science
Macquarie University
North Ryde NSW 2109
Australia
Mobile: +61 (0)422 096908
www.remkoduursma.com
More information about the R-help
mailing list