Skip to content

Sunburst

Pieter Verschaffelt edited this page Feb 22, 2021 · 7 revisions

The sunburst is a visualization for hierarchical quantitative data that renders a circular node with multiple subnodes that depict all parent-child relationships from the source data.

Sunburst showcase A live example of this visualization can be found on Observable.

Internals

The sunburst visualization works with an SVG under-the-hood. It can thus easily be exported as an SVG file. In order to speed up the rendering process, only nodes that are currently visible are rendered.

API

Sunburst

constructor

The constructor of the Sunburst class automatically starts rendering the sunburst upon invocation and has the following signature:

  • element: HTMLElement: The HTMLElement in which the sunburst should be rendered.
  • data: DataNodeLike: The root node of the hierarchical data that should be rendered by this sunburst. See DataNode for how to construct these objects properly.
  • options: SunburstSettings (optional): Can be used to configure the sunburst before rendering. See bellow for all the options that are currently supported.

SunburstSettings

Values

  • width: number (optional, default = 800): Maximum width of the visualization in pixels.
  • height: number (optional, default = 800): Maximum height of the visualization in pixels.
  • enableTooltips: boolean (optional, default = true): Are tooltips shown when hovering over a node in the sunburst?
  • radius: number (optional, default = 300): Radius size of the sunburst in pixels.
  • breadcrumbWidth: number (optional, default = 200): Amount of pixels that are reserved for the breadcrumb bar to the right of the visualization.
  • useFixedColors: boolean (optional, default = false): Should a fixed set of colors be used for the visualization? This means that nodes that return the same fixedColorHash will be shown in the same color (always, even when creating multiple sunbursts).
  • colorPalette: string[] (optional, default = ColorPalette.DEFAULT_COLORS): Default color palette that should be used for the node colors. Use one of the predefined palettes from the ColorPalette class if you lack inspiration.
  • fixedColorPalette: string[] (optional, default = ColorPalette.FIXED_COLORS): Color palette that should be used when the useFixedColors option has been set. Use one of the predefined palettes from the ColorPalette class if you lack inspiration.
  • enableBreadcrumbs: boolean (optional, default = true): Should breadcrumbs be shown to the right of the sunburst visualization?
  • levels: number (*optional, default = 4): With how many levels at once can the user interact in the visualization?
  • animationDuration: number (*optional, default = 1000): How long should the animation between different states of the sunburst last? (This time is given in milliseconds).

Functions

  • rerootCallback (optional, default = identity function): Function that's called whenever the user clicks on a node. This function should not return anything and is called with 1 parameter:
    • d: DataNode: The node that has been clicked by the user and which will become the new root of the visualization.
  • fixedColorHash (optional, default = function that returns a hash from the node's name). Returns the hashcode that should be used to determine which fixed color needs to be assigned to a node. The hash should be a number and should be the same for all nodes that require the same color. This function takes 1 parameter and returns a number:
    • d: DataNode: The node for which the hashcode should be computed.
  • getToolTip (optional, default = generic tooltip function) Returns the html to use as tooltip for a node. Is called with a node that represents the current node that's being hovered by the user. The result of getTooltipTitle is used for the header and getTooltipText is used for the body of the tooltip by default. This function needs to return a string representing HTML-code that will be executed and receives 1 parameter:
    • d: DataNode: Node for which the tooltip should be returned. NOTE: Be very cautious in passing user input directly as a result of this function. Please always sanitize the user's input before returning it, as this might lead to reflected XSS-attacks.
  • getToolTipTitle (optional, default = generic title function) Returns text that's being used for the title of a tooltip. This tooltip provides information to the user about the node that's currently hovered by the mouse cursor. This function needs to return a string representing HTML-code that will be executed and receives 1 parameter:
    • d: DataNode: Node for which the title should be returned. NOTE: Be very cautious in passing user input directly as a result of this function. Please always sanitize the user's input before returning it, as this might lead to reflected XSS-attacks.
  • getToolTipText (optional, default = generic body function) Returns text that's being used for the body of a tooltip. This tooltip provides information to the user about the node that's currently hovered by the mouse cursor. This function needs to return a string representing HTML-code that will be executed and receives 1 parameter:
    • d: DataNode: Node for which the tooltip body text should be returned. NOTE: Be very cautious in passing user input directly as a result of this function. Please always sanitize the user's input before returning it, as this might lead to reflected XSS-attacks.
Clone this wiki locally