-
Notifications
You must be signed in to change notification settings - Fork 29
Data Layer
API Reference ▸ Data Layer
A data layer is a layer in terms of depth of z-index within a panel for displaying data. It is clipped by the panel's defined clip area and can be one of any supported type. Depending on the type of the data layer it will be able to display different data and support different layout directives.
A data layer's layout is a serializable object that describes every customizable feature of a LocusZoom plot with nested values. It should only ever contain scalar values, arrays, and objects - no functions!
Several directives supported by data layers may be scalable, and will be denoted as such. Scalable directives are those that can be defined statically as a scalar value (string or number), on or more Scale Functions, or a combination thereof.
For example, consider an directive of an element on a data layer that denotes that elements color, and the use case warrants a color of red all the time:
{
color: "#FF0000"
}
If this is a scalable directive then we can also use a scale function to alter the color dynamically depending on the data the element represents (i.e. a different color depending on the value of a specific field):
{
color: {
scale_function: "categorical_bin",
field: "animal",
parameters: {
categories: ["dog", "cat", "llama"],
values: ["#FF0000","#00FF00","#0000FF"]
}
},
}
In this example the color is a single scale function that operates on the value of the animal
field on the data underlying each rendered element. If an element's data animal
is "dog"
, the element's color will resolve to red ("#FF0000"
).
Finally, scalable directives can be defined as an array the combines various scale functions to achieve more complex resolution to a single value:
{
color: [
{
scale_function: "if",
field: "is_captive",
parameters: {
field_value: true,
then: "#000000"
}
},
{
scale_function: "categorical_bin",
field: "animal",
parameters: {
categories: ["dog", "cat", "llama"],
values: ["#FF0000","#00FF00","#0000FF"]
}
},
"#999999"
]
}
When a scalable parameter is defined as an array each element in the array is evaluated in order until a non-null value is found. In the example above each element's is_captive
value is evaluated first using the if
scale function which performs a basic conditional match. If the value is true then a string for black ("#000000"
) is returned and the color has been resolved. If not then the if
scale function will return null
, continuing on to the next definition in the array (the same categorical_bin
scale function shown before). Here, if the animal
value on an element does not match any of the defined categories then the return will be null
, and the loop will continue to the last element: "#999999"
. Since this value is a scalar (string or number, not an object) it will be resolved as the color.
In this way any scalable directive, such as color, can be defined in terms of arbitrarily many independent data fields for a given element.
-
type
- String
The name of a definedDataLayer
class. LocusZoom Core comes pre-supplied with several types of Data Layers already defined and provides an API to create custom Data Layers as needed. See Data Layer Types for more details. -
fields
- Array
An array of strings that map to valid fields in the Data Sources. These values will be processed during every request for data so that every data object stored in the Data Layer has each of these values as a named property. -
color
- String or Object, Scalable
A string representing a uniform color for data represented by a data layer or an object describing a dynamic coloring scheme. -
z_index
- Number
An integer representing the order in which a data layer should be rendered relative to other data layers. Data layers with higher z_index values are rendered above those with lower values. This value will be automatically assigned to a data layer as it is added through the normal parsing of a layout object during initialization, and any value defined here may be overridden to ensure that all data layers for a panel have a meaningful integer z_index beginning at 0.
-
(x|y)_axis
- Object
An object that attaches a data field to an axis and sets limits on the range of the data displayed.For a panel with axes, both axes (
data_layer.x_axis
anddata_layer.y_axis
) should be defined as objects with at least a field defined on each for a data layer to render properly. Not all panels and data layers have axes in the traditional sense. If a panel / data layer does not define anx_axis
, for example, then the x_axis (shown or not) is assumed to be genetic position and the range of the axis shown assumed to be bounded by thestart
andend
values defined in the State.-
(x|y)_axis.field
- String
Name of the field to map to the axis. The field name used here should also be present indata_layer.fields
. -
y_axis.axis
- Number: 1 or 2
Number signifying which of the two available y axes to bind this data layer. Only values1
(left y-axis) and2
(right y-axis) are valid. If not set, or set to any value other than1
or2
, this value will default to1
. -
(x|y)_axis.floor
- Number
Discrete minimum value for data points on the axis. By default the lower limit on the axis will be the lower limit of the extent of the data set mapped to the axis. This value can override that automatic limit by forcing a specific minimum value. -
(x|y)_axis.ceiling
- Number
Discrete maximum value for data points on the axis. By default the upper limit on the axis will be the upper limit of the extent of the data set mapped to the axis. This value can override that automatic limit by forcing a specific maximum value. -
(x|y)_axis.lower_buffer
- Number
Amount to expand to the lower end of an axis as a proportion of the extent of the data. For instance, if a data ranges from 30 to 70 and the lower buffer is set to0.25
then the lower end of the axis will be expanded by 25% of the extent of the data (70 - 30 = 40 units), or 10 units, dropping the lower end of the axis to 20. Any buffer defined here will be overridden if afloor
is also defined. -
(x|y)_axis.upper_buffer
- Number
Amount to expand to the upper end of an axis as a proportion of the extent of the data. For instance, if a data ranges from 0 to 50 and the upper buffer is set to0.1
then the upper end of the axis will be expanded by 10% of the extent of the data (50 - 0 = 50 units), or 5 units, expanding the upper end of the axis to 55. Any buffer defined here will be overridden if aceiling
is also defined. -
(x|y)_axis.min_extent
- Array
A discrete extent to behave as the minimum low and high for the axis. This should be array of exactly two numbers. For example, a min_extent of[ 0, 10 ]
will ensure that the axis will at least range from 0 to 10 regardless of the data mapped to it. If the data or the data combined withlower_buffer
and/orupper_buffer
expands beyond the minimum extent in either direction then the axis will expand beyond the minimum extent to follow suit. Either value in themin_extent
array may be overridden by a discretefloor
orceiling
value.
-
LocusZoom data layers support the binding of mouse events to categorize individual data elements as highlighted or selected. The State object keeps arrays of element IDs for all highlighted and selected elements on each data layer to be used for further interaction logic. The act of highlighting or selecting an element also applies data element CSS classes that are suffixed (e.g. with -highlighted
or -selected
) to denote the status visually.
The data layer layout supports a variety of directives to explicitly describe when the statuses of highlighted and selected are to be applied, or removed, for elements in the data layer:
-
highlighted
- Object
An object describing when an element's highlighted status should be enabled, disabled or toggled. -
highlighted.(onmouseover|onmouseout|onclick|onctrlclick|onshiftclick|onctrlshiftclick)
- String
A string describing the preferred highlighted status of an element when the given mouse action occurs on it. Supported values are"on"
(ensure the element is highlighted),"off"
(ensure the element is not highlighted),"toggle"
(if the element is highlighted then unhighlight it and vice versa), and"toggle_exclusive"
(if the element is highlighted then unhighlight it and vice versa, and if the new status is highlighted then unhighlight all other elements, enforcing only one highlighted element at a time). -
selected
- Object
An object describing when an element's selected status should be enabled, disabled or toggled. -
selected.(onmouseover|onmouseout|onclick|onctrlclick|onshiftclick|onctrlshiftclick)
- String
A string describing the preferred selected status of an element when the given mouse action occurs on it. Supported values are"on"
(ensure the element is selected),"off"
(ensure the element is not selected),"toggle"
(if the element is selected then unselect it and vice versa), and"toggle_exclusive"
(if the element is selected then unselect it and vice versa, and if the new status is selected then unselect all other elements, enforcing only one selected element at a time).
-
tooltip
- Object
An object that defines the content and behavior of a tool tip to be displayed when interacting with elements in the data layer. All data layers render tool tips visually the same way, but each data layer has custom logic to position a tool tip relative to an element. -
tooltip.(show|hide)
- String or Object
This parameter encodes the logic for whether a tool tip should be shown or hidden for an element depending on its highlighted and/or selected statuses. Define logic in terms of the strings"highlighted"
,"unhighlighted"
,"selected"
, and"unselected"
. As a simple example:tooltip: { show: "highlighted", hide: "unhighlighted" }
This will show (create) the tool tip when the element is highlighted and hide (destroy) the tool tip when the element is unhighlighted, a status defined by the
highlighted
parameter of the data layer.More complex boolean combinations of the four available statuses can be done with an object/array syntax. For example:
tooltip: { show: { or: ["highlighted", "selected"] }, hide: { and: ["unhighlighted","unselected] } }
This will ensure that a tool tip is should on any element that is highlighted or selected or both, and ensure that tool tips are not shown for elements that are neither highlighted nor selected. When the internal logic is triggered to interpret these directives relative to an element's status a tool tip will only be shown if its
show
logic resolves to true and itshide
logic resolves to false (e.g. if bothshow
andhide
resolve to true, no tool tip will be shown). -
tooltip.closable
- Boolean
Whether a tool tip should render a "close" button in the upper right corner. When clicked the tool tip will be destroyed. Subsequent mouse events on an element that would cause a tool tip to be shown will recreate the tool tip. By default this is not defined, and therefore close buttons will not be rendered. -
tooltip.html
- String
HTML to render inside the tool tip. Any data fields that are present in the data layer'sfields
directive can be resolved to element-specific values inside a tool tip by using double-curly-bracket notation. For example:"Species: {{animal}}"
will attempt to resolve{{animal}}
to the value of theanimal
field on the data bound to the element when the tool tip is rendered. Such field declarations must match the elements in thefields
array exactly, so should include namespaces and/or transformations if present in thefields
array definition.
-
legend
- Array
A Legend data layer layout array. The contents of the array should be objects describing individual elements to be shown in the legend, which the parent panel will aggregate together with legend elements from sibling data layers.
-
transition
- Object
An object that defines how data in the data layer should transition when updated. If defined then all data layer types that support transitions will transition updates to data. By default transitions are not defined for any data layer type. -
transition.duration
- Number
Number of milliseconds for the transition to take place. If a transition object is defined in the layout, but this value is not defined, then this will default to0
. -
transition.ease
- String
Easing method for the transition. See d3.ease documentation for information on building easing method strings. If a transition object is defined in the layout, but this value is not defined, then this will default to"cubic-in-out"
.
-
label
- Object
An object that defines simple dynamic text labels for elements on a data layer. Labels differ from tool tips in that they are rendered as SVG elements (and thus are a part of the image that persists when downloading the SVG) and that they will render or not independent of any mouse interaction with the element. Labels may also be implemented with logic to attempt to keep adjacent labels from overlapping one another. -
label.text
- String
Text to render for the label. Any data fields that are present in the data layer'sfields
directive can be resolved to element-specific values inside a label by using double-curly-bracket notation. For example:"Species: {{animal}}"
will attempt to resolve{{animal}}
to the value of theanimal
field on the data bound to the element when the tool tip is rendered. Such field declarations must match the elements in thefields
array exactly, so should include namespaces and/or transformations if present in thefields
array definition. -
label.spacing
- Number
Number of pixels to attempt to fit between labels that are very close to one another. Used when labels are rendered and iterative logic executes to push labels apart that may be overlapping. -
label.filters
- Array
Array of objects that each represent a filter to determine whether a label should render for the element or not. For example:
filters: [
{
field: "height",
operator: ">=",
value: 50
},
{
field: "weight",
operator: "<",
value: 200
}
]
In this example each element is evaluated first on its height
parameter and then on its weight
parameter. Only elements with a height
>= 50 and a weight
< 200 will have a label rendered.
-
label.style
- Object
Object describing styles for the label's text element. Conforms to the d3 standard style object specification. -
label.lines.style
- Object
Object describing styles for lines connecting labels to their parent data elements. Conforms to the d3 standard style object specification.
LocusZoom has the following Data Layer types defined in the core:
The genes
Data Layer type implements a visualization of gene/transcript/exon information. It implements a custom tool tip rendering function to position tool tips (if defined) above or below genes depending on where there is available space (relative to the panel).
-
label_font_size
- Number
Font size (letter height) in pixels for each gene's label. Defaults to12
. -
label_exon_spacing
- Number
Spacing in pixels between the baseline of each gene's label and the top of exons for that gene. Defaults to4
. -
exon_height
- Number
Height, in pixels, of each exon in each gene. Defaults to16
. -
bounding_box_padding
- Number
Single value in pixels to be used as top, bottom, left, and right padding from data displayed to represent a given gene to its bounding box. The bounding box is directly displayed when a gene is selected but is otherwise invisible, however it represents the "footprint" of a gene in the data layer when the data layer's render function positions genes on tracks such that none overlap. Thus, a largerbounding_box_padding
will give genes more space during automatic positioning. Defaults to6
. -
track_vertical_spacing
- Number
Vertical space between gene tracks, in pixels, in which nothing will be rendered. Defaults to10
. -
selectable
- See general definition above
Defaults toone
.
The line
Data Layer type implements a standard line plot. It implements a custom tool tip rendering function to position a tool tip (if defined) that updates with new values as the mouse moves along the rendered line.
-
interpolate
- String
Interpolation mode for the line to be applied to the line directly using d3'sinterpolate()
method (documentation here). Defaults tolinear
. -
style
- Object
CSS styles built as an object to be applied to the line directly using d3'sstyle()
method (documentation here).Defaults to:
{
"fill": "transparent",
"stroke-width": "2px"
}
-
hitarea_width
- Number
Stroke width (in pixels) to apply to invisible hit area rendered over the line. This hit area is used to detect mouse interaction with the line (instead of the line itself to allow for intuitive mouse behavior when working with a thin or dotted line). Note that a wider hit area may decrease the accuracy of the mouse event's position relative to the line. Defaults to5
. -
selectable
- See general definition above
Defaults tofalse
, selectability not implemented for this data layer type.
The scatter
Data Layer type implements a standard scatter plot. It implements a custom tool tip rendering function to position tool tips (if defined) to the left or right of points depending on where there is available space (relative to the panel).
-
id_field
- String
Which field, as defined in thefields
array, is to be used as a unique identifier for individual scatter points. Defaults toid
. -
point_size
- Number, Scalable
Size, in square pixels, to render each point in the scatter plot. For example, a square point with apoint_size
of 64 will be an 8x8 square. Defaults to40
. -
point_shape
- String, Scalable
Shape of each point on the data layer as represented by a string. Supported values map to the d3 SVG Symbol Types (i.e.: "circle", "cross", "diamond", "square", "triangle-down", and "triangle-up"). Defaults to "circle". -
color
- See general definition above, Scalable
Defaults to"#888888"
. -
selectable
- See general definition above
Defaults tomultiple
.