CMainWindow

le système d’exploitation Microsoft Windows traduit les actions utilisateur suivantes en messages de fenêtre standard et les envoie à la procédure principale dans l’application StoClien :

  • L’utilisateur clique avec le bouton gauche de la souris ou le bouton de l’extrémité du stylet dans tablettes pour lancer une séquence de dessin de ligne.
  • L’utilisateur clique sur le bouton et le maintient enfoncé et déplace la souris pour dessiner une ligne.
  • La séquence se termine lorsque le bouton gauche de la souris est relâché.

L’exemple de code suivant illustre cette procédure.

CMainWindow :: WindowProc (STOCLIEN. COTISATIONS

LRESULT CMainWindow::WindowProc(
            UINT uMsg,
            WPARAM wParam,
            LPARAM lParam)
  {
    LRESULT lResult = FALSE;

    switch (uMsg)
    {
      case WM_CREATE:
        break;

      case WM_ACTIVATE:
        // A mouse click reactivates the paint procedure.
        // This is used to paint a new window when a user
        // selects a portion of the STOCLIEN window that is 
        // visible beneath another window. This message is  
        // sent in the WindowProc handle.
        if (WA_CLICKACTIVE == LOWORD(wParam))
          m_pGuiPaper->PaintWin();
        lResult = ::DefWindowProc(m_hWnd, uMsg, wParam, lParam);
        break;

      case WM_SIZE:
        // Handle a resize of this window.
        m_wWidth = LOWORD(lParam);
        m_wHeight = HIWORD(lParam);
        // Inform CGuiPaper of the change.
        m_pGuiPaper->Resize(m_wWidth, m_wHeight);
        break;

      case WM_PAINT:
        // This is a message to repaint the window.
        {
          PAINTSTRUCT ps;

          if(BeginPaint(m_hWnd, &ps))
            EndPaint(m_hWnd, &ps);

          m_pGuiPaper->PaintWin();
        }
        break;

      case WM_LBUTTONDOWN:
        // Start sequence of ink drawing to the paper.
        m_pGuiPaper->InkStart(LOWORD(lParam), HIWORD(lParam));
        break;

      case WM_MOUSEMOVE:
        // Draw inking sequence data.
        m_pGuiPaper->InkDraw(LOWORD(lParam), HIWORD(lParam));
        break;

      case WM_LBUTTONUP:
        // Stop an ink drawing sequence.
        m_pGuiPaper->InkStop(LOWORD(lParam), HIWORD(lParam));
        break;

      case WM_COMMAND:
        // Dispatch and handle any Menu command messages received.
        lResult = DoMenu(wParam, lParam);
        break;

      case WM_CHAR:
        if (wParam == 0x1b)
        {
          // Exit this application if user presses the ESC key.
          ::PostMessage(m_hWnd, WM_CLOSE, 0, 0);
        }
        break;

      case WM_CLOSE:
        // The user selected Close on the main window System menu
        // or Exit on the File menu.
        // If there is unsaved ink data, then prompt
        // the user. If the user cancels, do not close the window.
        if (IDCANCEL == m_pGuiPaper->AskSave())
          break;
      case WM_QUIT:
        // When exiting the application, close any associated help
        // windows.
        // ::WinHelp(m_hWnd, m_szHelpFile, HELP_QUIT, 0);
      default:
        // If there are any messages that have not been handled,
        // send them to the default window procedure.
        lResult = ::DefWindowProc(m_hWnd, uMsg, wParam, lParam);
        break;
    }

    return(lResult);
  }

Une séquence de dessin de ligne démarre lorsque le _ message WM LBUTTONDOWN remet les données de position de la souris.

CMainWindow a un pointeur vers l’objet CGuiPaper et appelle la méthode CGuiPaper :: InkStart pour démarrer la séquence de dessin de la ligne.

Lorsque la souris est déplacée vers Draw, une séquence de messages WM _ MOUSEMOVE distincts qui contiennent les données de position de la souris est fournie à la méthode CGuiPaper :: InkDraw .

Quand le bouton gauche de la souris est relâché, le message WM _ LBUTTONUP est reçu. La méthode CGuiPaper :: InkStop arrête la séquence de dessin de la ligne.