Slider<D> constructor

Slider<D>({
  1. SelectionTrigger eventTrigger = SelectionTrigger.tapAndDrag,
  2. SymbolRenderer? handleRenderer,
  3. D? initialDomainValue,
  4. SliderListenerCallback<D>? onChangeCallback,
  5. String? roleId,
  6. bool snapToDatum = false,
  7. SliderStyle? style,
  8. int layoutPaintOrder = LayoutViewPaintOrder.slider,
})

Constructs a Slider.

eventTrigger sets the type of gesture handled by the slider.

handleRenderer draws a handle for the slider. Defaults to a rectangle.

initialDomainValue sets the initial position of the slider in domain units. The default is the center of the chart.

onChangeCallback will be called when the position of the slider changes during a drag event.

roleId optional custom role ID for the slider. This can be used to allow multiple Slider behaviors on the same chart. Normally, there can only be one slider (per event trigger type) on a chart. This setting allows for configuring multiple independent sliders.

snapToDatum configures the slider to snap snap onto the nearest datum (by domain distance) when dragged. By default, the slider can be positioned anywhere along the domain axis.

style configures the color and sizing of the slider line and handle.

layoutPaintOrder configures the order in which the behavior should be painted. This value should be relative to LayoutPaintViewOrder.slider. (e.g. LayoutViewPaintOrder.slider + 1).

Implementation

Slider({
  this.eventTrigger = SelectionTrigger.tapAndDrag,
  SymbolRenderer? handleRenderer,
  D? initialDomainValue,
  SliderListenerCallback<D>? onChangeCallback,
  String? roleId,
  this.snapToDatum = false,
  SliderStyle? style,
  this.layoutPaintOrder = LayoutViewPaintOrder.slider,
})  : _handleRenderer = handleRenderer ?? RectSymbolRenderer(),
      _roleId = roleId ?? '',
      _style = style ?? SliderStyle(),
      _domainValue = initialDomainValue {
  if (_domainValue != null) {
    _dragStateToFireOnPostRender = SliderListenerDragState.initial;
  }

  // Setup the appropriate gesture listening.
  switch (eventTrigger) {
    case SelectionTrigger.tapAndDrag:
      _gestureListener = GestureListener(
        onTapTest: _onTapTest,
        onTap: _onSelect,
        onDragStart: _onSelect,
        onDragUpdate: _onSelect,
        onDragEnd: _onDragEnd,
      );
    case SelectionTrigger.pressHold:
      _gestureListener = GestureListener(
        onTapTest: _onTapTest,
        onLongPress: _onSelect,
        onDragStart: _onSelect,
        onDragUpdate: _onSelect,
        onDragEnd: _onDragEnd,
      );
    case SelectionTrigger.longPressHold:
      _gestureListener = GestureListener(
        onTapTest: _onTapTest,
        onLongPress: _onLongPressSelect,
        onDragStart: _onSelect,
        onDragUpdate: _onSelect,
        onDragEnd: _onDragEnd,
      );
    case SelectionTrigger.hover:
    case SelectionTrigger.tap:
      throw ArgumentError('Slider does not support the event trigger '
          '"$eventTrigger"');
  }

  // Set up chart draw cycle listeners.
  _lifecycleListener = LifecycleListener<D>(
    onData: _setInitialDragState,
    onAxisConfigured: _updateViewData,
    onPostrender: _fireChangeEvent,
  );

  // Set up slider event listeners.
  _sliderEventListener = SliderEventListener<D>(onChange: onChangeCallback);
}