Avatar billede chris18 Nybegynder
24. januar 2000 - 19:17 Der er 3 kommentarer og
1 løsning

MessageBox i Visual C++ 6.0

Hej,

Hvordan får jeg en MessageBox til at "poppe" op oven på alle andre åbne program vinduer? Dvs. at hvis jeg f.eks. er på Internettet med IE, og mit program kører i baggrunden, så skal messageboxen komme frem oven på IE vinduet. Er der nogen der ved hvordan dette kan gøres!!
Avatar billede faceorbit Nybegynder
24. januar 2000 - 22:44 #1
Hvilken hændelse skal udløse denne messageBox, og hvornår ? Eller er det bare koden til en messagebox du er interesseret i ?
Avatar billede soepro Nybegynder
25. januar 2000 - 09:32 #2
Det er meget enkelt: du skal blot sætte MB_WINDOWONTOP flaget i kaldet til MessageBox Windows API'en:

MessageBox(frmMain->Handle, "Der er sket en alvorlig fejl", "Fejl i underprogram", MB_ICONERROR | MB_TOPMOST | MB_RETRYCANCEL);

Du kan finde flere varianter af typen i Windows SDK help-filen under MessageBox.
Avatar billede soepro Nybegynder
25. januar 2000 - 09:35 #3
Nemlig disse:

The MessageBox function creates, displays, and operates a message box. The message box contains an application-defined message and title, plus any combination of predefined icons and push buttons.

int MessageBox(

    HWND hWnd,    // handle of owner window
    LPCTSTR lpText,    // address of text in message box
    LPCTSTR lpCaption,    // address of title of message box 
    UINT uType     // style of message box
  );   


Parameters

hWnd

Identifies the owner window of the message box to be created. If this parameter is NULL, the message box has no owner window.

lpText

Points to a null-terminated string containing the message to be displayed.

lpCaption

Points to a null-terminated string used for the dialog box title. If this parameter is NULL, the default title Error is used.

uType

Specifies a set of bit flags that determine the contents and behavior of the dialog box. This parameter can be a combination of flags from the following groups of flags.
Specify one of the following flags to indicate the buttons contained in the message box:

Flag    Meaning
MB_ABORTRETRYIGNORE    The message box contains three push buttons: Abort, Retry, and Ignore.
MB_OK    The message box contains one push button: OK. This is the default.
MB_OKCANCEL    The message box contains two push buttons: OK and Cancel.
MB_RETRYCANCEL    The message box contains two push buttons: Retry and Cancel.
MB_YESNO    The message box contains two push buttons: Yes and No.
MB_YESNOCANCEL    The message box contains three push buttons: Yes, No, and Cancel.


Specify one of the following flags to display an icon in the message box:

Flag    Meaning
MB_ICONEXCLAMATION,
MB_ICONWARNING
    An exclamation-point icon appears in the message box.
MB_ICONINFORMATION, MB_ICONASTERISK
    An icon consisting of a lowercase letter i in a circle appears in the message box.
MB_ICONQUESTION    A question-mark icon appears in the message box.
MB_ICONSTOP,
MB_ICONERROR,
MB_ICONHAND
    A stop-sign icon appears in the message box.


Specify one of the following flags to indicate the default button:

Flag    Meaning
MB_DEFBUTTON1    The first button is the default button. MB_DEFBUTTON1 is the default unless MB_DEFBUTTON2, MB_DEFBUTTON3, or MB_DEFBUTTON4 is specified.
MB_DEFBUTTON2    The second button is the default button.
MB_DEFBUTTON3    The third button is the default button.
MB_DEFBUTTON4    The fourth button is the default button.


Specify one of the following flags to indicate the modality of the dialog box:

Flag    Meaning
MB_APPLMODAL    The user must respond to the message box before continuing work in the window identified by the hWnd parameter. However, the user can move to the windows of other applications and work in those windows. Depending on the hierarchy of windows in the application, the user may be able to move to other windows within the application. All child windows of the parent of the message box are automatically disabled, but popup windows are not.MB_APPLMODAL is the default if neither MB_SYSTEMMODAL nor MB_TASKMODAL is specified.
MB_SYSTEMMODAL    Same as MB_APPLMODAL except that the message box has the WS_EX_TOPMOST style. Use system-modal message boxes to notify the user of serious, potentially damaging errors that require immediate attention (for example, running out of memory). This flag has no effect on the user's ability to interact with windows other than those associated with hWnd.
MB_TASKMODAL    Same as MB_APPLMODAL except that all the top-level windows belonging to the current task are disabled if the hWnd parameter is NULL. Use this flag when the calling application or library does not have a window handle available but still needs to prevent input to other windows in the current application without suspending other applications.


In addition, you can specify the following flags:

MB_DEFAULT_DESKTOP_ONLY

The desktop currently receiving input must be a default desktop; otherwise, the function fails. A default desktop is one an application runs on after the user has logged on.

MB_HELP

Adds a Help button to the message box. Choosing the Help button or pressing F1 generates a Help event.

MB_RIGHT

The text is right-justified.

MB_RTLREADING

Displays message and caption text using right-to-left reading order on Hebrew and Arabic systems.

MB_SETFOREGROUND

The message box becomes the foreground window. Internally, Windows calls the SetForegroundWindow function for the message box.

MB_TOPMOST

The message box is created with the WS_EX_TOPMOST window style.

MB_SERVICE_NOTIFICATION

Return Values

The return value is zero if there is not enough memory to create the message box.
If the function succeeds, the return value is one of the following menu-item values returned by the dialog box:

Value    Meaning
IDABORT    Abort button was selected.
IDCANCEL    Cancel button was selected.
IDIGNORE    Ignore button was selected.
IDNO    No button was selected.
IDOK    OK button was selected.
IDRETRY    Retry button was selected.
IDYES    Yes button was selected.


If a message box has a Cancel button, the function returns the IDCANCEL value if either the ESC key is pressed or the Cancel button is selected. If the message box has no Cancel button, pressing ESC has no effect.

Remarks

When you use a system-modal message box to indicate that the system is low on memory, the strings pointed to by the lpText and lpCaption parameters should not be taken from a resource file, because an attempt to load the resource may fail.
When an application calls MessageBox and specifies the MB_ICONHAND and MB_SYSTEMMODAL flags for the uType parameter, Windows displays the resulting message box regardless of available memory. When these flags are specified, Windows limits the length of the message box text to three lines. Windows does not automatically break the lines to fit in the message box, however, so the message string must contain carriage returns to break the lines at the appropriate places.

If you create a message box while a dialog box is present, use the handle of the dialog box as the hWnd parameter. The hWnd parameter should not identify a child window, such as a control in a dialog box.
Windows 95: The system can support a maximum of 16,364 window handles.

Håber det rækker.
Avatar billede chris18 Nybegynder
25. januar 2000 - 21:20 #4
Tak for hjælpen det virker perfekt, det var lige det jeg behøvede.
Avatar billede Ny bruger Nybegynder

Din løsning...

Tilladte BB-code-tags: [b]fed[/b] [i]kursiv[/i] [u]understreget[/u] Web- og emailadresser omdannes automatisk til links. Der sættes "nofollow" på alle links.

Loading billede Opret Preview
Kategori
Kurser inden for grundlæggende programmering

Log ind eller opret profil

Hov!

For at kunne deltage på Computerworld Eksperten skal du være logget ind.

Det er heldigvis nemt at oprette en bruger: Det tager to minutter og du kan vælge at bruge enten e-mail, Facebook eller Google som login.

Du kan også logge ind via nedenstående tjenester