All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scalafx.event.EventDispatchChain.scala Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2011-2014, 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.event

import javafx.{event => jfxe}

import scala.language.implicitConversions
import scalafx.Includes._
import scalafx.delegate.SFXDelegate

object EventDispatchChain {
  implicit def sfxEventDispatchChain2jfx(v: EventDispatchChain): jfxe.EventDispatchChain =
    if (v != null) v.delegate else null
}

/**
 * Represents a chain of `EventDispatcher` objects, which can dispatch
 * an `Event`. The event is dispatched by passing it from one
 * `EventDispatcher` to the next in the chain until the end of chain is
 * reached. Each `EventDispatcher` in the chain can influence the event
 * path and the event itself. The chain is usually formed by following some
 * parent - child hierarchy from the root to the event target and appending
 * all `EventDispatcher` objects encountered to the chain.
 *
 *
 * Wraps a $JFX $URL0 $FC]].
 *
 * @define FC EventDispatchChain
 * @define URL0 [[https://docs.oracle.com/javase/8/javafx/api/javafx/event/EventDispatchChain.html
 * @define JFX JavaFX
 * @define ORIGINALDOC Original Documentation]].
 */
abstract class EventDispatchChain(override val delegate: jfxe.EventDispatchChain)
  extends SFXDelegate[jfxe.EventDispatchChain] {

  /**
   * Appends the specified `EventDispatcher` to this chain. Returns a
   * reference to the chain with the appended element.
   * 

* The caller shouldn't assume that this `EventDispatchChain` remains * unchanged nor that the returned value will reference a different chain * after the call. All this depends on the `EventDispatchChain` * implementation. *

* So the call should be always done in the following form: * `chain = chain.append(eventDispatcher);` * * @param eventDispatcher the `EventDispatcher` to append to the * chain * @return the chain with the appended event dispatcher * @see $URL0#append $ORIGINALDOC */ def append(eventDispatcher: EventDispatcher): EventDispatchChain = delegate.append(eventDispatcher) /** * Prepends the specified `EventDispatcher` to this chain. Returns a * reference to the chain with the prepended element. *

* The caller shouldn't assume that this `EventDispatchChain` remains * unchanged nor that the returned value will reference a different chain * after the call. All this depends on the `EventDispatchChain` * implementation. *

* So the call should be always done in the following form: * `chain = chain.prepend(eventDispatcher);` * * @param eventDispatcher the `EventDispatcher` to prepend to the * chain * @return the chain with the prepended event dispatcher * @see $URL0#prepend $ORIGINALDOC */ def prepend(eventDispatcher: EventDispatcher): EventDispatchChain = delegate.prepend(eventDispatcher) /** * Dispatches the specified event through this `EventDispatchChain`. * The return value represents the event after processing done by the chain. * If further processing is to be done after the call the event referenced * by the return value should be used instead of the original event. In the * case the event is fully handled / consumed in the chain the returned * value is `null` and no further processing should be done with that * event. * * @param event the event to dispatch * @return the processed event or `null` if the event had been fully * handled / consumed * @see $URL0#dispatchEvent $ORIGINALDOC */ def dispatchEvent(event: Event): Event = delegate.dispatchEvent(event) }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy