WM_POINTERUPDATE messaggio
Inviato per fornire un aggiornamento su un puntatore che ha effettuato il contatto sull'area client di una finestra o su un puntatore non incapsulato al passaggio del mouse sull'area client di una finestra. Mentre il puntatore passa il mouse, il messaggio è destinato a qualsiasi finestra su cui si trova il puntatore. Mentre il puntatore è in contatto con la superficie, il puntatore viene acquisito in modo implicito nella finestra su cui il puntatore ha effettuato il contatto e tale finestra continua a ricevere l'input per il puntatore fino a quando non interrompe il contatto.
! [Importante]
Le app desktop devono essere compatibili con dpi. Se l'app non riconosce valori DPI, le coordinate dello schermo contenute nei messaggi del puntatore e nelle strutture correlate potrebbero risultare imprecise a causa della virtualizzazione DPI. La virtualizzazione DPI offre supporto automatico per il ridimensionamento alle applicazioni che non sono compatibili con dpi ed è attivo per impostazione predefinita (gli utenti possono disattivarlo). Per altre informazioni, vedere Scrittura di applicazioni Win32 con valori DPI elevati.
#define WM_POINTERUPDATE 0x0245
Parametri
-
wParam
-
Contiene informazioni sul puntatore. Utilizzare le macro seguenti per recuperare informazioni dal parametro wParam.
IS_POINTER_NEW_WPARAM(wParam): flag che indica se questo messaggio rappresenta il primo input generato da un nuovo puntatore.
IS_POINTER_INRANGE_WPARAM(wParam): flag che indica se il messaggio è stato generato da un puntatore durante la sua durata. Questo flag non è impostato sui messaggi che indicano che il puntatore ha lasciato l'intervallo di rilevamento
IS_POINTER_INCONTACT_WPARAM(wParam): flag che indica se il messaggio è stato generato da un puntatore in contatto con la superficie della finestra. Questo flag non è impostato sui messaggi che indicano un puntatore al passaggio del mouse.
IS_POINTER_PRIMARY_WPARAM(wParam): indica che questo puntatore è stato designato come primario.
IS_POINTER_FIRSTBUTTON_WPARAM(wParam): flag che indica se è presente un'azione primaria.
- Questo è analogo a un pulsante sinistro del mouse verso il basso.
- Un puntatore tocco avrà questo set quando è in contatto con la superficie del digitalizzatore.
- Un puntatore penna avrà questo set quando è in contatto con la superficie del digitalizzatore senza pulsanti premuti.
IS_POINTER_edizione Standard CONDBUTTON_WPARAM(wParam): flag che indica se è presente un'azione secondaria.
- Questo è analogo a un pulsante destro del mouse verso il basso.
- Un puntatore penna avrà questo set quando è in contatto con la superficie del digitalizzatore con il pulsante della canna della penna premuto.
IS_POINTER_THIRDBUTTON_WPARAM(wParam): flag che indica se sono presenti una o più azioni terziarie basate sul tipo di puntatore; le applicazioni che desiderano rispondere alle azioni terziarie devono recuperare informazioni specifiche del tipo di puntatore per determinare quali pulsanti terziari vengono premuti. Ad esempio, un'applicazione può determinare gli stati dei pulsanti di una penna chiamando GetPointerPenInfo ed esaminando i flag che specificano gli stati del pulsante.
IS_POINTER_FOURTHBUTTON_WPARAM(wParam): flag che indica se il puntatore specificato ha intrapreso la quarta azione. Le applicazioni che desiderano rispondere alle quarto azioni devono recuperare informazioni specifiche del tipo di puntatore per determinare se viene premuto il primo pulsante esteso del mouse (XButton1).
IS_POINTER_FIFTHBUTTON_WPARAM(wParam): flag che indica se il puntatore specificato ha intrapreso la quinta azione. Le applicazioni che desiderano rispondere alla quinta azione devono recuperare informazioni specifiche del tipo di puntatore per determinare se viene premuto il secondo pulsante del mouse esteso (XButton2).
Per altri dettagli, vedere Flag puntatore .
Nota
Un puntatore al passaggio del mouse non ha nessuno dei flag pulsante impostati. Questo è analogo a uno spostamento del mouse senza pulsanti del mouse verso il basso. Un'applicazione può determinare gli stati dei pulsanti di una penna al passaggio del mouse, ad esempio chiamando GetPointerPenInfo ed esaminando i flag che specificano gli stati del pulsante.
-
lParam
-
Contiene la posizione del punto del puntatore.
Nota
Poiché il puntatore può contattare il dispositivo su un'area non semplice, questa posizione può essere una semplificazione di un'area puntatore più complessa. Quando possibile, un'applicazione deve usare le informazioni complete sull'area del puntatore anziché la posizione del punto.
Utilizzare le macro seguenti per recuperare le coordinate fisiche dello schermo del punto.
Valore restituito
Se un'applicazione elabora questo messaggio, deve restituire zero.
Se l'applicazione non elabora questo messaggio, deve chiamare DefWindowProc.
Osservazioni:
Ogni puntatore ha un identificatore di puntatore univoco durante la sua durata. La durata di un puntatore inizia quando viene rilevata per la prima volta.
Se viene rilevato un puntatore al passaggio del mouse, viene generato un messaggio di WM_POINTERENTER. Viene generato un messaggio WM_POINTERDOWN seguito da un messaggio WM_POINTERENTER se viene rilevato un puntatore non al passaggio del mouse.
Durante la sua durata, un puntatore può generare una serie di messaggi WM_POINTERUPDATE mentre è al passaggio del mouse o in contatto.
La durata di un puntatore termina quando non viene più rilevata. Verrà generato un messaggio di WM_POINTERLEAVE .
Quando un puntatore viene interrotto, viene impostato POINTER_FLAG_CANCELED .
Un messaggio WM_POINTERLEAVE può essere generato anche quando un puntatore non acquisito si sposta all'esterno dei limiti di una finestra.
Per ottenere la posizione orizzontale e verticale di un puntatore, usare quanto segue:
xPos = GET_X_LPARAM(lParam);
yPos = GET_Y_LPARAM(lParam);
La macro MAKEPOINTS può essere utilizzata anche per convertire il parametro lParam in una struttura POINTS.
La funzione GetKeyState può essere utilizzata per determinare gli stati dei tasti di modifica della tastiera associati a questo messaggio. Ad esempio, per rilevare che il tasto ALT è stato premuto, controllare se GetKeyState (VK_MENU) < 0.
Se l'applicazione non elabora questo messaggio, DefWindowProc può generare uno o più messaggi WM_GESTURE se la sequenza di input da questo e, possibilmente, altri puntatori vengono riconosciuti come movimento. Se un movimento non viene riconosciuto, DefWindowProc può generare l'input del mouse.
Se un'applicazione utilizza in modo selettivo un input puntatore e passa il resto a DefWindowProc, il comportamento risultante non è definito.
Utilizzare la funzione GetPointerInfo per recuperare ulteriori informazioni correlate a questo messaggio.
Se l'applicazione non elabora questi messaggi con la stessa velocità con cui vengono generati, alcuni spostamenti potrebbero essere uniti. La cronologia degli input uniti in questo messaggio può essere recuperata usando la funzione GetPointerInfoHistory.
Esempi
Nell'esempio di codice seguente viene illustrato come usare GET_X_LPARAM, GET_Y_LPARAM, IS_POINTER_FIRSTBUTTON_WPARAM e IS_POINTER_edizione Standard CONDBUTTON_WPARAM per recuperare informazioni rilevanti dai parametri wParam e lParam del messaggio di WM_POINTERUPDATE.
int xPos = GET_X_LPARAM(lParam);
int yPos = GET_Y_LPARAM(lParam);
if (IS_POINTER_PRIMARYBUTTON_WPARAM(wParam))
{
// process pointer move while down, similar to mouse move with left button down
}
else if (IS_POINTER_SECONDARYBUTTON_WPARAM(wParam))
{
// process pointer move while down, similar to mouse move with right button down
}
Nell'esempio di codice seguente viene illustrato come usare GET_POINTERID_WPARAM per recuperare l'ID del puntatore dal parametro wParam del messaggio WM_POINTERUPDATE .
POINTER_INFO pointerInfo;
UINT32 pointerId = GET_POINTERID_WPARAM(wParam);
// Retrieve common pointer information
if (!GetPointerInfo(pointerId, &pointerInfo))
{
// failure, call GetLastError()
}
else
{
// success, process pointerInfo
}
Nell'esempio di codice seguente viene illustrato come gestire tipi di puntatore diversi.
POINTER_TOUCH_INFO touchInfo;
POINTER_PEN_INFO penInfo;
POINTER_INFO pointerInfo;
UINT32 pointerId = GET_POINTERID_WPARAM(wParam);
POINTER_INPUT_TYPE pointerType = PT_POINTER;
// default to unhandled to enable call to DefWindowProc
fHandled = FALSE;
if (!GetPointerType(pointerId, &pointerType))
{
// failure, call GetLastError()
// set PT_POINTER to fall to default case below
pointerType = PT_POINTER;
}
switch (pointerType)
{
case PT_TOUCH:
// Retrieve touch information
if (!GetPointerTouchInfo(pointerId, &touchInfo))
{
// failure, call GetLastError()
}
else
{
// success, process touchInfo
// mark as handled to skip call to DefWindowProc
fHandled = TRUE;
}
break;
case PT_PEN:
// Retrieve pen information
if (!GetPointerPenInfo(pointerId, &penInfo))
{
// failure, call GetLastError()
}
else
{
// success, process penInfo
// mark as handled to skip call to DefWindowProc
fHandled = TRUE;
}
break;
default:
if (!GetPointerInfo(pointerId, &pointerInfo))
{
// failure.
}
else
{
// success, proceed with pointerInfo.
fHandled = HandleGenericPointerInfo(&pointerInfo);
}
break;
}
Requisiti
Requisito | Valore |
---|---|
Client minimo supportato |
Windows 8 [solo app desktop] |
Server minimo supportato |
Windows Server 2012 [solo app desktop] |
Intestazione |
|
Vedi anche
-
Riferimento