#' @include class_AmObject.R utils_basicClassUnions.R
NULL
#' @title ChartCursor class
#' @author datastorm-open
#'
#' @description Creates a cursor for the chart which follows the mouse movements.
#' In case of AmSerialChart charts it shows the balloons of hovered data points.
#' @details Run \code{api("ChartCursor")} for more information and all avalaible properties.
#'
#' @slot oneBalloonOnly \code{logical}.
#' If TRUE, border color will be changed when user rolls-over the slice, graph,
#' etc, instead of background color.
#' @slot valueLineAxis \code{list}.
#' Properties of Axis of value line. If you set valueLineBalloonEnabled to true,
#' but you have more than one axis, you can use this property
#' to indicate which axis should display balloon.
#' @slot listeners \code{list} containining the listeners to add to the object.
#' The list must be named as in the official API. Each element must be a character string.
#' @slot otherProperties \code{list}
#' containing other avalaible properties not yet implemented in the package.
#' @slot value \code{numeric}.
#'
#' @export
#'
setClass(Class = "ChartCursor", contains = "AmObject",
representation = representation(
oneBalloonOnly = "logical",
valueLineAxis = "listOrCharacter"
))
#' @title Initializes a ChartCursor
#' @description Initializes or updates a \linkS4class{ChartCursor}.
#'
#' @param .Object \linkS4class{ChartCursor}.
#' @param oneBalloonOnly \code{logical},
#' if TRUE, border color will be changed when user rolls-over the slice, graph,
#' etc, instead of background color.
#' @param valueLineAxis \linkS4class{ValueAxis}.
#' If you set valueLineBalloonEnabled to TRUE,
#' but you have more than one axis, you can use this property
#' to indicate which axis should display balloon.
#' @param ... other properties of ChartCursor.
#' Run : api("ChartCursor") for more information.
#'
#' @return (updated) .Object of class \linkS4class{ChartCursor}.
#'
#' @examples
#' new("ChartCursor", oneBalloonOnly = TRUE)
#'
#' @rdname initialize-ChartCursor
#' @export
#'
setMethod(f = "initialize", signature = "ChartCursor",
definition = function(.Object, oneBalloonOnly, valueLineAxis,...)
{
if (!missing(oneBalloonOnly)) {
.Object@oneBalloonOnly <- oneBalloonOnly
} else {}
if (!missing(valueLineAxis)) {
.Object <- setValueLineAxis(.Object, valueLineAxis)
} else {}
.Object <- setProperties(.Object, ...)
validObject(.Object)
return(.Object)
})
# CONSTRUCTOR ####
#' @rdname initialize-ChartCursor
#'
#' @param animationDuration \code{numeric}, duration of animation of a line, in seconds.
#'
#' @examples
#' chartCursor()
#' chartCursor(oneBalloonOnly = TRUE)
#'
#' @export
#'
chartCursor <- function(animationDuration = .3, oneBalloonOnly, valueLineAxis,...) {
.Object <- new("ChartCursor", animationDuration = animationDuration)
if (!missing(oneBalloonOnly)) {
.Object@oneBalloonOnly <- oneBalloonOnly
} else {}
if (!missing(valueLineAxis)) {
.Object <- setValueLineAxis(.Object, valueLineAxis)
} else {}
.Object <- setProperties(.Object, ...)
validObject(.Object)
return( .Object )
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.