scalafx.scene.AccessibleAction.scala Maven / Gradle / Ivy
/*
* Copyright (c) 2011-2018, ScalaFX Project
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions are met:
* * Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* * Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
* * Neither the name of the ScalaFX Project nor the
* names of its contributors may be used to endorse or promote products
* derived from this software without specific prior written permission.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL THE SCALAFX PROJECT OR ITS CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
* SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
* AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
package scalafx.scene
import javafx.{scene => jfxs}
import scalafx.delegate.{SFXEnumDelegate, SFXEnumDelegateCompanion}
/**
* This enum describes the actions that an assistive technology
* such as a screen reader can request from the scene graph.
*
* The {@link AccessibleRole} dictates the set of actions that
* the screen reader will request for a particular control. For
* example, a push button normally fires an event to indicate
* that it was pressed in response to the FIRE action.
*
* An action may have any number of parameters, depending on the particular action.
*
* Wraps [[http://docs.oracle.com/javase/8/javafx/api/javafx/scene/AccessibleAction.html]]
*/
object AccessibleAction extends SFXEnumDelegateCompanion[jfxs.AccessibleAction, AccessibleAction] {
/**
* Request that the node be decremented by a large value.
* A smaller decrement is requested using {@link #DECREMENT}.
*
*/
case object BlockDecrement extends AccessibleAction(jfxs.AccessibleAction.BLOCK_DECREMENT)
/**
* Request that the node be incremented by a large value.
* A smaller increment is requested using {@link #INCREMENT}.
* Used by Slider, ScrollBar, and others
*/
case object BlockIncrement extends AccessibleAction(jfxs.AccessibleAction.BLOCK_INCREMENT)
/**
* Request that the node should become collapsed.
*
* Used by TreeItem, TitledPane, and others
*/
case object Collapse extends AccessibleAction(jfxs.AccessibleAction.COLLAPSE)
/**
* Request that the node be decremented by a small value.
* A larger decrement is requested using {@link #BLOCK_DECREMENT}.
*
* Used by Slider, ScrollBar, and others
*
*/
case object Decrement extends AccessibleAction(jfxs.AccessibleAction.DECREMENT)
/**
* Request that the node should become expanded.
*
* Used by TreeItem, TitledPane, and others
*
*/
case object Expand extends AccessibleAction(jfxs.AccessibleAction.EXPAND)
/**
* Fires the primary action for the node. For example, a push
* button will normally send an action event to notify listeners
* that is has been activated.
*
* Used by Button, Hyperlink, and others
*
*/
case object Fire extends AccessibleAction(jfxs.AccessibleAction.FIRE)
/**
* Request that the node be incremented by a small value.
* A larger increment is requested using {@link #BLOCK_INCREMENT}.
*
* Used by Slider, ScrollBar, and others
*
*/
case object Increment extends AccessibleAction(jfxs.AccessibleAction.INCREMENT)
/**
* Request that the node take focus. By default, a node will
* request focus using {@link javafx.scene.Node#requestFocus()}.
* Both JavaFX and the assisteve technology have the concept of
* a focus node and most of the time, they are the same.
* In some cases, a control might want the JavaFX focus to remain
* on the parent, while the assistive technology focus is on the child.
* For example, a table may respond to this request by setting focus
* to a cell inside the table before allowing the default to run.
*
* Used by Node, TabItem, TableCell and others
*/
case object RequestFocus extends AccessibleAction(jfxs.AccessibleAction.REQUEST_FOCUS)
/**
* Request the node to show an item, scrolling if required.
*
* Used by ListView, TreeView, and others
*
* Parameters:
*
* - {@link Node} the item to show
*
*/
case object ShowItem extends AccessibleAction(jfxs.AccessibleAction.SHOW_ITEM)
/**
* Request the node to show a text range, scrolling if required.
*
* Used by TextField and TextArea.
*
* Parameters:
*
* - {@link java.lang.Integer} the start offset
* - {@link java.lang.Integer} the end offset
*
*/
case object ShowTextRange extends AccessibleAction(jfxs.AccessibleAction.SHOW_TEXT_RANGE)
/**
* Request the node to set the selection to a list of items.
*
* Used by ListView, TreeView, and others
*
* Parameters:
*
* - {@link javafx.collections.ObservableList}<{@link Node}> the items to select
*
*/
case object SetSelectedItems extends AccessibleAction(jfxs.AccessibleAction.SET_SELECTED_ITEMS)
/**
* Request the node to set the selection to range of text.
*
* Used by TextField and TextArea.
*
* Parameters:
*
* - {@link java.lang.Integer} the start offset
* - {@link java.lang.Integer} the end offset
*
*/
case object SetTextSelection extends AccessibleAction(jfxs.AccessibleAction.SET_TEXT_SELECTION)
/**
* Request the node to set the current text.
*
* Used by TextField and TextArea.
*
* Parameters:
*
* - {@link String} the new text
*
*/
case object SetText extends AccessibleAction(jfxs.AccessibleAction.SET_TEXT)
/**
* Request the node to set the current value.
*
* Used by Slider, Scrollbars, and others
*
* Parameters:
*
* - {@link java.lang.Double} the new value
*
*/
case object SetValue extends AccessibleAction(jfxs.AccessibleAction.SET_VALUE)
/**
* Request the node to show a menu. If the node is a control,
* then the context menu for the control is shown. If the node
* is a menu, then the submenu for the menu is shown.
*
* Used by Node, Menu
*
* Parameters:
*
*
*/
case object ShowMenu extends AccessibleAction(jfxs.AccessibleAction.SHOW_MENU)
protected override def unsortedValues: Array[AccessibleAction] = Array(
BlockDecrement, BlockIncrement, Collapse, Decrement, Expand, Fire, Increment, RequestFocus, ShowItem,
ShowTextRange, SetSelectedItems, SetTextSelection, SetText, SetValue, ShowMenu
)
}
sealed abstract class AccessibleAction(override val delegate: jfxs.AccessibleAction) extends SFXEnumDelegate[jfxs.AccessibleAction]
© 2015 - 2025 Weber Informatics LLC | Privacy Policy