Class LineVisualSet<T>
java.lang.Object
com.amalgamasimulation.charts.visualsets.VisualSet<T>
com.amalgamasimulation.charts.visualsets.AbstractLineVisualSet<T>
com.amalgamasimulation.charts.visualsets.LineVisualSet<T>
- Type Parameters:
T- visual set data elements type
- All Implemented Interfaces:
IClipboardTextPropertyOwner<Double>,ILegendNodePropertiesOwner,IMinMaxValuePropertyOwner,IUpdatePolicyPropertyOwner,IAbstractChartVisualSet,ILineChartVisualSet
public class LineVisualSet<T>
extends AbstractLineVisualSet<T>
implements ILineChartVisualSet, IClipboardTextPropertyOwner<Double>
Visual set for drawing line plots with points. Optionally draws the plot as a
stack diagram.
Can be drawn on AbstractLineChart.
Does not allow multiple data elements with the same X-axis value. All elements must be ordered in ascending order of values along the x-axis.
- Author:
- Aleksey Kirillov
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic enumEnumeration that represents the interpolation type of a plot.static enumEnumeration that represents the way to draw the elements of the plot.classInternal class that represents visual element for line data element.Nested classes/interfaces inherited from class com.amalgamasimulation.charts.visualsets.AbstractLineVisualSet
AbstractLineVisualSet.AbstractLineVisualElement, AbstractLineVisualSet.Extrapolation, AbstractLineVisualSet.PointsAndLinesStyleNested classes/interfaces inherited from class com.amalgamasimulation.charts.visualsets.VisualSet
VisualSet.ContextMenuHandler<T>, VisualSet.UpdatePolicy, VisualSet.VisualElement -
Field Summary
FieldsModifier and TypeFieldDescriptionprotected LineVisualSet.InterpolationTypeprotected LineVisualSet.LineDrawingPolicyprotected Colorprotected booleanFields inherited from class com.amalgamasimulation.charts.visualsets.AbstractLineVisualSet
extrapolation, legendTextProvider, lineColor, lineStyle, lineWidth, maxValueProvider, pointsAndLinesStyle, pointSize, valueExtractorFields inherited from class com.amalgamasimulation.charts.visualsets.VisualSet
argumentExtractor, contentsToBeginArguments, contentsToEndArguments, contentsToVisualElements, contextMenuHandlers, dataElementsProvider, listeners, maxArgument, maxValueCache, minArgument, minValueCache, mouseEnterHandlers, mouseExitHandlers, mousePressedHandlers, mouseTransparent, name, needsUpdate, oldContentsList, tooltipTextExtractor, updatePolicy, visibilityChangeHandlers, visualElementsList -
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionaddContextMenuHandler(VisualSet.ContextMenuHandler<T> contextMenuHandler) Adds the action to be executed every time a context menu for given data element is called.addMouseEnterHandler(BiConsumer<T, javafx.scene.input.MouseEvent> handler) Adds the action to be executed every time mouse enters to any visual element borders.addMouseExitHandler(BiConsumer<T, javafx.scene.input.MouseEvent> handler) Adds the action to be executed every time the mouse exits the previously entered element's bounds.addMousePressedHandler(BiConsumer<T, javafx.scene.input.MouseEvent> handler) Adds the action to be executed every time a mouse button is pressed.addVisibilityChangeHandler(Consumer<VisibilityChangeDescriptor<? extends IAbstractChartVisualSet>> visibilityChangeHandler) Adds the action to be executed every time the visibility of this VisualSet is changed.createVisualElement(T contents) Creates a new instance ofVisualSet<T>.VisualElementcorresponding to the current VisualSet type.getClipboardText(Double object) Returns the text that will be copied to clipboard for the given object.Returns the list of visual set contents.Returns the currentLineVisualSet.InterpolationTypei.e.Returns the color of theLegend's icon corresponding to this VisualSetReturns the currentLineVisualSet.LineDrawingPolicyi.e.Returns the color of a stack visual element.getVisualElements(boolean recalculationRequired) Returns the list of visual elements corresponding to current data elements.booleanReturns the visibility of a stack visual element.setClipboardText(Function<Double, String> clipboardTextExtractor) Sets the conversion method from values of each plot data element into text that will be copied to clipboard.setExtrapolation(AbstractLineVisualSet.Extrapolation extrapolation) Sets the of the plot i.e.setInterpolationType(LineVisualSet.InterpolationType interpolationType) Sets the newLineVisualSet.InterpolationTypei.e.setLegendText(Supplier<String> legendTextProvider) Sets theLegendlabel text represents this visual set.setLineColor(Color color) Sets the line color of the plot.setLineDrawingPolicy(LineVisualSet.LineDrawingPolicy lineDrawingPolicy) Sets the newLineVisualSet.LineDrawingPolicyi.e.setLineStyle(LineStyle lineStyle) Sets theLineStyleof the plot i.e.setLineWidth(double width) Sets the width of the line, in pixels.setMaxValue(Supplier<Double> maxValueProvider) Sets the supplier of max value.setMouseTransparent(boolean mouseTransparent) Sets the value of the property mouseTransparent.setPointsAndLinesStyle(AbstractLineVisualSet.PointsAndLinesStyle pointsAndLinesStyle) Sets theAbstractLineVisualSet.PointsAndLinesStyleof the plot i.e.setPointSize(double pointSize) Sets the diameter of the point, in pixels.setStackFillColor(Color stackFillColor) Sets the color of a stack visual element.setStackVisible(boolean stackVisible) Sets the visibility of a stack visual element.setTooltipText(Function<T, String> tooltipTextExtractor) Adds tooltip text to display when the mouse is hovered over a visual element representing given data element.setUpdatePolicy(VisualSet.UpdatePolicy updatePolicy) Sets the newVisualSet.UpdatePolicyi.e.Methods inherited from class com.amalgamasimulation.charts.visualsets.AbstractLineVisualSet
getExtrapolation, getLegendText, getLineColor, getLineStyle, getLineWidth, getMaxValue, getMinValue, getPointsAndLinesStyle, getPointSize, getValueMethods inherited from class com.amalgamasimulation.charts.visualsets.VisualSet
addVisualElement, addVisualElement, addVisualSetChangeHandler, clearDependencies, getArgument, getContextMenuHandlers, getDataElements, getInjectionIndex, getMaxArgument, getMinArgument, getMouseEnterHandlers, getMouseExitHandlers, getMousePressedHandlers, getName, getTooltipText, getUpdatePolicy, getVisibilityChangeHandlers, getVisibleVisualElementIndex, getVisibleVisualElementsCount, isMouseTransparent, isNeedsUpdate, recalculateVisualElements, removeContextMenuHandler, removeMouseEnterHandler, removeMouseExitHandler, removeMousePressedHandler, removeVisibilityChangeHandler, removeVisualElement, removeVisualSetChangeHandler, sortVisualElements, toString, update, updateMinMaxArgumentsValuesMethods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, waitMethods inherited from interface com.amalgamasimulation.charts.visualsets.types.IAbstractChartVisualSet
addVisualSetChangeHandler, getMaxArgument, getMinArgument, getName, getUpdatePolicy, getVisibilityChangeHandlers, getVisibleVisualElementsCount, isMouseTransparent, removeVisibilityChangeHandler, removeVisualSetChangeHandlerMethods inherited from interface com.amalgamasimulation.charts.visualsets.IUpdatePolicyPropertyOwner
getUpdatePolicy
-
Field Details
-
interpolationType
-
lineDrawingPolicy
-
stackVisible
protected boolean stackVisible -
stackFillColor
-
clipboardTextExtractor
-
-
Constructor Details
-
LineVisualSet
public LineVisualSet(String name, Supplier<List<T>> dataElementsProvider, Function<T, Double> argumentExtractor, Function<T, Double> valueExtractor) Constructs a LineVisualSet with given name, data elements and arguments/value extractors, i.e. a functions that specifies the rule for extracting an argument/value from a data element.- Parameters:
name- visual set name is used to sort and name the visual sets on the chartdataElementsProvider- data elements list provider. The provider is invalidated every time the chart is being redrawnargumentExtractor- a function that specifies the rule for extracting an argument from a data elementvalueExtractor- a function that specifies the rule for extracting a value from a data element
-
-
Method Details
-
setLineDrawingPolicy
Sets the newLineVisualSet.LineDrawingPolicyi.e. the way to draw the elements of the plot.- Parameters:
lineDrawingPolicy- newLineVisualSet.LineDrawingPolicyi.e. the way to draw the elements of the plot- Returns:
- reference to this object
-
setInterpolationType
Sets the newLineVisualSet.InterpolationTypei.e. the interpolation type of the data for a given plot.- Parameters:
interpolationType- newLineVisualSet.InterpolationTypei.e. the interpolation type of the data for a given plot- Returns:
- reference to this object
-
setStackVisible
Sets the visibility of a stack visual element. The stack is an element that fills the space between the plot and the zero Y-axis grid line.- Parameters:
stackVisible- new visibility of a stack visual element- Returns:
- reference to this object
-
setStackFillColor
Sets the color of a stack visual element. The stack is an element that fills the space between the plot and the zero Y-axis grid line.- Parameters:
stackFillColor- new color of a stack visual element- Returns:
- reference to this object
-
setExtrapolation
Description copied from class:AbstractLineVisualSetSets the of the plot i.e. mode of extending a line to the maximum argument among all visual sets or to the current argument along the horizontal axis. Applicable only forAbstractLineVisualSet.- Overrides:
setExtrapolationin classAbstractLineVisualSet<T>- Parameters:
extrapolation- theAbstractLineVisualSet.Extrapolationof the plot- Returns:
- reference to this object
-
getLineDrawingPolicy
Returns the currentLineVisualSet.LineDrawingPolicyi.e. the way to draw the elements of the plot.- Returns:
- the current
LineVisualSet.LineDrawingPolicyi.e. the way to draw the elements of the plot
-
getInterpolationType
Returns the currentLineVisualSet.InterpolationTypei.e. the interpolation type of the data for a given plot.- Returns:
- the current
LineVisualSet.InterpolationTypei.e. the interpolation type of the data for a given plot
-
isStackVisible
public boolean isStackVisible()Returns the visibility of a stack visual element.- Returns:
- the visibility of a stack visual element
-
getStackFillColor
Returns the color of a stack visual element.- Returns:
- the color of a stack visual element
-
setClipboardText
Description copied from interface:IClipboardTextPropertyOwnerSets the conversion method from values of each plot data element into text that will be copied to clipboard.- Specified by:
setClipboardTextin interfaceIClipboardTextPropertyOwner<T>- Parameters:
clipboardTextExtractor- an extractor that converts the value of each plot data element into text that will be copied to the clipboard- Returns:
- reference to this object
-
setLineColor
Description copied from class:AbstractLineVisualSetSets the line color of the plot. Transparent and semi-transparent colors are allowed.- Overrides:
setLineColorin classAbstractLineVisualSet<T>- Parameters:
color- the line color of the plot- Returns:
- reference to this object
-
setTooltipText
Description copied from class:VisualSetAdds tooltip text to display when the mouse is hovered over a visual element representing given data element.- Specified by:
setTooltipTextin classVisualSet<T>- Parameters:
tooltipTextExtractor- a function that specifies the rule for extracting a tooltip text from a data element- Returns:
- reference to this object
-
setLineWidth
Description copied from class:AbstractLineVisualSetSets the width of the line, in pixels.- Overrides:
setLineWidthin classAbstractLineVisualSet<T>- Parameters:
width- the width of the line, in pixels- Returns:
- reference to this object
-
setPointSize
Description copied from class:AbstractLineVisualSetSets the diameter of the point, in pixels.- Overrides:
setPointSizein classAbstractLineVisualSet<T>- Parameters:
pointSize- the diameter of the point, in pixels- Returns:
- reference to this object
-
setLegendText
Description copied from interface:ILegendNodePropertiesOwnerSets theLegendlabel text represents this visual set.- Specified by:
setLegendTextin interfaceILegendNodePropertiesOwner- Overrides:
setLegendTextin classAbstractLineVisualSet<T>- Parameters:
legendTextProvider- theLegendlabel text represents this visual set- Returns:
- reference to this object
-
setPointsAndLinesStyle
public LineVisualSet<T> setPointsAndLinesStyle(AbstractLineVisualSet.PointsAndLinesStyle pointsAndLinesStyle) Description copied from class:AbstractLineVisualSetSets theAbstractLineVisualSet.PointsAndLinesStyleof the plot i.e. the methodology of drawing the visual elements for data elements.- Overrides:
setPointsAndLinesStylein classAbstractLineVisualSet<T>- Parameters:
pointsAndLinesStyle- theAbstractLineVisualSet.PointsAndLinesStyleof the plot i.e. the methodology of drawing the visual elements for data elements- Returns:
- reference to this object
-
getClipboardText
Description copied from interface:IClipboardTextPropertyOwnerReturns the text that will be copied to clipboard for the given object.- Specified by:
getClipboardTextin interfaceIClipboardTextPropertyOwner<T>- Parameters:
object- object for which the clipboard text is being checked- Returns:
- the text that will be copied to clipboard for the given object
-
getContents
Description copied from interface:IAbstractChartVisualSetReturns the list of visual set contents.- Specified by:
getContentsin interfaceIAbstractChartVisualSet- Overrides:
getContentsin classVisualSet<T>- Returns:
- the list of visual set contents
-
addContextMenuHandler
Description copied from class:VisualSetAdds the action to be executed every time a context menu for given data element is called.- Overrides:
addContextMenuHandlerin classVisualSet<T>- Parameters:
contextMenuHandler- context menu call action- Returns:
- reference to this object
-
addMouseEnterHandler
Description copied from class:VisualSetAdds the action to be executed every time mouse enters to any visual element borders.- Overrides:
addMouseEnterHandlerin classVisualSet<T>- Parameters:
handler- new mouse enter action- Returns:
- reference to this object
-
addMouseExitHandler
Description copied from class:VisualSetAdds the action to be executed every time the mouse exits the previously entered element's bounds.- Overrides:
addMouseExitHandlerin classVisualSet<T>- Parameters:
handler- new mouse exit action- Returns:
- reference to this object
-
addMousePressedHandler
Description copied from class:VisualSetAdds the action to be executed every time a mouse button is pressed.- Overrides:
addMousePressedHandlerin classVisualSet<T>- Parameters:
handler- new mouse button pressed action- Returns:
- reference to this object
-
addVisibilityChangeHandler
public LineVisualSet<T> addVisibilityChangeHandler(Consumer<VisibilityChangeDescriptor<? extends IAbstractChartVisualSet>> visibilityChangeHandler) Description copied from interface:IAbstractChartVisualSetAdds the action to be executed every time the visibility of this VisualSet is changed.- Specified by:
addVisibilityChangeHandlerin interfaceIAbstractChartVisualSet- Overrides:
addVisibilityChangeHandlerin classVisualSet<T>- Parameters:
visibilityChangeHandler- visibility change action- Returns:
- reference to this object
-
setMouseTransparent
Description copied from interface:IAbstractChartVisualSetSets the value of the property mouseTransparent. If true, this VisualSet is completely transparent to mouse events. When choosing target for mouse event, VisualSets with mouseTransparent set to true won't be taken into account.- Specified by:
setMouseTransparentin interfaceIAbstractChartVisualSet- Overrides:
setMouseTransparentin classVisualSet<T>- Parameters:
mouseTransparent- new value of property mouseTransparent- Returns:
- reference to this object
-
getVisualElements
Description copied from interface:IAbstractChartVisualSetReturns the list of visual elements corresponding to current data elements. Cannot be changed by the user.- Specified by:
getVisualElementsin interfaceIAbstractChartVisualSet- Specified by:
getVisualElementsin interfaceILineChartVisualSet- Overrides:
getVisualElementsin classVisualSet<T>- Parameters:
recalculationRequired- flag of the need to recalculate the visual elements- Returns:
- the list of visual elements corresponding to current data elements
-
createVisualElement
Description copied from class:VisualSetCreates a new instance ofVisualSet<T>.VisualElementcorresponding to the current VisualSet type.- Specified by:
createVisualElementin classVisualSet<T>- Parameters:
contents- data element for which theVisualSet<T>.VisualElementis being checked- Returns:
- a new instance of
VisualSet<T>.VisualElementcorresponding to the current VisualSet type
-
getLegendColor
Description copied from interface:ILegendNodePropertiesOwnerReturns the color of theLegend's icon corresponding to this VisualSet- Specified by:
getLegendColorin interfaceILegendNodePropertiesOwner- Overrides:
getLegendColorin classAbstractLineVisualSet<T>- Returns:
- the color of the
Legend's icon corresponding to this VisualSet
-
setUpdatePolicy
Description copied from interface:IAbstractChartVisualSetSets the newVisualSet.UpdatePolicyi.e. the VisualSet update control rule.- Specified by:
setUpdatePolicyin interfaceIAbstractChartVisualSet- Specified by:
setUpdatePolicyin interfaceIUpdatePolicyPropertyOwner- Overrides:
setUpdatePolicyin classVisualSet<T>- Parameters:
updatePolicy- newVisualSet.UpdatePolicyi.e. the VisualSet update control rule- Returns:
- reference to this object
-
setLineStyle
Description copied from class:AbstractLineVisualSetSets theLineStyleof the plot i.e. the methodology of drawing the lines for data elements.- Overrides:
setLineStylein classAbstractLineVisualSet<T>- Parameters:
lineStyle- theLineStyleof the plot i.e. the methodology of drawing the lines for data elements- Returns:
- reference to this object
-
setMaxValue
Description copied from class:AbstractLineVisualSetSets the supplier of max value. This value allows to set some "natural" max value of the data being displayed It will be used when scaling the Y-axis of the chart.- Overrides:
setMaxValuein classAbstractLineVisualSet<T>- Parameters:
maxValueProvider- the supplier of max value- Returns:
- reference to this object
-