Class PointsVisualSet<T>
java.lang.Object
com.amalgamasimulation.charts.visualsets.VisualSet<T>
com.amalgamasimulation.charts.visualsets.PointsVisualSet<T>
- Type Parameters:
T- visual set data elements type
- All Implemented Interfaces:
IClipboardTextPropertyOwner<Double>,ILegendNodePropertiesOwner,IMinMaxValuePropertyOwner,IUpdatePolicyPropertyOwner,IAbstractChartVisualSet,ILineChartVisualSet
public class PointsVisualSet<T>
extends VisualSet<T>
implements IMinMaxValuePropertyOwner, ILegendNodePropertiesOwner, IUpdatePolicyPropertyOwner, ILineChartVisualSet, IClipboardTextPropertyOwner<Double>
Visual set for drawing plots with points.
Can be drawn on AbstractLineChart.
This VisualSet provides the opportunity to arrange points not only in ascending order of the X-axis values, but also in a random order, including the allocation of several different points on the same value of the horizontal axis.
- Author:
- Aleksey Kirillov
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionclassInternal class that represents visual element for point data element.Nested classes/interfaces inherited from class com.amalgamasimulation.charts.visualsets.VisualSet
VisualSet.ContextMenuHandler<T>, VisualSet.UpdatePolicy, VisualSet.VisualElement -
Field Summary
FieldsFields 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.Returns the point border color of the plot.getClipboardText(Double object) Returns the text that will be copied to clipboard for the given object.Returns the point fill color of the plot.Returns the color of theLegend's icon corresponding to this VisualSetReturns theLegendlabel text represents this visual set.doubleReturns the maximum Y-axis value for all data elements.doubleReturns the minimum Y-axis value for all data elements.doublegetPointSize(T element) Returns the diameter of the point, in pixels.getValue(double argument) Returns the value of the given X-axis argument.doubleReturns the value of the given data element.getVisualElements(boolean recalculationRequired) Returns the list of visual elements corresponding to current data elements.setBorderColor(Color borderColor) Sets the point border color of the plot.setClipboardText(Function<Double, String> clipboardTextExtractor) Sets the conversion method from values of each plot data element into text that will be copied to clipboard.setFillColor(Color fillColor) Sets the point fill color of the plot.setLegendText(Supplier<String> legendTextProvider) Sets theLegendlabel text represents this visual set.setMouseTransparent(boolean mouseTransparent) Sets the value of the property mouseTransparent.setPointSize(double pointSize) Sets the diameter of the point, in pixels.setPointSize(Function<T, Double> pointSizeExtractor) Sets the diameter of the point, in pixels.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.VisualSet
addVisualElement, addVisualElement, addVisualSetChangeHandler, clearDependencies, getArgument, getContents, 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, getContents, getMaxArgument, getMinArgument, getName, getUpdatePolicy, getVisibilityChangeHandlers, getVisibleVisualElementsCount, isMouseTransparent, removeVisibilityChangeHandler, removeVisualSetChangeHandlerMethods inherited from interface com.amalgamasimulation.charts.visualsets.IUpdatePolicyPropertyOwner
getUpdatePolicy
-
Field Details
-
borderColor
-
fillColor
-
pointSizeExtractor
-
valueExtractor
-
clipboardTextExtractor
-
legendTextProvider
-
-
Constructor Details
-
PointsVisualSet
public PointsVisualSet(String name, Supplier<List<T>> dataElementsProvider, Function<T, Double> argumentExtractor, Function<T, Double> valueExtractor) Constructs a PointsVisualSet 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
-
setPointSize
Sets the diameter of the point, in pixels. If this method is called, all point sizes will be set the same.- Parameters:
pointSize- the diameter of the point, in pixels- Returns:
- reference to this object
-
setPointSize
Sets the diameter of the point, in pixels.- Parameters:
pointSizeExtractor- a function that specifies the rule for extracting the diameter of the point from a data element- Returns:
- reference to this object
-
setFillColor
Sets the point fill color of the plot. Transparent and semi-transparent colors are allowed.- Parameters:
fillColor- the point fill color of the plot- Returns:
- reference to this object
-
setBorderColor
Sets the point border color of the plot. Transparent and semi-transparent colors are allowed.- Parameters:
borderColor- the point border color of the plot- Returns:
- reference to this object
-
getBorderColor
Returns the point border color of the plot.- Returns:
- the point border color of the plot
-
getFillColor
Returns the point fill color of the plot.- Returns:
- the point fill color of the plot.
-
getPointSize
Returns the diameter of the point, in pixels.- Parameters:
element- data element for which the point size is being checked- Returns:
- the diameter of the point, in pixels
-
getValue
Returns the value of the given data element.- Parameters:
element- data element for which the value is being checked- Returns:
- the value of the given data 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
-
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
-
setLegendText
Description copied from interface:ILegendNodePropertiesOwnerSets theLegendlabel text represents this visual set.- Specified by:
setLegendTextin interfaceILegendNodePropertiesOwner- Parameters:
legendTextProvider- theLegendlabel text represents this visual set- Returns:
- reference to this object
-
getLegendText
Description copied from interface:ILegendNodePropertiesOwnerReturns theLegendlabel text represents this visual set.- Specified by:
getLegendTextin interfaceILegendNodePropertiesOwner- Returns:
- the
Legendlabel text represents this visual set
-
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
-
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
public PointsVisualSet<T> addMousePressedHandler(BiConsumer<T, javafx.scene.input.MouseEvent> handler) 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 PointsVisualSet<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
-
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
-
getValue
Returns the value of the given X-axis argument.- Parameters:
argument- X-axis argument for which the value is being checked- Returns:
- the value of the given X-axis argument
-
getVisualElements
public List<PointsVisualSet<T>.PointsVisualElement> getVisualElements(boolean recalculationRequired) 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
-
getMinValue
public double getMinValue()Description copied from interface:IMinMaxValuePropertyOwnerReturns the minimum Y-axis value for all data elements. The minimum value is recalculated and cached at the moment the chart is redrawn. The method returns the value stored in the cache.- Specified by:
getMinValuein interfaceIMinMaxValuePropertyOwner- Returns:
- the minimum Y-axis value for all data elements
- See Also:
-
getMaxValue
public double getMaxValue()Description copied from interface:IMinMaxValuePropertyOwnerReturns the maximum Y-axis value for all data elements. The maximum value is recalculated and cached at the moment the chart is redrawn. The method returns the value stored in the cache.- Specified by:
getMaxValuein interfaceIMinMaxValuePropertyOwner- Returns:
- the maximum Y-axis value for all data elements
- See Also:
-
getLegendColor
Description copied from interface:ILegendNodePropertiesOwnerReturns the color of theLegend's icon corresponding to this VisualSet- Specified by:
getLegendColorin interfaceILegendNodePropertiesOwner- Returns:
- the color of the
Legend's icon corresponding to this VisualSet
-