The present application is a continuation application of PCT/CN2008/070088, filed Jan. 11, 2008, which claims the benefit of Chinese Patent Application No. 200710086999.6, filed Mar. 29, 2007, both of which are hereby incorporated by reference in their entirety.
The present disclosure relates to a communication technology, and in particular, to a method, apparatus and system for sending and receiving notification messages.
With the rapid development of the Internet, a great number of multimedia services are widely used, for example, mobile video, television broadcasting, videoconference, online education, and interactive games.
Currently, a lot of radio communication systems support applications of multimedia services, including radio communication systems based on terrestrial broadcasting technologies such as European digital video broadcasting-handheld (DVB-H) system, South Korean terrestrial-digital multimedia broadcasting (T-DMB) system and MediaFLO system launched by Qualcomm in the U.S.A., radio communication systems based on satellite broadcasting technologies such as European satellite digital multimedia broadcasting (SDMB) system, the multimedia broadcast/multicast service (MBMS) technology, broadcast and multicast service (BCMCS) technology, and streaming media technology that are based on the 3rd Generation Partnership Project (3GPP) standards.
The radio communication system includes a server adapted to generate and send Real-Time Transport Protocol/Real-Time Transport Control Protocol (RTP/RTCP) packets and notification messages and a terminal adapted to receive the RTP/RTCP packets and notification messages sent by the server and process the RTP/RTCP packets according to the notification messages.
The notification messages are messages that operators send to a user or a terminal in a mobile broadcasting system when some events (e.g., emergency event, system failure event, program description event and software update event) occur in order to notify the terminal of these events and allow the user terminal to handle these events. One type of notification message is related to a program. For example, when a user watches a program, notification messages such as bonus questions and answers or program related captions need to be synchronous with the program to reflect the meanings of the notification messages.
The notification message in the prior art adopts the XML text format, as shown in the table below:
As seen from the above format of the notification message, there is a sub-element PresentationRule in the notification message. The PresentationRule includes a renderingTime (presentation time) property. However, the presentation time is an absolute time, and the program stream timestamp is a relative time. Thus, it is impossible to synchronize the notification message and the program stream accurately. Therefore, the notification message cannot be displayed in a program frame in the program stream resulting in a failure to present the actual contents. Supposing the notification message is the program caption, if the notification message cannot be displayed in the corresponding program frame, the notification message may fail to explain voices in the frame.
Embodiments of the present disclosure provide a method, apparatus, and system for sending and receiving notification messages to synchronize notification messages with program streams accurately.
A method for sending notification messages provided in an embodiment of the present disclosure includes obtaining the notification message and a synchronization timestamp that are synchronous with a program, encapsulating the notification message into an RTP/RTCP packet corresponding to the synchronization timestamp, and sending the RTP/RTCP packet to a terminal.
A method for receiving notification messages provided in an embodiment of the present disclosure includes receiving an RTP/RTCP packet that includes the notification message and decapsulating the RTP/RTCP packet to obtain the notification message.
A notification messages sending apparatus provided in an embodiment of the present disclosure includes an obtaining module adapted to obtain the notification message and a synchronization timestamp that are synchronous with a program, an RTP/RTCP packet encapsulating module adapted to encapsulate the notification message into an RTP/RTCP packet corresponding to the synchronization timestamp obtained by the obtaining module, and a sending module adapted to send the RTP/RTCP packet that is obtained by the RTP/RTCP packet encapsulating module.
A notification messages receiving apparatus provided in an embodiment of the present disclosure includes a receiving module adapted to receive an RTP/RTCP packet sent by a notification messages sending apparatus and an RTP/RTCP packet decapsulating module adapted to decapsulate the RTP/RTCP packet received by the receiving module to obtain the notification message and process the notification message according to the format of the notification message.
A system for transmitting notification messages provided in an embodiment of the present disclosure includes a message source entity adapted to generate a notification message and a synchronization timestamp that are synchronous with a program and send the notification message and the synchronization timestamp to a notification messages sending apparatus, and a notification messages sending apparatus adapted to obtain the notification message and the synchronization timestamp synchronous with the program that are generated by the message source entity, encapsulate the notification message into an RTP/RTCP packet corresponding to the synchronization timestamp, and send the RTP/RTCP packet to a notification messages receiving apparatus.
According to the embodiments of the present disclosure, the notification message is synchronized with the program stream accurately by carrying the notification message in the RTP/RTCP packet.
For better understanding and implementation of the present disclosure, the present disclosure is hereinafter described in detail with reference to the accompanying drawing and exemplary embodiments.
As shown in
Step 1: A notification message and a synchronization timestamp that are synchronous with a program are obtained.
Step 2: The notification message is encapsulated into an RTP/RTCP packet corresponding to the synchronization timestamp.
Step 3: The RTP/RTCP packet is sent to a user terminal.
Step 4: The user terminal decapsulates the RTP/RTCP packet to obtain the notification message.
According to an embodiment of the present disclosure, before the notification message is encapsulated into an RTP/RTCP packet corresponding to the synchronization timestamp in step 2 and step 4, it is necessary to extend the format of the RTP/RTCP packet. The method for extending the format of the RTP/RTCP packet, the method for encapsulating the notification message into the RTP/RTCP packet, and the method for decapsulating the RTP/RTCP packet to obtain the notification message are described in the first embodiment to the fourth embodiment of the disclosure.
The first embodiment describes the method for extending the RTP packet header, the method for encapsulating a notification message into the RTP packet header, and the method for decapsulating the RTP packet header to obtain the notification message.
To transmit a notification message, it is necessary to set a notification message indication bit and determine a field for carrying the notification message in the RTP packet header. In the first embodiment, an extended field of the RTP packet header is extended. The extended field includes “defined by profile”, “length”, and “header extension”. The “defined by profile” field is defined as a notification message indication field.
If the notification message indication field is valid (e.g., the notification message indication field is set to 0×C051), there is a notification message in the RTP packet header. Otherwise, there is no notification message in the RTP packet header. A header extension field is defined as a field for carrying a notification message. The figure below shows the format of the RTP packet header:
Wherein:
Multiple notification messages may be set in the header extension, where each notification message carries the following parameters:
After the notification message indication field and the field for carrying the notification message are determined, the message source generates a notification message payload that is synchronous with a program according to the program contents and determines such parameter information as a synchronization timestamp, a notification message ID, and a notification message subtype. Then the message source encapsulates the notification message payload, the notification message ID, and the notification message subtype into the RTP packet header corresponding to the synchronization timestamp. The message source sends the RTP packet header and program to the terminal.
At the receiving side (e.g., the terminal) of the RTP packet, the terminal listens to the IP address and port number where the RTP packet is sent in order to obtain the RTP packet, as shown in
Step 201: The RTP packet is obtained according to the PT, that is, the terminal parses the RTP packet header and judges whether there is a header extension.
Step 202: It is judged whether there is a header extension. If there is, step 203 is performed. Otherwise step 208 is performed.
In other words, the X field in the RTP packet header (see the description of the RTP packet header in this embodiment) is used to judge whether there is a header extension. If the X field is 1, there is a header extension. If the X field is 0, there is no header extension.
Step 203: It is judged whether there is a notification message according to the “defined by profile” field of the header extension. If so, step 204 is performed. Otherwise step 208 is performed.
In other words, if the notification message indication field indicates that there is a notification message (e.g., the notification message indication field is set to 0×C051), there is a notification message in the RTP packet header. Otherwise, there is no notification message in the RTP packet header.
Step 204: The notification message is obtained from the header extension of the RTP packet.
Step 205: The terminal pre-processes each notification message according to the defined format of the message and judges whether to process the notification message according to the pre-processing result. If so, it goes to step 207. Otherwise it goes to step 206. The pre-processing includes determining whether the notification message has been received according to the ID of the notification message, judging whether to receive the notification message according to the subtype of the notification message, determining whether to process the notification message immediately according to the priority of the notification message, judging whether to update the existing messages according to the version of the message, judging whether the message has expired according to the Valid to date, and judging whether the user is concerned about the notification message and whether to process the notification message according to the provider ID of the notification message.
Step 206: This notification message is discarded and step 208 is performed.
Step 207: The terminal decompresses the payload of the length indicated by the Length field according to the compression type of the notification message. The terminal synchronizes the notification message with the program according to the synchronization timestamp and processes the decompressed payload contents.
Step 208: The program data in the RTP packet is processed.
According to this embodiment, the notification message and the program stream are synchronized accurately by setting the notification message in the header extension of the RTP packet that is synchronous with the synchronization timestamp. Because the notification message and the program stream adopt the same RTP packet, the terminal needs to only listen to the address and port number where the program is located.
This embodiment describes the method for extending an RTCP sender report (RTP SR) packet, the method for encapsulating a notification message into the RTP SR packet, and the method for decapsulating the RTP SR packet to obtain the notification message.
The figure below shows the structure of the RTCP SR packet:
In the Header part:
The RTP/RTCP protocol specifies that this field is defined by the profile.
The profile-specific extensions field is extended to transfer the notification message. It includes the following parameters:
The type parameter indicates whether a notification message is carried in the profile-specific extensions field. That is, if the type parameter is valid (e.g., the type parameter is set to 0×0001), there is a notification message in the profile-specific extensions field. Otherwise, there is no notification message in the profile-specific extensions field. The contents of other fields are parameters and contents of the notification message. The table below shows the specific contents of the profile-specific extensions field:
After the extension format of the profile-specific extensions field is determined, when a notification message is generated, the notification message may be encapsulated into the RTCP SR packet according to the following method:
The message source generates a notification message payload that is synchronous with the program according to the program contents and determines such parameter information as the synchronization timestamp, the notification message ID, and the notification message subtype.
Then the message source encapsulates the notification message payload, the notification message ID, and the notification message subtype into the profile-specific extensions field of the RTCP SR packet corresponding to the synchronization timestamp.
At the receiving side (e.g., the terminal) of the RTP SR packet, the terminal accesses the RTCP SR packet to obtain the notification message as shown in
Step 301: The terminal receives an RTCP session and filters the RTCP packet according to the rule of PT=200 to obtain the RTCP SR packet.
Step 302: The information that is synchronous with the RTP carrying the program stream is obtained according to the NTP timestamp and the RTP timestamp.
Step 303: The received information of the program source SSRC_n is obtained.
Step 304: The terminal judges whether there is a profile-specific extensions field in the RTCP SR packet according to the determination of whether the length exceeds a preset value. If there is, step 305 is performed. Otherwise step 308 is performed.
Step 305: The terminal judges whether the profile-specific extensions field carries a notification message according to the type parameter in the profile-specific extensions field. If so, step 306 is performed. Otherwise step 308 is performed.
Step 306: The terminal pre-processes the notification message according to the format of the profile-specific extensions field and judges whether to process the notification message according to the pre-processing result. If so, step 307 is performed. Otherwise step 309 is performed. The pre-processing includes determining whether the notification message has been received according to the ID of the notification message, judging whether to receive the notification message according to the subtype of the notification message, determining whether to process the notification message immediately according to the priority of the notification message, judging whether to update the existing messages according to the version of the message, judging whether the message has expired according to the Valid to date, and judging whether the user is concerned about the notification message and whether to process the notification message according to the provider ID of the notification message.
Step 307: If the notification message needs to be processed, the terminal decompresses the payload of the length indicated by the Length field according to the compression type of the notification message. The terminal synchronizes the notification message with the program according to the synchronization timestamp and processes the decompressed payload contents.
Step 308: This process ends.
Step 309: The notification message is discarded.
In this embodiment, when a notification message is generated, the notification message (see the notification message in Table 3) is set in the profile-specific extensions field. After receiving the notification message, the terminal processes the notification message according to each parameter. If judgment shows that the notification message must be processed, the information “Voting begins” may be displayed on the user terminal at the time when the program is played.
This embodiment can synchronize the notification message with the program stream accurately by carrying the notification message in the RTCP SR packet. Because the RTCP SR packet and the program stream adopt the same IP address, the terminal does not need to listen to additional IP addresses despite different port numbers used.
This embodiment describes the method for extending another RTCP packet, namely, an application-defined RTCP packet, the method for encapsulating a notification message into the application-defined RTCP packet, and the method for decapsulating the application-defined RTCP packet to obtain the notification message.
(1) Extending The Application-Defined RTCP Packet
The figure below shows the format of the application-defined RTCP packet:
In the preceding format:
The PT parameter: indicates whether an RTCP packet is an application-defined RTCP packet according to the value of PT (e.g., PT=204).
The Name ASCII parameter indicates whether a notification message is transmitted in the application-dependent data according to the value of name ASCII (e.g., Noti).
The Application-dependent data parameter is adapted to transmit the notification message.
To transmit a general notification message, it is necessary to extend the application-dependent data field. The format of the extended application-dependent data field includes the following parameters:
(2) Encapsulating the Notification Message into the Application-Defined RTCP Packet
After the extension format of the application-dependent data field is determined, when a notification message is generated, the message source generates a notification message payload that is synchronous with the program according to the program contents and determines such parameter information as the synchronization timestamp, the notification message ID, and the notification message subtype. Then the message source encapsulates the notification message payload, the notification message ID, and the notification message subtype into the RTCP packet corresponding to the synchronization timestamp.
(3) Decapsulating the Application-Defined RTCP Packet to Obtain the Notification Message
At the receiving side (e.g., the terminal) of the RTCP packet, the terminal obtains the notification message according to the obtained application-defined RTCP packet, as shown in
Step 401: The terminal receives an RTCP session and obtains the application-defined RTCP packet according to the value of PT (e.g., PT=204).
Step 402: The notification message is obtained according to the value of name ASCII (e.g., Noti).
Step 403: The notification message is pre-processed and whether to process the notification message is judged according to the pre-processing result. If so, step 404 is performed. Otherwise, step 405 is performed. The pre-processing includes determining whether the notification message has been received according to the ID of the notification message, judging whether to receive the notification message according to the subtype of the notification message, determining whether to process the notification message immediately according to the priority of the notification message, judging whether to update the existing messages according to the version of the message, judging whether the message has expired according to the Valid to date, and judging whether the user is concerned about the notification message and whether to process the notification message according to the provider ID of the notification message.
Step 404: The terminal decompresses the payload of the length indicated by the Length field according to the compression type of the notification message. The terminal synchronizes the notification message with the program according to the synchronization timestamp and processes the decompressed payload contents.
Step 405: The notification message is discarded.
This embodiment can synchronize the notification message with the program stream accurately by carrying the notification message in an application-dependent RTCP packet. Because the RTCP packet and the program stream adopt the same IP address, the terminal does not need to listen to additional IP addresses despite different port numbers used.
This embodiment describes the method for extending another RTP packet, the method for encapsulating a notification message into the RTP packet, and the method for decapsulating the RTP packet to obtain the notification message.
(1) Extending the RTP Packet
The figure below shows the format of the RTP packet:
In the preceding RTP format:
The PT parameter indicates that a notification message is carried in the RTP payload according to the value of PT (for example, PT=255).
The RTP payload parameter is adapted to carry a notification message. The RTP payload may include multiple notification messages, where each notification message carries the following parameters:
(2) Encapsulating The Notification Message Into The RTP Packet
After the format of the RTP packet is determined, that is, the formats of the PT and the RTP payload are determined, the message source generates a notification message payload that is synchronous with the program according to the program contents, determines such parameter information as the synchronization timestamp, the notification message ID, and the notification message subtype, and encapsulates the notification message payload, the notification message ID, and the notification message subtype into the RTP packet corresponding to the synchronization timestamp.
(3) Decapsulating the RTP Packet to Obtain the Notification Message
At the receiving side (e.g., the terminal) of the RTP packet, the terminal obtains the notification message according to the obtained RTP packet, as shown in
Step 501: The terminal receives an RTP session and obtains an RTP packet that transfers the notification message according to the value of PT.
Step 502: The terminal pre-processes the notification message and judges whether to process the notification message according to the pre-processing result. If so, it goes to step 503. Otherwise, it goes to step 504. The pre-processing includes determining whether the notification message has been received according to the ID of the notification message, judging whether to receive the notification message according to the subtype of the notification message, determining whether to process the notification message immediately according to the priority of the notification message, judging whether to update the existing messages according to the version of the message, judging whether the message has expired according to the Valid to date, and judging whether the user is concerned about the notification message and whether to process the notification message according to the provider ID of the notification message.
Step 503: The terminal decompresses the payload of the length indicated by the Length field according to the compression type of the notification message. The terminal synchronizes the notification message with the program according to the synchronization timestamp and processes the decompressed RTP payload contents.
Step 504: The notification message is discarded.
According to this embodiment, the notification message may be synchronized with the program stream accurately by carrying the notification message in an RTP packet.
The system includes a program source entity adapted to generate a program, a message source entity corresponding to the program source entity adapted to generate a notification message and a synchronization timestamp that is synchronous with the program, a notification messages sending apparatus adapted to obtain the notification message and the synchronization timestamp synchronous with the program, encapsulate the notification message into an RTP/RTCP packet corresponding to the synchronization timestamp, and send the RTP/RTCP packet to a notification messages receiving apparatus, and the notification messages receiving apparatus adapted to receive the RTP/RTCP packet sent by the notification messages sending apparatus, obtain a notification message from the RTP/RTCP packet, and process the notification message.
The notification messages sending apparatus includes an obtaining module adapted to obtain a notification message and a synchronization timestamp that are synchronous with the program, an RTP/RTCP packet encapsulating module adapted to encapsulate the notification message into an RTP/RTCP packet corresponding to the synchronization timestamp obtained by the obtaining module, and a sending module, adapted to send the RTP/RTCP packet obtained by the RTP/RTCP packet encapsulating module to the notification messages receiving apparatus.
The notification messages receiving apparatus includes a receiving module adapted to receive the RTP/RTCP packet from the notification messages sending apparatus and an RTP/RTCP packet decapsulating module adapted to decapsulate the RTP/RTCP packet received by the receiving module to obtain the notification message and process the notification message according to the format of the notification message. The RTP/RTCP packet decapsulating module includes an obtaining sub-module adapted to decapsulate the RTP/RTCP packet received by the receiving module to obtain the notification message, a pre-processing sub-module adapted to pre-process the notification message obtained by the obtaining sub-module and start a processing sub-module or a discarding sub-module according to the pre-processing result, where the processing sub-module is adapted to process the notification message and the discarding sub-module is adapted to discard the notification message.
According to the embodiments of the present disclosure, the notification message is synchronized with the program stream accurately by carrying the notification message in the RTP/RTCP packet.
Although the disclosure has been described through some exemplary embodiments, the disclosure is not limited to such embodiments. It is apparent that those skilled in the art can make various modifications and variations to the disclosure without departing from the spirit and scope of the disclosure. The disclosure is intended to cover the modifications and variations provided that they fall in the scope of protection defined by the following claims or their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
200710086999.6 | Mar 2007 | CN | national |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2008/070088 | Jan 2008 | US |
Child | 12346013 | US |