| Title: | View 3D Raster Cubes Interactively | 
| Version: | 0.4.1 | 
| Maintainer: | Tim Appelhans <tim.appelhans@gmail.com> | 
| Description: | Creates a 3D data cube view of a RasterStack/Brick, typically a collection/array of RasterLayers (along z-axis) with the same geographical extent (x and y dimensions) and resolution, provided by package 'raster'. Slices through each dimension (x/y/z), freely adjustable in location, are mapped to the visible sides of the cube. The cube can be freely rotated. Zooming and panning can be used to focus on different areas of the cube. | 
| License: | MIT + file LICENSE | 
| Encoding: | UTF-8 | 
| Depends: | R (≥ 2.10) | 
| Imports: | base64enc, htmltools, htmlwidgets, lattice, stars, svglite, viridisLite | 
| Suggests: | methods, raster, shiny, terra | 
| RoxygenNote: | 7.3.2 | 
| NeedsCompilation: | no | 
| Packaged: | 2025-08-21 09:14:02 UTC; tim | 
| Author: | Tim Appelhans [cre, aut], Stefan Woellauer [aut], three.js authors [ctb, cph] (three.js library) | 
| Repository: | CRAN | 
| Date/Publication: | 2025-08-21 09:40:16 UTC | 
Options to control cube appearance.
Description
Options to control cube appearance.
Usage
cubeOptions(x_pos = 1, y_pos = 1, z_pos = 1, ...)
Arguments
| x_pos | initial position of x-axis slice. | 
| y_pos | initial position of y-axis slice. | 
| z_pos | initial position of z-axis slice. | 
| ... | currently ignored. | 
Widget output/render function for use in Shiny
Description
Widget output/render function for use in Shiny
Usage
cubeViewOutput(outputId, width = "100%", height = "400px")
renderCubeView(expr, env = parent.frame(), quoted = FALSE)
Arguments
| outputId | Output variable to read from | 
| width,height | the width and height of the map
(see  | 
| expr | An expression that generates an HTML widget | 
| env | The environment in which to evaluate expr | 
| quoted | Is expr a quoted expression (with quote())? This is useful if you want to save an expression in a variable | 
Examples
if (interactive()) {
  library(shiny)
  library(raster)
  kili_data <- system.file("extdata", "kiliNDVI.tif", package = "cubeview")
  kiliNDVI <- stack(kili_data)
  cube = cubeView(kiliNDVI)
  ui = fluidPage(
    cubeViewOutput("cube", width = 300, height = 300)
  )
  server = function(input, output, session) {
    output$cube <- renderCubeView(cube)
  }
  shinyApp(ui, server)
}
View a RasterStack or RasterBrick as 3-dimensional data cube.
Description
Creates a 3D data cube view of a RasterStack/Brick. Slices through each dimension (x/y/z) are mapped to the visible sides of the cube. The cube can be freely rotated. Zooming and panning can be used to focus on different areas of the cube.
See Details for information on how to control the location of the slices and all other available keyborad and mouse guestures to control the cube.
Usage
cubeview(x, ...)
## S3 method for class 'character'
cubeview(
  x,
  at,
  col.regions = viridisLite::inferno,
  na.color = "#BEBEBE",
  legend = TRUE,
  options = cubeOptions(),
  legend.options = legendOptions(),
  ...
)
## S3 method for class 'stars'
cubeview(
  x,
  at,
  col.regions = viridisLite::inferno,
  na.color = "#BEBEBE",
  legend = TRUE,
  options = cubeOptions(),
  legend.options = legendOptions(),
  xdim = "x",
  ydim = "y",
  zdim = "band",
  ...
)
## S3 method for class 'SpatRaster'
cubeview(
  x,
  at,
  col.regions = viridisLite::inferno,
  na.color = "#BEBEBE",
  legend = TRUE,
  options = cubeOptions(),
  legend.options = legendOptions(),
  ...
)
## S3 method for class 'RasterStackBrick'
cubeview(
  x,
  at,
  col.regions = viridisLite::inferno,
  na.color = "#BEBEBE",
  legend = TRUE,
  options = cubeOptions(),
  legend.options = legendOptions(),
  ...
)
cubeView(x, ...)
Arguments
| x | a file name, stars object, RasterStack or RasterBrick | 
| ... | additional arguments passed on to read_stars. | 
| at | the breakpoints used for the visualisation. See
 | 
| col.regions | either a palette function or a vector of colors to be used for palette generation. | 
| na.color | color for missing values. | 
| legend | logical. Whether to plot a legend. | 
| options | list of options (x_pos, y_pos, z_pos) for the cube. See cubeOptions for details. | 
| legend.options | list of options (width & height in pixels) for the legend. See legendOptions for details. | 
| xdim | name of the x dimension. | 
| ydim | name of the y dimension. | 
| zdim | name of the z dimension. | 
Details
The location of the slices can be controlled by keys: 
x-axis: LEFT / RIGHT arrow key 
y-axis: DOWN / UP arrow key 
z-axis: PAGE_DOWN / PAGE_UP key 
Other controls: 
Press and hold left mouse-button to rotate the cube. 
Press and hold right mouse-button to move the cube. 
Spin mouse-wheel or press and hold middle mouse-button and
move mouse down/up to zoom the cube. 
Press space bar to show/hide slice position guides. 
Note: 
In RStudio cubeView may show a blank viewer window. In this case open the view in
a web-browser (RStudio button at viewer: "show in new window").
Note: 
Because of key focus issues key-press-events may not always be
recognised within RStudio on Windows. In this case open the view in
a web-browser (RStudio button at viewer: "show in new window").
Author(s)
Stephan Woellauer and Tim Appelhans
Examples
if (interactive()) {
  library(raster)
  library(stars)
  ## directly from file
  kili_data <- system.file("extdata", "kiliNDVI.tif", package = "cubeview")
  cubeview(kili_data)
  ## stars object
  kili_strs = read_stars(kili_data)
  cubeview(kili_strs)
  ## rsater stack (also works with brick)
  kili_rstr <- stack(kili_data)
  cubeview(kili_rstr)
  ## use different color palette and set breaks
  clr <- viridisLite::viridis
  cubeview(kili_data, at = seq(-0.15, 0.95, 0.1), col.regions = clr)
  ## specify initial location of slices
  cubeview(kili_data, options = cubeOptions(x_pos = 21, y_pos = 45, z_pos = 22))
}
Options to control legend appearance.
Description
Options to control legend appearance.
Usage
legendOptions(width = NULL, height = NULL, ...)
Arguments
| width | width of the legend in pixels. | 
| height | height of the legend in pixels. | 
| ... | currently ignored. |