Compartir a través de


Event.filter<'T,'Del> (Función de F#)

Devuelve un nuevo evento que escucha el evento original y desencadena el evento resultante únicamente cuando el argumento del evento pasa la función especificada.

Espacio de nombres/Ruta de acceso del módulo: Microsoft.FSharp.Control.Event

Ensamblado: FSharp.Core (en FSharp.Core.dll)

// Signature:
Event.filter : ('T -> bool) -> IEvent<'Del,'T> -> IEvent<'T> (requires delegate)

// Usage:
Event.filter predicate sourceEvent

Parámetros

  • predicate
    Tipo: 'T ->bool

    Función que se va a usar para determinar qué desencadenadores del evento se van a propagar.

  • sourceEvent
    Tipo: IEvent<'Del,'T>

    Evento de entrada.

Valor devuelto

Evento que solo pasa valores que pasan el predicado.

Comentarios

Esta función se denomina Filter en los ensamblados compilados.Si obtiene acceso a la función desde un lenguaje distinto de F# o mediante reflexión, use este nombre.

Ejemplo

En el siguiente ejemplo de código se muestra cómo utilizar la función Event.filter.En este ejemplo, los eventos del mouse se pasan solo cuando el puntero de este está en una región determinada.

let form = new Form(Text = "F# Windows Form",
                    Visible = true,
                    TopMost = true)
form.MouseMove
    |> Event.filter ( fun evArgs -> evArgs.X > 100 && evArgs.Y > 100)
    |> Event.add ( fun evArgs ->
        form.BackColor <- System.Drawing.Color.FromArgb(
            evArgs.X, evArgs.Y, evArgs.X ^^^ evArgs.Y) )

Plataformas

Windows 8, Windows 7, Windows Server 2012, Windows Server 2008 R2

Información de versiones

Versiones de la biblioteca básica de F#

Se admite en: 2.0, 4.0, portables

Vea también

Referencia

Control.Event (Módulo de F#)

Microsoft.FSharp.Control (Espacio de nombres de F#)