DirectX SDK |
Lobby messages fall into two categories: DirectPlay-defined messages and application-defined messages.
DirectPlay-defined messages can be system messages, generated automatically by DirectPlay and sent to the lobby to inform it of changes in the status of the application, or standard message types, sent from the application to the lobby or from the lobby to the application.
The advantage of standard messages over application-defined messages is that the receiver can always interpret a standard message. A lobby client is not necessarily going to be able to handle custom messages from an application, just as an application may not be able to handle custom messages from a lobby client.
Lobby messages are retrieved by using the IDirectPlayLobby3::ReceiveLobbyMessage method. The message category can be identified by the value returned in the variable pointed to by the lpdwMessageFlags parameter. If neither DPLMSG_SYSTEM or DPLMSG_STANDARD is present, the message is application-defined.
Lobbies should be prepared to handle all the standard message types. If an application uses the DPLMSG_GETPROPERTY message, it must be able to handle DPLMSG_GETPROPERTYRESPONSE messages. (See Staying in Touch with the Lobby.)
DirectPlay-defined messages all start with a DWORD value that identifies the message type. After retrieving a message using ReceiveLobbyMessage, cast *lpData to the DPLMSG_GENERIC structure and examine the structure's dwType member. Then cast *lpData to the appropriate message structure for further processing.
The following table shows the possible values of DPLMSG_GENERIC.dwType for standard messages, and the structure and message cause associated with each value.
Value of dwType | Message structure | Cause |
---|---|---|
DPLSYS _APPTERMINATED |
DPLMSG_SYSTEMMESSAGE | The application has terminated. |
DPLSYS _CONNECTIONSETTINGSREAD |
DPLMSG_SYSTEMMESSAGE | The application has read the connection settings. |
DPLSYS _DPLAYCONNECTFAILED |
DPLMSG_SYSTEMMESSAGE | The application failed to connect to the DirectPlay session. |
DPLSYS _DPLAYCONNECTSUCCEEDED |
DPLMSG_SYSTEMMESSAGE | The application successfully connected to the DirectPlay session. |
DPLSYS _GETPROPERTY |
DPLMSG_GETPROPERTY | The application is requesting a property from the lobby. See Staying in Touch with the Lobby. |
DPLSYS _GETPROPERTYRESPONSE |
DPLMSG_GETPROPERTYRESPONSE | The lobby is responding to a DPLMSG_GETPROPERTY message. See Staying in Touch with the Lobby. |
DPLSYS _NEWCONNECTIONSETTINGS |
DPLMSG_SYSTEMMESSAGE | A waiting application was found when a lobby client called RunApplication. See Supporting Dynamic Lobby Connection. |
DPLSYS _NEWSESSIONHOST |
DPLMSG_NEWSESSIONHOST | The application session has a new host. |
DPLSYS _SETPROPERTY |
DPLMSG_SETPROPERTY | The application is setting a property on the lobby. See Staying in Touch with the Lobby. |
DPLSYS _SETPROPERTYRESPONSE |
DPLMSG_SETPROPERTYRESPONSE | The lobby is responding to a DPLMSG_SETPROPERTY message. See Staying in Touch with the Lobby. |
Lobby messages are retrieved by using the DirectPlayLobby3.ReceiveLobbyMessage method. The message category can be identified by the value returned in the messageFlags parameter. If neither DPLMSG_SYSTEM or DPLMSG_STANDARD is present, the message is application-defined.
Lobbies should be prepared to handle all the standard message types. If an application uses the DPLSYS_GETPROPERTY message, it must be able to handle DPLSYS_GETPROPERTYRESPONSE messages. (See Staying in Touch with the Lobby.)
DirectPlay-defined messages all start with a value from the CONST_DPSYSMSGTYPES enumeration that identifies the message type. You retrieve this value by using DirectPlayMessage.ReadLong.
The following table shows the message type and the message cause associated with each value.
Message Type | Cause |
---|---|
DPLSYS _APPTERMINATED |
The application has terminated. |
DPLSYS _CONNECTIONSETTINGSREAD |
The application has read the connection settings. |
DPLSYS _DPLAYCONNECTFAILED |
The application failed to connect to the DirectPlay session. |
DPLSYS _DPLAYCONNECTSUCCEEDED |
The application successfully connected to the DirectPlay session. |
DPLSYS _GETPROPERTY |
The application is requesting a property from the lobby. See Staying in Touch with the Lobby. |
DPLSYS _GETPROPERTYRESPONSE |
The lobby is responding to a DPLMSG_GETPROPERTY message. See Staying in Touch with the Lobby. |
DPLSYS _NEWCONNECTIONSETTINGS |
A waiting application was found when a lobby client called RunApplication. See Supporting Dynamic Lobby Connection. |
DPLSYS _NEWSESSIONHOST |
The application session has a new host. |
DPLSYS _SETPROPERTY |
The application is setting a property on the lobby. See Staying in Touch with the Lobby. |
DPLSYS _SETPROPERTYRESPONSE |
The lobby is responding to a DPLMSG_SETPROPERTY message. See Staying in Touch with the Lobby. |