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 ->boolFunció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