Skip to content

Latest commit

 

History

History
80 lines (57 loc) · 1.88 KB

046-read-rforge.md

File metadata and controls

80 lines (57 loc) · 1.88 KB

This demo shows you how to reference code in a URL. We use R-Forge as an example, but you can really read code from anywhere.

We cache this chunk so that the next time we compile this document, the code does not need to be read from the web again.

library(knitr)
demo.sub = read_rforge("rgl/demo/subdivision.r", project = "rgl")
head(demo.sub)
## [1] "# RGL-demo: subdivision surfaces"    
## [2] "# author: Daniel Adler"              
## [3] ""                                    
## [4] "rgl.demo.subdivision <- function() {"
## [5] "  # setup environment"               
## [6] "  clear3d(\"all\")"

Once we have the source code, we can insert it into knitr with read_chunk():

read_chunk(lines = demo.sub, labels = "rgl-sub")

That means we assigned the code to a chunk named rgl-sub, which appears below:

# RGL-demo: subdivision surfaces author: Daniel Adler

rgl.demo.subdivision <- function() {
    # setup environment
    clear3d("all")
    view3d()
    bg3d(color = "gray")
    light3d()

    # generate basic mesh
    obj <- oh3d()

    part <- function(level, tx, ...) {
        shade3d(translate3d(obj, tx, 0, 0), color = "gray30", front = "lines",
            alpha = 0.5, back = "lines", override = TRUE)
        shade3d(translate3d(subdivision3d(obj, depth = level), tx, 0, 0), override = TRUE,
            ...)
    }

    part(0, -5.5, color = "blue")
    part(1, -1.75, color = "yellow")
    part(2, 1.75, color = "red")
    part(3, 5.5, color = "green")

}

open3d()
rgl.demo.subdivision()

You can actually run the code and capture the rgl plot, but before that we need to load the package and set a rgl hook:

library(rgl)
knit_hooks$set(rgl = hook_rgl)

Now you can see the 3D plot:

open3d()
rgl.demo.subdivision()

plot of chunk rgl-sub