home *** CD-ROM | disk | FTP | other *** search
/ Liren Large Software Subsidy 7 / 07.iso / d / d020_1_4 / 5.ddi / HELPEX / HELPEX.C < prev    next >
Encoding:
C/C++ Source or Header  |  1990-06-01  |  13.0 KB  |  436 lines

  1. /****************************************************************************
  2.  
  3.    PROGRAM:    HelpEx.c
  4.  
  5.    PURPOSE:    Illustrates calls to WinHelp and context-sensitive help.
  6.                HelpEx loads library MenuHook, which detects F1 keystrokes in
  7.                the HelpEx application menus.
  8.  
  9.    FUNCTIONS:
  10.  
  11.    WinMain() - Calls initialization function, processes message loop.
  12.    InitApplication() - Initializes window data and registers window class.
  13.    InitInstance() - Saves instance handle and creates main window.
  14.    MainWndProc() - Processes window messages.
  15.    About() - Processes messages for "About" dialog box.
  16.    MakeHelpPathName() - Derives path name of help file.
  17.  
  18. ****************************************************************************/
  19.  
  20. #include <windows.h>
  21. #include "helpex.h"
  22. #include "helpids.h"
  23.  
  24. HWND       hWnd;               /* Handle to main window */
  25. HANDLE     hInst;              /* Handle to instance data*/
  26. BOOL       bHelp = FALSE;      /* Help mode flag; TRUE = "ON"*/
  27. HCURSOR    hHelpCursor;        /* Cursor displayed when in help mode*/
  28. char       szHelpFileName[EXE_NAME_MAX_SIZE+1];    /* Help file name*/
  29. HANDLE     hAccTable;                              /* handle to accelerator table */
  30.  
  31. void MakeHelpPathName(char*);  /* Function deriving help file path */
  32.  
  33.  
  34. /****************************************************************************
  35.  
  36.    FUNCTION:   WinMain(HANDLE, HANDLE, LPSTR, int)
  37.  
  38.    PURPOSE:    Calls initialization function, processes message loop.
  39.  
  40. ****************************************************************************/
  41.  
  42. int PASCAL WinMain(hInstance, hPrevInstance, lpCmdLine, nCmdShow)
  43. HANDLE hInstance;
  44. HANDLE hPrevInstance;
  45. LPSTR  lpCmdLine;
  46. int    nCmdShow;
  47. {
  48.    MSG msg;
  49.  
  50.    if (!hPrevInstance)
  51.        if (!InitApplication(hInstance))
  52.        return (FALSE);
  53.  
  54.    if (!InitInstance(hInstance, nCmdShow))
  55.        return (FALSE);
  56.  
  57.    while (GetMessage(&msg, NULL, NULL, NULL)) {
  58.  
  59.       /* Only translate message if it is not an accelerator message */
  60.       if (!TranslateAccelerator(hWnd, hAccTable, &msg)) {
  61.  
  62.           TranslateMessage(&msg);
  63.           DispatchMessage(&msg);
  64.       }
  65.    }
  66.    return (msg.wParam);
  67. }
  68.  
  69.  
  70. /****************************************************************************
  71.  
  72.    FUNCTION:   InitApplication(HANDLE)
  73.  
  74.    PURPOSE:    Initializes window data and registers window class.
  75.  
  76.    RETURNS:    Status of RegisterClass() call.
  77.  
  78. ****************************************************************************/
  79.  
  80. BOOL InitApplication(hInstance)
  81. HANDLE hInstance;
  82. {
  83.    WNDCLASS wc;
  84.  
  85.    wc.style = NULL;
  86.    wc.lpfnWndProc = MainWndProc;
  87.    wc.cbClsExtra = 0;
  88.    wc.cbWndExtra = 0;
  89.    wc.hInstance = hInstance;
  90.    wc.hIcon = LoadIcon(NULL, IDI_APPLICATION);
  91.    wc.hCursor = LoadCursor(NULL, IDC_ARROW);
  92.    wc.hbrBackground = GetStockObject(WHITE_BRUSH); 
  93.    wc.lpszMenuName ="HelpexMenu";
  94.    wc.lpszClassName = "HelpexWClass";
  95.  
  96.    return (RegisterClass(&wc));
  97. }
  98.  
  99.  
  100. /****************************************************************************
  101.  
  102.    FUNCTION:   InitInstance(HANDLE, int)
  103.  
  104.    PURPOSE:    Saves instance handle in global variable and creates main 
  105.                window.
  106.  
  107.    RETURNS:    Status of CreateWindow() call.
  108.  
  109. ****************************************************************************/
  110.  
  111. BOOL InitInstance(hInstance, nCmdShow)
  112. HANDLE hInstance;
  113. int    nCmdShow;
  114. {
  115.  
  116.    hInst = hInstance;
  117.  
  118.    hAccTable = LoadAccelerators(hInst, "HelpexAcc");
  119.  
  120.    hWnd = CreateWindow(
  121.        "HelpexWClass",
  122.        "Help Example ",
  123.        WS_OVERLAPPEDWINDOW,
  124.        CW_USEDEFAULT,
  125.        CW_USEDEFAULT,
  126.        CW_USEDEFAULT,
  127.        CW_USEDEFAULT,
  128.        NULL,
  129.        NULL,
  130.        hInstance,
  131.        NULL
  132.        );
  133.  
  134.    if (!hWnd)
  135.        return (FALSE);
  136.  
  137.    ShowWindow(hWnd, nCmdShow);
  138.    UpdateWindow(hWnd);
  139.  
  140.    EnableMenuItem(GetSubMenu(GetMenu(hWnd), 1), IDM_CLEAR, MF_ENABLED);
  141.  
  142.    MakeHelpPathName(szHelpFileName);
  143.    hHelpCursor = LoadCursor(hInst,"HelpCursor");
  144.  
  145.    return (TRUE);
  146.  
  147. }
  148.  
  149. /****************************************************************************
  150.  
  151.    FUNCTION:   MainWndProc(HWND, unsigned, WORD, LONG)
  152.  
  153.    PURPOSE:    Processes window messages.
  154.  
  155.    MESSAGES:
  156.  
  157.        WM_COMMAND- Application menu item 
  158.        WM_DESTROY- Destroy window
  159.  
  160. ****************************************************************************/
  161.  
  162. long FAR PASCAL MainWndProc(hWnd, message, wParam, lParam)
  163. HWND       hWnd;
  164. unsigned   message;
  165. WORD       wParam;
  166. LONG       lParam;
  167. {
  168.    FARPROC lpProcAbout;
  169.    DWORD   dwHelpContextId;
  170.    RECT    rect;
  171.    POINT   pt;
  172.    DWORD   dword;
  173.    WORD    wFormat;
  174.    HCURSOR hArrow;
  175.    
  176.    switch (message) {
  177.  
  178.        case WM_COMMAND:
  179.            /* Was F1 just pressed in a menu, or are we in help mode */
  180.            /* (Shift-F1)? */
  181.  
  182.            if (bHelp) {
  183.                dwHelpContextId =
  184.                    (wParam == IDM_NEW)    ? (DWORD) HELPID_FILE_NEW     :
  185.                    (wParam == IDM_OPEN)   ? (DWORD) HELPID_FILE_OPEN    :
  186.                    (wParam == IDM_SAVE)   ? (DWORD) HELPID_FILE_SAVE    :
  187.                    (wParam == IDM_SAVEAS) ? (DWORD) HELPID_FILE_SAVE_AS :
  188.                    (wParam == IDM_PRINT)  ? (DWORD) HELPID_FILE_PRINT   :
  189.                    (wParam == IDM_EXIT)   ? (DWORD) HELPID_FILE_EXIT    :
  190.                    (wParam == IDM_UNDO)   ? (DWORD) HELPID_EDIT_UNDO    :
  191.                    (wParam == IDM_CUT)    ? (DWORD) HELPID_EDIT_CUT     :
  192.                    (wParam == IDM_CLEAR)  ? (DWORD) HELPID_EDIT_CLEAR   :
  193.                    (wParam == IDM_COPY)   ? (DWORD) HELPID_EDIT_COPY    :
  194.                    (wParam == IDM_PASTE)  ? (DWORD) HELPID_EDIT_PASTE   :
  195.                                             (DWORD) 0L;
  196.  
  197.                if (!dwHelpContextId)
  198.            {
  199.                    MessageBox( hWnd, "Help not available for Help Menu item",
  200.                    "Help Example", MB_OK                          );
  201.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  202.            }
  203.  
  204.                bHelp = FALSE;
  205.                WinHelp(hWnd,szHelpFileName,HELP_CONTEXT,dwHelpContextId);
  206.                break;
  207.            }
  208.  
  209.            switch (wParam) {
  210.                case IDM_NEW:
  211.                case IDM_OPEN:
  212.                case IDM_SAVE:
  213.                case IDM_SAVEAS:
  214.                case IDM_PRINT:
  215.                case IDM_UNDO:
  216.                case IDM_CUT:
  217.                case IDM_CLEAR:
  218.                case IDM_COPY:
  219.                case IDM_PASTE:
  220.                    MessageBox(hWnd,
  221.                    "Command not implemented",
  222.                    "Help Example",
  223.                    MB_OK);
  224.                    break;
  225.  
  226.                case IDM_EXIT:
  227.                     DestroyWindow(hWnd);
  228.                     break;
  229.  
  230.                case IDM_HELP_INDEX:
  231.                    WinHelp(hWnd,szHelpFileName,HELP_INDEX,0L);
  232.                    break;
  233.  
  234.                case IDM_HELP_KEYBOARD:
  235.            WinHelp(hWnd,szHelpFileName,HELP_KEY,(DWORD)(LPSTR)"keys");
  236.                    break;
  237.  
  238.                case IDM_HELP_HELP:
  239.            WinHelp(hWnd,"WINHELP.HLP",HELP_INDEX,0L);
  240.                    break;
  241.  
  242.                case IDM_ABOUT:
  243.                    lpProcAbout = MakeProcInstance(About, hInst);
  244.                    DialogBox(hInst, 
  245.                        "AboutBox", 
  246.                        hWnd, 
  247.                        lpProcAbout);
  248.                    FreeProcInstance(lpProcAbout);
  249.                    break;
  250.  
  251.                default:
  252.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  253.            }
  254.  
  255.            break;
  256.        
  257.        case WM_LBUTTONDOWN:
  258.        if (bHelp)
  259.        {
  260.            bHelp = FALSE;
  261.            WinHelp( hWnd, szHelpFileName, HELP_CONTEXT,
  262.             (DWORD) HELPID_EDIT_WINDOW          );
  263.            break;
  264.        }
  265.  
  266.            return (DefWindowProc(hWnd, message, wParam, lParam));
  267.  
  268.        case WM_NCLBUTTONDOWN:
  269.            /* If we are in help mode (Shift-F1) then display context- */
  270.            /* sensitive help for non-client area. */
  271.  
  272.            if (bHelp) {
  273.                dwHelpContextId =
  274.                    (wParam == HTCAPTION)     ? (DWORD) HELPID_TITLE_BAR     :
  275.                    (wParam == HTREDUCE)      ? (DWORD) HELPID_MINIMIZE_ICON :
  276.                    (wParam == HTZOOM)        ? (DWORD) HELPID_MAXIMIZE_ICON :
  277.                    (wParam == HTSYSMENU)     ? (DWORD) HELPID_SYSTEM_MENU   :
  278.                    (wParam == HTBOTTOM)      ? (DWORD) HELPID_SIZING_BORDER :
  279.                    (wParam == HTBOTTOMLEFT)  ? (DWORD) HELPID_SIZING_BORDER :
  280.                    (wParam == HTBOTTOMRIGHT) ? (DWORD) HELPID_SIZING_BORDER :
  281.                    (wParam == HTTOP)         ? (DWORD) HELPID_SIZING_BORDER :
  282.                    (wParam == HTLEFT)        ? (DWORD) HELPID_SIZING_BORDER :
  283.                    (wParam == HTRIGHT)       ? (DWORD) HELPID_SIZING_BORDER :
  284.                    (wParam == HTTOPLEFT)     ? (DWORD) HELPID_SIZING_BORDER :
  285.                    (wParam == HTTOPRIGHT)    ? (DWORD) HELPID_SIZING_BORDER :
  286.                                                (DWORD) 0L;
  287.  
  288.                if (!((BOOL)dwHelpContextId))
  289.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  290.  
  291.                bHelp = FALSE;
  292.                WinHelp(hWnd,szHelpFileName,HELP_CONTEXT,dwHelpContextId);
  293.                break;
  294.            }
  295.  
  296.            return (DefWindowProc(hWnd, message, wParam, lParam));
  297.  
  298.        case WM_KEYDOWN:
  299.            if (wParam == VK_F1) {
  300.  
  301.                /* If Shift-F1, turn help mode on and set help cursor */ 
  302.  
  303.                if (GetKeyState(VK_SHIFT)<0) {
  304.                    bHelp = TRUE;
  305.                    SetCursor(hHelpCursor);
  306.                    return (DefWindowProc(hWnd, message, wParam, lParam));
  307.                }
  308.  
  309.                /* If F1 without shift, then call up help main index topic */ 
  310.                else {
  311.                    WinHelp(hWnd,szHelpFileName,HELP_INDEX,0L);
  312.                }
  313.            }
  314.  
  315.            else if (wParam == VK_ESCAPE && bHelp) {
  316.  
  317.                /* Escape during help mode: turn help mode off */
  318.                bHelp = FALSE;
  319.                SetCursor((HCURSOR)GetClassWord(hWnd,GCW_HCURSOR));
  320.            }
  321.  
  322.            break;
  323.  
  324.        case WM_SETCURSOR:
  325.            /* In help mode it is necessary to reset the cursor in response */
  326.            /* to every WM_SETCURSOR message.Otherwise, by default, Windows */
  327.            /* will reset the cursor to that of the window class. */
  328.  
  329.            if (bHelp) {
  330.                SetCursor(hHelpCursor);
  331.                break;
  332.            }
  333.            return (DefWindowProc(hWnd, message, wParam, lParam));
  334.            break;
  335.  
  336.        case WM_INITMENU:
  337.            if (bHelp) {
  338.                SetCursor(hHelpCursor);
  339.            } 
  340.            return (TRUE);
  341.  
  342.        case WM_ENTERIDLE:
  343.            if ((wParam == MSGF_MENU) && (GetKeyState(VK_F1) & 0x8000)) {
  344.                bHelp = TRUE;
  345.                PostMessage(hWnd, WM_KEYDOWN, VK_RETURN, 0L);
  346.            }
  347.            break;
  348.  
  349.        case WM_DESTROY:
  350.            WinHelp(hWnd,szHelpFileName,HELP_QUIT,0L);
  351.            PostQuitMessage(0);
  352.            break;
  353.  
  354.        default:
  355.            return (DefWindowProc(hWnd, message, wParam, lParam));
  356.    }
  357.  
  358.    return (NULL);
  359. }
  360.  
  361.  
  362. /****************************************************************************
  363.  
  364.    FUNCTION:   About(HWND, unsigned, WORD, LONG)
  365.  
  366.    PURPOSE:    Processes messages for "About" dialog box
  367.    
  368.    MESSAGES:
  369.  
  370.        WM_INITDIALOG - Initialize dialog box
  371.        WM_COMMAND- Input received
  372.  
  373. ****************************************************************************/
  374.  
  375. BOOL FAR PASCAL About(hDlg, message, wParam, lParam)
  376. HWND       hDlg;
  377. unsigned   message;
  378. WORD       wParam;
  379. LONG       lParam;
  380. {
  381.    switch (message) {
  382.        case WM_INITDIALOG:
  383.            return (TRUE);
  384.  
  385.        case WM_COMMAND:
  386.            if (wParam == IDOK) {
  387.                EndDialog(hDlg, TRUE);
  388.                return (TRUE);
  389.            }
  390.            break;
  391.    }
  392.  
  393.    return (FALSE);
  394. }
  395.  
  396.  
  397. /****************************************************************************
  398.  
  399.    FUNCTION:   MakeHelpPathName
  400.  
  401.    PURPOSE:    HelpEx assumes that the .HLP help file is in the same
  402.                directory as the HelpEx executable.This function derives
  403.                the full path name of the help file from the path of the
  404.                executable.
  405.  
  406. ****************************************************************************/
  407.  
  408. void MakeHelpPathName(szFileName)
  409. char * szFileName;
  410. {
  411.    char *  pcFileName;
  412.    int     nFileNameLen;
  413.  
  414.    nFileNameLen = GetModuleFileName(hInst,szFileName,EXE_NAME_MAX_SIZE);
  415.    pcFileName = szFileName + nFileNameLen;
  416.  
  417.    while (pcFileName > szFileName) {
  418.        if (*pcFileName == '\\' || *pcFileName == ':') {
  419.            *(++pcFileName) = '\0';
  420.            break;
  421.        }
  422.    nFileNameLen--;
  423.    pcFileName--;
  424.    }
  425.  
  426.    if ((nFileNameLen+13) < EXE_NAME_MAX_SIZE) {
  427.        lstrcat(szFileName, "helpex.hlp");
  428.    }
  429.  
  430.    else {
  431.        lstrcat(szFileName, "?");
  432.    }
  433.  
  434.    return;
  435. }
  436.