Compartir a través de


UIElement.PointerEntered Evento

Definición

Se produce cuando un puntero entra en el área de prueba de posicionamiento de este elemento.

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

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

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

Tipo de evento

Comentarios

El evento PointerEntered se desencadena en respuesta a un puntero que se mueve al área de límite del elemento. Las interacciones táctiles, del mouse y del lápiz o del lápiz se reciben, procesan y administran como entrada de puntero en la aplicación para UWP. Cualquiera de estos dispositivos y sus interacciones pueden producir un evento PointerEntered. Para obtener más información, vea Controlar la entrada del puntero y también los demás comentarios de este tema.

PointerEntered es un evento enrutado. Para obtener más información sobre el concepto de evento enrutado, consulta Información general sobre eventos y eventos enrutados.

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 las pruebas de posicionamiento. Para obtener más información, consulta Introducción a eventos y eventos enrutados.

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

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

PunteroEntrarEntrar para la entrada de lápiz y lápiz y lápiz

Un dispositivo de entrada del mouse tiene un cursor en pantalla que es visible cada vez que el mouse se mueve, incluso si no se presiona ningún botón del mouse en el momento. Un evento PointerEntered precederá al primer evento PointerMoved desencadenado por el elemento . 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. Por lo tanto, la entrada del dispositivo del mouse y el lápiz activarán los eventos PointerEntered en casos ligeramente diferentes que los eventos táctiles. Para obtener más información, consulta Interacciones de mouse.

PunteroEntrar para la entrada táctil

Un punto táctil solo se puede detectar si un dedo está tocando la superficie. Cada vez que una acción táctil da como resultado un evento PointerPressed , ese evento va precedido inmediatamente por un evento PointerEntered, con todos los datos del evento siendo 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á PointerEntered si un puntero permanece en contacto constante con la superficie a medida que se mueve y entra en 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 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 PointerEntered

PointerEntered es un evento enrutado. Para obtener más información sobre el concepto de evento enrutado, consulta Información general sobre eventos y eventos enrutados. Puedes definir varios eventos PointerEntered 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 evento PointerEntered se producirá primero para el elemento primario cuando el puntero se mueva al elemento primario y, a continuación, para el elemento secundario cuando el puntero se mueva allí. El evento PointerEntered normalmente no se propaga al elemento primario cuando el elemento secundario lo desencadena, ya que conceptualmente el puntero ya está dentro de los límites primarios y sería confuso para que el sistema de entrada enrute también la repetición del evento PointerEntered al elemento primario. Normalmente, no desea que los eventos PointerEntered enruten de todos modos, solo quiere procesarlos desde el remitente. Puede evitar explícitamente el enrutamiento de eventos estableciendo Handled entrue en el controlador.

En raras ocasiones, es posible ver una burbuja de evento PointerEntered al 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 escribe el elemento secundario y proporciona la información del evento tal y como indica cómo el elemento secundario desencadenó el evento.

Captura de puntero

Si otro elemento ha capturado el puntero, PointerEntered no se activará aunque el puntero capturado entre los límites de un elemento. Sin embargo, si se libera la captura de puntero mientras el puntero está sobre el elemento, PointerEntered se activará, incluso pensó que el puntero podría haberse mantenido estacionario en este caso. El valor de GetCurrentPoint de los datos de eventos podría ser un punto en algún lugar del centro de un elemento en lugar de un punto a lo largo de sus bordes porque el puntero ya estaba sobre el elemento cuando se liberó la captura. Para obtener más información sobre la captura de puntero, consulta CapturePointer o Interacciones del mouse.

Estados visuales pointerOver para controles

Los controles que tienen plantillas de control pueden aplicar estados visuales que están activos solo cuando un puntero está sobre 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 cada vez que un puntero esté sobre el control. Un estado visual para el 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. Para obtener más información, consulta Animaciones con guion gráfico para estados visuales.

Comportamiento de Windows 8

Para Windows 8, generalmente el evento PointerEntered no se activará si el cursor en pantalla (o lápiz o punto táctil) no se movió realmente. Por ejemplo, PointerEntered no se activa si el mouse y su cursor en pantalla permanece estacionario, y un objeto con un controlador PointerEntered tiene su posición traducida o ajustada de otro modo para moverse debajo del cursor en pantalla. O bien, PointerEntered no se activa si un elemento como un elemento emergente o un control flotante desaparece y el puntero se encuentra ahora sobre un nuevo elemento (pero el puntero aún no se ha movido). Relacionado con esto es el comportamiento PointerExited . Por ejemplo, si un elemento emergente se descarta mediante programación, no activará PointerExited si el puntero no se movió como causa de descartarlo. Todavía obtendría un evento PointerEntered si el puntero se mueve mientras se desplaza sobre el elemento recién revelado, pero eso es para el usuario si eso ocurrirá y ocurre en el momento del movimiento, no en el momento del despido. En resumen, intentar usar el último elemento que desencadenó PointerEntered para la determinación del estado de puntero en la interfaz de usuario de la aplicación no es completo en Windows 8 y hay muchos escenarios en los que PointerEntered y PointerExited no se emparejan. Esto afecta también a los estados visuales de los controles que usan PointerEntered y PointerExited como desencadenadores.

A partir de Windows 8.1, PointerExited se desencadena para cualquier caso en el que el puntero tuviera al mismo tiempo un evento PointerEntered, pero algún cambio de estado de la interfaz de usuario se produce cuando el puntero ya no está dentro de ese elemento. Esto incluye casos en los que desaparece todo el elemento. Y si el puntero se encuentra ahora sobre un elemento diferente porque un elemento anterior desapareció, ese elemento activa PointerEntered, incluso si el puntero nunca se mueve. Los elementos que establecen su visibilidad en Collapsed mediante programación es una manera de que los elementos puedan desaparecer de la interfaz de usuario y el comportamiento de Windows 8.1 tenga en cuenta esto y activará PointerExited para el elemento Collapsed y PointerEntered para el elemento recién revelado.

Si migras el código de la aplicación de Windows 8 a Windows 8.1 quizás quieras tener en cuenta este cambio de comportamiento, ya que da como resultado que PointerExited y PointerEntered se activen en casos en los que no se hayan desencadenado antes.

Las aplicaciones compiladas para Windows 8 que se ejecuten en Windows 8.1 siguen usando el comportamiento de Windows 8.

Se aplica a

Consulte también