public class Selection<K> implements Iterable

Known direct subclasses
MutableSelection

Subclass of Selection exposing public support for mutating the underlying selection data.


Object representing a "primary" selection and a "provisional" selection.

This class tracks selected items by managing two sets:

Primary Selection

Primary selection consists of items selected by a user. This represents the selection "at rest", as the selection does not contains items that are in a "provisional" selected state created by way of an ongoing gesture or band operation.

Provisional Selection

Provisional selections are selections which are interim in nature.

Provisional selection exists to address issues where a transitory selection might momentarily intersect with a previously established selection resulting in a some or all of the established selection being erased. Such situations may arise when band selection is being performed in "additive" mode (e.g. SHIFT or CTRL is pressed on the keyboard prior to mouse down), or when there's an active gesture selection (which can be initiated by long pressing an unselected item while there is an existing selection).

Parameters
<K>

Selection key type. @see StorageStrategy for supported types.

See also
MutableSelection

Summary

Public methods

boolean
boolean
equals(Object other)
int
boolean
@NonNull Iterator<K>

Returns an Iterator that iterators over the selection, *excluding* any provisional selection.

int
String

Inherited methods

From java.lang.Iterable
void
forEach(Consumer<T> action)
Spliterator<T>

Public methods

contains

Added in 1.0.0
public boolean contains(@Nullable K key)
Returns
boolean

true if the position is currently selected.

equals

public boolean equals(Object other)

hashCode

public int hashCode()

isEmpty

Added in 1.0.0
public boolean isEmpty()
Returns
boolean

true if the selection is empty.

iterator

Added in 1.0.0
public @NonNull Iterator<K> iterator()

Returns an Iterator that iterators over the selection, *excluding* any provisional selection.

size

Added in 1.0.0
public int size()
Returns
int

size of the selection including both final and provisional selected items.

toString

public String toString()