Einzeilige Edit-Steuerelemente verwenden

In diesem Abschnitt veranschaulicht, wie eine Fensterprozedur verwenden, um ein Dialogfeld zu erstellen, die den Benutzer zur Eingabe eines Kennworts aufgefordert werden.

Einzeilige Edit-Steuerelement im Dialogfeld das Kennwort hat den ES_PASSWORD Stil. In der Standardeinstellung edit-Steuerelemente mit dieser Stil-Anzeige für jedes Zeichen ein Sternchen der Benutzer eingibt. In diesem Beispiel, verwendet jedoch die EM_SETPASSWORDCHAR -Nachricht das Standardzeichen aus einem Stern, ein Pluszeichen (+) ändern.

Diese Fensterprozedur ändert die Standardschaltfläche Push von Abbrechen, OK, sobald der Benutzer Text in das Edit-Steuerelement eingibt. Wenn der Benutzer die OK-Taste drückt, verwendet die Fensterprozedur der EM_LINELENGTH und EM_GETLINE um den Text abzurufen.

LRESULT CALLBACK PassProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) 
{ 
    CHAR lpszPassword[16]; 
    WORD cchPassword; 
 
    switch (message) 
    { 
        case WM_INITDIALOG: 
 
            // Set password character to a plus sign (+) 
 
            SendDlgItemMessage(hDlg, 
                IDE_PASSWORDEDIT, 
                EM_SETPASSWORDCHAR, 
                (WPARAM) '+', 
                (LPARAM) 0); 
 
            // Set the default push button to "Cancel." 
 
            SendMessage(hDlg, 
                DM_SETDEFID, 
                (WPARAM) IDCANCEL, 
                (LPARAM) 0); 
 
            return TRUE; 
 
        case WM_COMMAND: 
 
            // Set the default push button to "OK" when the user 
            // enters text. 
 
            if(HIWORD (wParam) == EN_CHANGE && 
                    LOWORD(wParam) == IDE_PASSWORDEDIT) 
            {
                SendMessage(hDlg, 
                    DM_SETDEFID, 
                    (WPARAM) IDOK, 
                    (LPARAM) 0); 
            }
 
            switch(wParam) 
            { 
                case IDOK: 
 
                    // Get number of characters. 
 
                    cchPassword = (WORD) SendDlgItemMessage(hDlg, 
                        IDE_PASSWORDEDIT, 
                        EM_LINELENGTH, 
                        (WPARAM) 0, 
                        (LPARAM) 0); 
 
                    if (cchPassword >= 16) 
                    { 
                        MessageBox(hDlg, 
                            "Too many characters.", 
                            "Error", 
                            MB_OK); 
                        EndDialog(hDlg, TRUE); 
                        return FALSE; 
                    } 
                    else if (cchPassword == 0) 
                    { 
                        MessageBox(hDlg, 
                            "No characters entered.", 
                            "Error", 
                            MB_OK); 
                        EndDialog(hDlg, TRUE); 
                        return FALSE; 
                    } 
 
                    // Put the number of characters into first word 
                    // of buffer. 
 
                    *((LPWORD)lpszPassword) = cchPassword; 
 
                    // Get the characters. 
 
                    SendDlgItemMessage(hDlg, 
                        IDE_PASSWORDEDIT, 
                        EM_GETLINE, 
                        (WPARAM) 0,       // line 0 
                        (LPARAM) lpszPassword); 
 
                    // Null-terminate the string. 
 
                    lpszPassword[cchPassword] = 0; 
 
                    MessageBox(hDlg, 
                        lpszPassword, 
                        "Did it work?", 
                        MB_OK); 
 
                    // Call a local password-parsing function. 
 
                    ParsePassword(lpszPassword); 
 
                    EndDialog(hDlg, TRUE); 
                    return TRUE; 
 
                case IDCANCEL: 
                    EndDialog(hDlg, TRUE); 
                    return TRUE; 
            } 
            return 0; 
    } 
    return FALSE; 
        UNREFERENCED_PARAMETER(lParam); 
} 
 

Index