This invention relates to providing media content to a user at a user terminal.
Voice over internet protocol (“VoIP”) communication systems allow the user of a device, such as a personal computer, to make calls across a computer network such as the Internet. These systems are beneficial to the user as they are often of significantly lower cost than fixed line or mobile networks. This may particularly be the case for long distance calls. To use VoIP, the user must install and execute client software on their device. The client software provides the VoIP connections as well as other functions such as registration and authentication. In addition to voice communication, the client may also provide video calling and instant messaging (“IM”).
If the user requires help or technical assistance with using the client software the user can access a help facility. This help facility is accessed by the user selecting a help tab or window in the user interface of the client software.
Skype™ is one example of client software that implements a help facility. In Skype, responsive to the user selecting a help tab or window in the user interface the user will be directed to webpage where answers to ‘Frequently Asked Questions’ or ‘FAQs’ are displayed to the user. These ‘FAQs’ are directed to all the users of the client software and are not specific to an individual user. As a result the ‘FAQs’ often contains help information that may not be relevant to the user.
The word processing application Microsoft Word provides a help facility to its users. Once the help facility is accessed the user may search for help documents using a keyword search. The user must then select a help document displayed amongst a plurality of help documents in the keyword search results. The user is then able to read the help document in order to resolve the user's problem. This can often be a time consuming process as the user may have to enter variations or combinations of keywords in the keyword search before a relevant help document appears in the help search results. Furthermore the help documents themselves are available to all the users of Microsoft Word and are often written by Microsoft in a way such that all users will understand the information. As a result an experienced user of Microsoft Word that requires help or technical assistance on a certain issue may have to read through large quantities of information that he does not require before arriving at the relevant section that he will find useful.
In addition to the help facilities provided by the client software, the software providers often advertise new features of the client software by delivering content to its users. The client software MSN messenger delivers content to its users. This content can take the form of text, images, videos and animations and often appear in pop up windows (for example the ‘MSN Today’ window that is displayed responsive to the user logging into the MSN messenger client) or in areas of the client software user interface. As the content is delivered to all the users of the client software, users who have installed the new feature will also receive this content. As a result these users of the client software can become frustrated with content being displayed at their user terminal that relates to features of the client software that they already use.
Advertising content can also be delivered to web pages. DoubleClick® delivers advertising content to a user browsing web pages in dependence on information about the user. Such information is stored with cookies on their device and can include the gender or age of the user. It is apparent that the advertising content is delivered to a large quantity of users i.e. male users or users aged between 18-25. As a result users browsing web pages can become frustrated with advertising content being displayed at their user device that is not relevant to them.
There is therefore a need for a technique to address the aforementioned problems with providing media content to a user of a communication client application.
In a first aspect of the present invention there is provided a method of providing selectable media content from a server to a user at a user terminal, the method comprising: storing variables relating to the user's familiarity with a communication client application executable at the user terminal; executing program code to read said variables to determine the media content to be provided to the user based on said variables; retrieving said determined media content from the server; and providing said media content to the user at the user terminal.
In one embodiment, the variables are stored at the user terminal. In another embodiment the variables are stored at the server.
Preferably, the user's familiarity with the communication client application is assessed based on the user's usage of the communication client application.
Preferably, the program code is stored at the server.
Preferably, the communication client application retrieves the program code from the server.
Preferably, at least one or both of the retrieval and execution of the program code is performed responsive to an interaction comprising (i) the user logging into the communication client application, or (ii) the user selecting a window provided in the communication client application.
In one case, the program code is retrieved at log-in and executed responsive to the user selecting a window provided in the communication client application.
Preferably, responsive to the user interacting with the communication client application the communication client application compares program code stored at the user terminal with program code stored at the server, and wherein the program code stored at the user terminal is executed by the communication client application if the program code stored at the user terminal is the same as the program code stored at the server, and wherein the program code stored at the server is retrieved and executed by the communication client application if the program code stored at the server is an updated version of the program code stored at the user terminal.
In one embodiment the communication client application provides the variables to the server, and the program code is executed at the server.
Preferably, the media content is a video, for example a tutorial video; or an audio recording; or text and images.
Preferably the communication client application is one of a voice over internet protocol communication client; a peer-to-peer communication client; an instant messaging communication client.
In a second aspect of the present invention there is provided a user terminal for receiving selectable media content from a server, the user terminal comprising: means for executing a communication client application; means for accessing variables relating to a user's familiarity with the communication client application; means for executing program code to read said variables to determine the media content to be provided to the user based on said variables; means for retrieving said determined media content from the server; and means for providing said media content to the user at the user terminal.
Preferably the means for accessing the variables accesses them from storage means at the server.
In a third aspect of the present invention there is provided a server for providing media content to a user terminal, the server comprising: storage means for storing media content; means for accessing variables relating to a user's familiarity with a communication client application executable at the user terminal; selection means for selecting media content from
storage means, said selection based on said variables; and means for providing said media content to the user terminal in response to receiving a request from the user terminal.
In a fourth aspect of the present invention there is provided a computer program product for providing selectable media content from a server to a user at a user terminal, the computer program product comprising code embodied on a non-transient computer-readable medium and configured so as when executed on a processing apparatus to: store variables relating to the user's familiarity with a communication client application executable at the user terminal; and trigger the execution of further program code to read said variables to determine the media content to be provided to the user based on said variables, thereby enabling the determined media content from the server to be retrieved and provided to the user at the user terminal.
In a fifth aspect of the present invention there is provided a communication system comprising a user terminal and a server connected to a communication network, wherein the user terminal receives selectable media content from a server over the communication network, the system comprising: means at the user terminal for executing a communication client application; means for accessing variables relating to a user's familiarity with the communication client application; means for executing program code to read said variables to determine the media content to be provided to the user based on said variables; and means at the server for providing said media content to the user terminal in response to receiving a request from the user terminal.
For a better understanding of the present invention and to show how the same may be put into effect, reference will now be made, by way of example, to the following drawings in which:
a shows a detailed view of a user terminal on which is executed a client;
a and 5b show example routines that a program executes
The description below describes an embodiment where media content is provided from a server that is dependent on a user's familiarity with a communication client application. The media content is provided in a user interface of the communication client application and can contain text, images, and streaming video. Media content is only retrieved from the server and provided to the user if it is relevant to that user's familiarity with the communication client application. In this embodiment the media content to be provided to the user is determined by reading variables that are monitored and stored by the communication client application. These variables are related to the user's usage of the communication client application and are described in more detail below
Reference is first made to
Those skilled in the art will appreciate that the Internet 106 can be connected to other types of networks (not shown in
As shown in
The user terminal 104 is now described in more detail with reference to
The communication client application 110 is a software program executed on a local processor 122 in the user terminal 104. The communication client application 110 may download a content retrieval program 112 from the content server 108 over the network 106, the content retrieval program 112 being received at the user terminal 104 at a network interface 120. The communication client application 110 is connected to a monitoring block 126 that monitor's User A's usage of the communication client application 110. As an alternative or in addition to the memory 114, a memory 124 can be provided to store variables relating to User A's usage of the communication client application 110.
It will be appreciated that memory 124 may comprise a single memory unit or a plurality of memory units. Memory 124 may include but is not limited to RAM, ROM, SRAM, EPROM, EEPROM.
The client user interface 200 displays the username 202 of User A 102 in the P2P system, and User A can set his own presence state (that will be seen by other users) using a drop down list by selecting icon 204. The client user interface 200 comprises a tab 206 labelled “people”, and when this tab is selected the contacts 208 stored by the user in a contact list are displayed.
The client user interface 200 further comprises a window 214. The window 214 utilizes browser software on the user terminal 104 to provide media content in the window 214. When User A 102 logs into the client 110 the user will be able to access a help channel 216 (depicted as ‘Skype Home’ in
The help channel launches a help channel page which consists of a “title area” 218, a “video or images area” 220, and a “action area” 222.
The title area 218 can contain the text indicating the title of the content 224 and an activation button 226. Upon selection of the activation button 226 the help channel page is closed.
The video or images area 220 can contain text, images, streaming video and an action button 228 to commence the video stream.
The action area 222 can contain multiple instances of text, images, drop-down list to allow user to filter information, entry text box to facilitate further activity, and an action button 230. The action button 230 allows the user to do one or more of: open a web page in the user's browser, initiate an activity in the client, open another window to be displayed in web window 214, switch to another video that is determined to be relevant to the user, act upon drop down list selection, and act upon text box entry. The activities in the client that may be initiated by action button 230 may include but are not limited to initiating a call, initiating an IM, and opening a window in web window 214 to import contacts stored on the user terminal to the communication client application 110.
Once User A has registered with the communication client application 110, variables relating to the User A's usage of the communication client application 110 are monitored and stored in memory 124 at the communication client application 110 and/or in memory 114 at the server 108.
These variables may include (i) the number of days since the user registered; (ii) the number of contacts that the user has; (iii) whether the user has made any calls to a PSTN or mobile device; (iv) whether the user has set up Voice Mail; (v) whether the user has set up Call Forwarding; (vi) whether the user has sent an SMS; and (vii) whether the user has made any VOIP calls. Activities (iii) to (vii) can be determined by monitoring the users interaction with the user interface with the communication client application 110, and storing data accordingly. Variables such as (i) and (ii) can be monitored and updated on an ongoing basis. Other variables can also be monitored as discussed later.
With reference to the flow chart in
The process starts at step S1 when User A 102 logs in to the communication client application. At step S2 the communication client application 110 determines whether a content retrieval program 112 is stored at the user terminal 104. If no such program is stored at the user terminal the process proceeds to step S3 where the communication client application 110 retrieves a content retrieval program 112 from the server 108. The retrieved content retrieval program 112 is then stored at step S4 in memory 124.
Referring back to step S2, if a content retrieval program 112 is already stored at the user terminal 104, the process proceeds to step S8 where the communication client application 110 determines if the content retrieval program 112 stored at the user terminal 104 is the same as the content retrieval program 112 stored in the store 120 at the server 108. If the content retrieval program 112 stored at the user terminal 104 is the same as the content retrieval program 112 stored in the store 120 at the server 108 then there is no new version of the content retrieval program 112 at the server 108 and the process proceeds to step S5.
If the content retrieval program 112 stored at the user terminal 104 is not the same as the content retrieval program 112 stored in the store 120 at the server 108 then there is a new version of the content retrieval program 112 at the server 108 and the process proceeds to step S9. At step S9 the communication client application 110 retrieves the latest version of the content retrieval program 112 from the server 108 and the process proceeds to step S4 where the retrieved content retrieval program 112 is stored.
The content retrieval program 112 may be retrieved responsive to the user interacting with the communication client application 110. This interaction may include the user logging into the communication client application 110 or selecting a window provided in the communication client application 110.
In one mode of operation, the content retrieval program 112 is retrieved from the server 108 and executed at the user terminal 104 responsive to the user interacting with the communication client application 110. This user interaction may include the user logging into the communication client application 110. It will be appreciated that in this mode of operation the step S5 shown in
In this mode of operation, following determining at step S8 that there is no new version of the content retrieval program 112 at the server 108, or storing the retrieved content retrieval program 112 at the user terminal 104 at step S4, the process proceeds to step S6.
At step S6 the content retrieval program 112 that is stored at the user terminal is executed. When the content retrieval program 112 is executed the variables relating to User A's usage of the communication client application 110 are read by the content retrieval program 112 to determine the relevant media content that is to be retrieved from the content store 118 at the server 108. At step S7 the client retrieves the relevant media from the content server 108.
In a further mode of operation, the content retrieval program 112 is retrieved from the server 108 and executed at the user terminal 104 responsive to the user interacting with the communication client application 110. This interaction may include the user selecting a window provided in the communication client application 110.
It will be appreciated that in this further mode of operation, the step S5 shown in
In another mode of operation, the latest version of the content retrieval program 112 is stored at the user terminal 104 responsive to the user logging in to the communication client application 110. It will be appreciated that the latest version of the content retrieval program 112 may be stored at the user terminal through steps S1, S2, S3 and S4; steps S1, S2 and S8; or steps S1, S2, S8, S9 and S4.
Once the latest version of the content retrieval program 112 is stored at the user terminal 104 the process proceeds to step S5 (as shown in
At step S5 it is determined whether the user has interacted with the communication client application 110, this interaction may include the user selecting a window provided in the communication client application 110. If no interaction is detected the process continually loops until an interaction is detected. When an interaction is detected the process proceeds to step S6 where the content retrieval program 112 that is stored at the user terminal is executed.
When the content retrieval program 112 is executed the variables relating to User A's usage of the communication client application 110 are read by the content retrieval program 112 to determine the relevant media content that is to be retrieved from the content store 118 at the server 108. At step S7 the client retrieves the relevant media from the content server 108.
It will be appreciated that the content retrieval program 112 may comprise computer program code of any length or size. The content retrieval program 112 may comprise a whole computer program or a portion of computer program code that may be used to update a program already stored at the user terminal 104. It will also be appreciated that the content retrieval program 112 may be written in any programming language including JavaScript, Java, C, C++ and Basic.
With reference to
The process begins at step S1 where the content retrieval program 112 determines how many days since User A 102 registered with the communication client application 110. The number of days since User A registered with the communication client application 110 is one of a plurality of variables relating to User A's usage of the communication client application 110 that is stored in memory 124 of the user terminal 104 (or memory 114).
At S1 the program determines whether the number of days since User A 102 registered with the communication client application 110 has exceeded a threshold number of days. In
If it has been less than 30 days since User A 102 registered with the communication client application 110, then the process continues to step S2.
At step S2 the content retrieval program 112 determines whether User A 102 has any contacts 208. The number of contacts User A 102 has is one of a plurality of variables relating to User A's usage of the communication client application 110 that is stored in memory 124 of the user terminal 104. If User A 102 does not have any contacts the content retrieval program 112 proceeds to execute “Routine 1”.
Routine 1 is now described in detail with reference to
Routine 1 is executed by the content retrieval program 112 to determine media content relevant to the User A 102. In particular routine 1 is executed to determine media content relevant to users that have registered with the communication client application 110 less than 30 days ago and have zero contacts i.e. they are a relatively new user to the communication client application 110. When the program executes routine 1 the content retrieval program 112 will determine a ‘feature set” that should be retrieved from the server 108. As shown in
Referring back to
If User A 102 does have less than 5 contacts the process proceeds to step S4 where the content retrieval program 112 determines whether User A is a paid user. A paid user is a user who has previously paid the client software provider for a service provided by the client software provider. If user A is not a paid user the content retrieval program 112 proceeds to execute “Routine 2”. It will be understood that Routine 2 will include features sets that are relevant to User A 102.
If at step S4 it is determined that User A 102 is a paid user then the content retrieval program 112 proceeds to execute “Routine 3”. It will be understood that Routine 3 will include features sets that are relevant to User A 102.
Referring back to step S3, if User A 102 has more than 5 contacts the process proceeds to step S5. At step S5 the content retrieval program 112 determines whether User A 102 is a paid user. If at step S5 it is determined that user A is not a paid user then the content retrieval program 112 proceeds to execute “Routine 4”. It will be understood that Routine 4 will include features sets that are relevant to User A 102.
If at step S5 it is determined that User A 102 is a paid user then the content retrieval program 112 proceeds to execute “Routine 5”. It will be understood that Routine 5 will include features sets that are relevant to User A 102.
Referring back to step S1, if it is determined that it has been more than 30 days since User A 102 registered with the communication client application 110, then the process continues to step S6.
At step S6 the content retrieval program 112 determines whether User A 102 has any contacts 208. If User A 102 does not have any contacts the content retrieval program 112 proceeds to execute “Routine 1”. In this case User A has been registered with the communication client application 110 for some time but has not added any contacts, therefore suitable media content is retrieved for User A by executing Routine 11.e. videos titled ‘find friends’ and ‘how to make a call’.
If at step S6 it is determined that that User A does have some contacts then the process proceeds to step S7 where the content retrieval program 112 determines whether User A has less than 5 contacts. It will be appreciated that the threshold of 5 contacts is merely an example and is not limiting in any way.
If User A does have less than 5 contacts the process proceeds to step S8 where the content retrieval program 112 determines whether User A is a paid user. If user A is not a paid user the content retrieval program 112 proceeds to execute “Routine 6”. It will be understood that Routine 6 will include features sets that are relevant to User A 102.
If at step S8 it is determined that User A 102 is a paid user then the content retrieval program 112 proceeds to execute “Routine 7”. It will be understood that Routine 7 will include features sets that are relevant to User A 102.
Referring back to step S7, if User A 102 has more than 5 contacts the process proceeds to step S9. At step S9 the content retrieval program 112 determines whether User A 102 is a paid user. If at step S9 it is determined that User A 102 is not a paid user then the content retrieval program 112 proceeds to execute “Routine 8”. It will be understood that Routine 8 will include features sets that are relevant to User A 102.
If at step S9 it is determined that User A 102 is a paid user then the content retrieval program 112 proceeds to execute “Routine 9”. It will be understood that Routine 9 will include features sets that are relevant to user A.
Routine 9 will now be described in detail with reference to
Routine 9 is executed by the content retrieval program 112 to determine media content relevant to the User A. In particular routine 9 is executed to determine media content relevant to users that have registered with the communication client application 110 more than 30 days ago, have more than 5 contacts and are a paid user i.e. User A is relatively experienced user of the communication client application 110. When the content retrieval program 112 executes routine 9 the content retrieval program 112 reads the variables stored in memory 124 to determine a ‘Feature Set” that should be retrieved from the content server 108.
The possible media content in the feature sets that may be retrieved from server content 108 when Routine 9 is executed will be relevant to User A and will be dependent on variables such as variables (iii) to (vii) mentioned earlier and other variables such as whether the user has made any video calls. It will be understood that the variables that will be read by the content retrieval program 112 when the content retrieval program 112 executes Routine 9 will relate to features of the communication client application 110 that will be relevant to users with a higher usage of the communication client application 110 than relatively new users to the communication client application 110.
As shown in
In the embodiment where the variables are held at the server in memory 114, the program can be executed at the server 108. In this embodiment the variables relating to User A's usage of the communication client application 110 can be made available to the server 108 in a number of different ways. For example the variable relating to the number of contacts that user A has may be retrieved from a contact list server (not shown in
In a further example, the communication client application 110 may provide the variables relating to User A's usage of the communication client application 110 to the content server 108. In this case the content retrieval program 112 may be executed on the server to read these variables to determine the relevant media that is to be sent from the content store 118 at the content server 108 to the communication client application 110 at the user terminal 104.
In a case where only some of the variables are made available to the server, the server will execute only a part of the content retrieval program 112. In that case the user terminal could execute the remaining part by accessing variables stored locally in memory 124.
Referring back to
The media content retrieved from the content server 108 will include an image 232 which is displayed in the video or images area 220, and the title 224 of the media content which is displayed in the title area 218.
Upon activation of a play button 228 in the video or images area 220 by User A, the content server 108 will start to stream the relevant media content to the User A at the user terminal 104. It will be appreciated to those skilled in the art that the term ‘stream’ refers to how media content is delivered to an end-user via a telecommunication network.
It will be appreciated that the media content that is retrieved from the content server 108 may contain more than one video or image that is relevant to User A. Once User A 102 has viewed a video or image, the next time the user logs into the communication client application 110 and accesses the help channel 216 User A will be presented with an image 232 in the ‘video or images area’ 220 of the next image or video that be displayed. Again upon activation of the play button 228 in the video or images area 220 by User A 102, the server 108 will start to stream the next video or image to the User A 102 at the user terminal 104
When User A 102 closes media content using activation button 226, activation button 226 is replaced with a ‘view all videos button’ (not shown in
If another user of the P2P communication system (not shown in
While this invention has been particularly shown and described with reference to preferred embodiments, it will be understood to those skilled in the art that various changes in form and detail may be made without departing from the scope of the invention as defined by the appendant claims.
Number | Date | Country | Kind |
---|---|---|---|
1014611.6 | Sep 2010 | GB | national |