Compartir a través de


UIElement.PointerExited Evento

Definición

Se produce cuando un puntero sale del área de prueba de posicionamiento de este elemento.

public:
 virtual event PointerEventHandler ^ PointerExited;
// Register
event_token PointerExited(PointerEventHandler const& handler) const;

// Revoke with event_token
void PointerExited(event_token const* cookie) const;

// Revoke with event_revoker
UIElement::PointerExited_revoker PointerExited(auto_revoke_t, PointerEventHandler const& handler) const;
public event PointerEventHandler PointerExited;
function onPointerExited(eventArgs) { /* Your code */ }
uIElement.addEventListener("pointerexited", onPointerExited);
uIElement.removeEventListener("pointerexited", onPointerExited);
- or -
uIElement.onpointerexited = onPointerExited;
Public Custom Event PointerExited As PointerEventHandler 
<uiElement PointerExited="eventhandler"/>

Tipo de evento

Comentarios

El PointerExited evento se desencadena en respuesta a un puntero que se encontraba inicialmente en el área delimitador del elemento dejando ese área delimitador. Las interacciones táctiles, del mouse y del lápiz/lápiz se reciben, procesan y administran como entrada de puntero en la aplicación. Cualquiera de estos dispositivos y sus interacciones pueden producir un PointerExited evento. Para obtener más información, consulta Controlar la entrada del puntero y los demás comentarios de este tema.

Use un controlador basado en PointerEventHandler para controlar este evento.

En el caso de las acciones táctiles y también de los eventos de manipulación o específicos de la interacción que son consecuencia de una acción táctil, un elemento debe ser visible en la prueba de acceso para poder ser origen de eventos y generar el evento que está asociado a la acción. UIElement.Visibility debe ser Visible. Otras propiedades de los tipos derivados también afectan a la visibilidad de la prueba de posicionamiento. Para obtener más información, consulta Introducción a eventos y eventos enrutados.

PointerExited admite la capacidad de adjuntar controladores de eventos a la ruta que se invocará incluso si los datos del evento se marcan como Controlado. Consulte AddHandler.

Los controles de Windows Runtime específicos pueden tener control basado en clases para el PointerExited evento de entrada. Si es así, es probable que el control tenga una invalidación para el método OnPointerExited. Normalmente, el evento no está marcado como controlado por el controlador de clase, por lo que el código de usuario todavía puede controlar el PointerExited evento para el control en la interfaz de usuario. Para obtener más información sobre cómo funciona el control basado en clases para eventos, consulta Información general sobre eventos y eventos enrutados.

Si otro elemento ha capturado el puntero, PointerExited no se activará aunque el puntero capturado deje los límites de un elemento. Para obtener más información sobre la captura de punteros, consulta Interacciones de CapturePointer o Mouse.

PointerExited para la entrada del mouse y el lápiz/lápiz

Un dispositivo de entrada del mouse tiene un cursor en pantalla que es visible cada vez que se mueve el mouse, incluso si no se presiona ningún botón del mouse en el momento. Hay un comportamiento similar disponible para la entrada del dispositivo de lápiz, donde los dispositivos de entrada pueden detectar que el lápiz óptico mantiene el puntero sobre la superficie del dispositivo de entrada (IsInRange), pero no lo toca. La entrada del dispositivo de mouse y lápiz desencadenará PointerExited eventos en casos ligeramente diferentes de los que hacen los eventos táctiles. Para obtener más información, consulta Interacciones de mouse. Un PointerExited evento se desencadena después del último evento PointerMoved para el elemento.

PointerExited para la entrada táctil

Un punto táctil solo es detectable si un dedo está tocando la superficie. Cada vez que una acción táctil da como resultado un evento PointerReleased , ese evento va seguido inmediatamente de un PointerExited evento, y todos los datos del evento son la misma información para los dos eventos (el mismo identificador de puntero, la misma posición, etc.). En otras palabras, el puntero se considera que entra en el elemento en el momento y la posición en que el elemento se toca mediante un punto táctil.

Como alternativa, un punto táctil generará PointerExited si ese puntero permanece en contacto constante con la superficie a medida que se mueve, estaba sobre el elemento inicialmente y, a continuación, sale de los límites de prueba de posicionamiento de un elemento. Para estos tipos de acciones táctiles, también es posible que la acción se pueda procesar como una manipulación, o como un gesto, en lugar de un evento de puntero. Para obtener más información, consulta Controlar la entrada del puntero.

Comportamiento del evento enrutado para PointerExited

PointerExited es un evento enrutado. Para obtener más información sobre el concepto de eventos enrutados, consulta Información general sobre eventos y eventos enrutados. Puedes definir varios PointerExited eventos para los elementos de una interfaz de usuario XAML, incluidos los elementos que se encuentran en una relación de elementos primarios y secundarios. En una composición típica de la interfaz de usuario, los elementos secundarios están en algún lugar dentro de los límites de un elemento primario, por lo que el PointerExited evento se producirá primero para el elemento secundario cuando el puntero salga del elemento secundario y, a continuación, para el elemento primario cuando el puntero se mueva completamente fuera de ese elemento primario. Normalmente PointerExited , el evento no se propaga al elemento primario cuando el elemento secundario lo desencadena, ya que sería confuso para que el sistema de entrada enrute también la repetición del PointerExited evento al elemento primario. Normalmente no quiere PointerExited que los eventos se enruten de todos modos, solo quiere procesarlos desde el remitente. Puede evitar explícitamente el enrutamiento de eventos estableciendo Handledtrue en en el controlador.

En raras ocasiones, es posible ver una PointerExited burbuja de evento para el elemento primario. Por ejemplo, si ha usado un RenderTransform para desplazar un elemento secundario fuera de los límites de su elemento primario, el evento se propaga al elemento primario cuando se sale del elemento secundario y proporciona la información del evento tal y como indica cómo el elemento secundario desencadenó el evento.

PunteroIntroducción de estados visuales para controles

Los controles que tienen plantillas de control pueden aplicar estados visuales que están activos solo cuando un puntero está por encima de los límites del control. No siempre es necesario controlar PointerEntered o PointerExited para obtener o cambiar este comportamiento. Es posible que tenga que volver a crear una plantilla del control. Si deriva de un control existente que ya tiene el control de entrada de bajo nivel que invoca estados visuales, debe proporcionar un estado visual denominado "PointerOver" en el visualStateGroup "CommonStates" y la lógica de control integrada cargará ese estado visual siempre que un puntero esté sobre el control. Un estado visual para puntero a través suele estar presente en los controles que se pueden invocar o seleccionar, como un Button o ListViewItem. Si deriva de una clase base como Control que no tiene control de eventos de entrada integrado que invoca estados visuales, es posible que tenga que invalidar OnPointerEntered y OnPointerExited para obtener este comportamiento. Use OnPointerExited para llamar a GoToState para cargar un estado distinto del estado "PointerOver", por ejemplo"Normal".

Se aplica a

Consulte también