Nota:
El acceso a esta página requiere autorización. Puede intentar iniciar sesión o cambiar directorios.
El acceso a esta página requiere autorización. Puede intentar cambiar los directorios.
Devuelve un nuevo evento que escucha el evento original y desencadena el primer evento resultante si la aplicación del predicado a los argumentos del evento devolvió true, y desencadena el segundo evento si devolvió false.
Espacio de nombres/Ruta de acceso del módulo: Microsoft.FSharp.Control.Event
Ensamblado: FSharp.Core (en FSharp.Core.dll)
// Signature:
Event.partition : ('T -> bool) -> IEvent<'Del,'T> -> IEvent<'T> * IEvent<'T> (requires delegate)
// Usage:
Event.partition predicate sourceEvent
Parámetros
predicate
Tipo: 'T ->boolFunción para determinar qué evento de salida se va a desencadenar.
sourceEvent
Tipo: IEvent<'Del,'T>Evento de entrada.
Valor devuelto
Tupla de eventos.El primero se desencadena cuando el predicado se evalúa como true; el segundo se desencadena cuando el predicado se evalúa como false.
Comentarios
Esta función se denomina Partition 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 código siguiente se muestra cómo usar la función Event.partition para dividir un evento en dos, cada uno con su propio código de control de eventos.
open System.Windows.Forms
open System.Drawing
let form = new Form(Text = "F# Windows Form",
Visible = true,
TopMost = true)
let (event1, event2) =
form.MouseMove
|> Event.partition (fun evArgs -> evArgs.X > 100)
event1 |> Event.add ( fun evArgs ->
form.BackColor <- System.Drawing.Color.FromArgb(
evArgs.X, evArgs.Y, evArgs.X ^^^ evArgs.Y))
event2 |> Event.add ( fun evArgs ->
form.BackColor <- System.Drawing.Color.FromArgb(
evArgs.Y, evArgs.X, evArgs.Y ^^^ evArgs.X))
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