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 7, Windows Vista SP2, Windows XP SP3, Windows XP x64 SP2, Windows Server 2008 R2, Windows Server 2008 SP2, Windows Server 2003 SP2
Información de versiones
Runtime de F#
Se admite en las versiones: 2.0, 4.0
Silverlight
Se admite en la versión: 3
Vea también
Referencia
Microsoft.FSharp.Control (Espacio de nombres de F#)
Historial de cambios
Fecha |
Historial |
Motivo |
---|---|---|
Septiembre de 2010 |
Se ha agregado un ejemplo de código. |
Mejora de la información. |