This application is related by subject matter to the following concurrently-filed patent applications filed on Apr. 30, 2010, each of which is hereby incorporated by reference in its entirety: International Patent Application Serial No. PCT/US2009/PPPP1, entitled “Systems, Methods, and Computer Programs for Providing a Conference User Interface” (Applicant: American Teleconferencing Services, Ltd.; Attorney Docket No. 16003.1206P1); International Patent Application Serial No. PCT/US2009/PPPP2, entitled “Conferencing Application Store” (Applicant: American Teleconferencing Services, Ltd.; Attorney Docket No. 16003.1207P1); International Patent Application Serial No. PCT/US2009/PPPP3, entitled “Sharing Social Networking Content in a Conference User Interface” (Applicant: American Teleconferencing Services, Ltd.; Attorney Docket No. 16003.1208P1); International Patent Application Serial No. PCT/US2009/PPPP4, entitled “Distributing Information Between Participants in a Conference via a Conference User Interface” (Applicant: American Teleconferencing Services, Ltd.; Attorney Docket No. 16003.1211P1); International Patent Application Serial No. PCT/US2009/PPPP5, entitled “Record and Playback in a Conference” (Applicant: American Teleconferencing Services, Ltd.; Attorney Docket No. 16003.1218P1); U.S. patent application Ser. No. ______ entitled “Conferencing Alerts” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1202U1); U.S. patent application Ser. No. ______ entitled “Participant Profiling in a Conferencing System” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1203U1); U.S. patent application Ser. No. ______ entitled “Location-Aware Conferencing” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1204U1); U.S. patent application Ser. No. ______ entitled “Real-Time Speech-to-Text Conversion in an Audio Conference Session” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1205U1); U.S. patent application Ser. No. ______ entitled “Managing Participants in a Conference via a Conference User Interface” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1209U1); U.S. patent application Ser. No. ______ entitled “Managing Conference Sessions via a Conference User Interface” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1210U1); U.S. patent application Ser. No. ______ entitled “Participant Authentication via a Conference User Interface” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1212U1); U.S. patent application Ser. No. ______ entitled “Location-Aware Conferencing with Participant Rewards” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1213U1); U.S. patent application Ser. No. 12/111,111 entitled “Location-Aware Conferencing with Graphical Representations That Enable Licensing And Advertising” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1214U1); U.S. patent application Ser. No. ______ entitled “Location-Aware Conferencing with Graphical Interface For Communicating Information” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1215U1); U.S. patent application Ser. No. ______ entitled “Location-Aware Conferencing with Graphical Interface for Participant Survey” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1217U1); U.S. patent application Ser. No. ______ entitled “Transferring a Conference Session Between Client Devices” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1219U1); and U.S. patent application Ser. No. ______ entitled “Location-Aware Conferencing with Calendar Functions” (First Named Inventor: Boland T. Jones; Attorney Docket No. 16003.1220U1).
Currently, there are a number of conference solutions for enabling people to conduct live meetings, conferences, presentations, or other types of gatherings via the Internet, the public switched telephone network (PSTN), or other voice and/or data networks. Participants typically use a telephone, computer, or other communication device that connects to a conference system. The meetings include an audio component and a visual component, such as, a shared presentation, video, whiteboard, or other multimedia, text, graphics, etc. These types of convenient conference solutions have become an indispensable form of communication for many businesses and individuals.
Despite the many advantages and commercial success of existing conference, meeting, grouping or other types of gathering systems, there remains a need in the art for improved conference, meeting, grouping or other types of gathering systems, methods, and computer programs.
A method for providing a virtual conference is described. The method includes a conferencing system that configures a virtual conference location; the conferencing system playing a personalized sound effect corresponding to generating a graphical representation of a conference participant; and the conferencing system displaying the graphical representation of the conference participant in the virtual conference location.
A method for providing a virtual conference is also described in which the method includes: a conferencing system receiving an entertainment option request. The method further includes the conferencing system displaying a graphical user interface that lists one or more entertainment options and the conferencing system receiving one or more selections from the graphical user interface. The method further includes displaying visuals corresponding to one or more of the selections.
A conferencing system for providing a virtual conference is described. The system includes a display device and a processor. The processor is operable to: display visual objects on the display device corresponding to an interactive entertainment feature during the virtual conference; and receive signals associated with one or more second conference participant identifiers of the virtual conference and corresponding to the visual objects of the interactive entertainment feature.
a is a more detailed view of one of the participant objects in the conference interface of
b illustrates the participant object of
a illustrates an embodiment of a participant object for an unidentified participant.
b illustrates an embodiment of a user interface screen for implementing a participant profile user interface control.
Various embodiments of systems, methods, and computer programs are disclosed for providing a visually engaging conference experience to participants of a conference via a conference user interface presented to a client device. The conference interface may be used for conferences, meetings, groupings or other types gatherings (collectively, a “conference” with a system that provides the conference interface for a conference being referred to herein as a “conferencing system”) for any variety of purposes of one or more people, groups or organizations (including combinations thereof and collectively referred to as “participants”) with or without an audio component, including, without limitation, enabling simulcast audio with such conference for the participants. As mentioned above and described below in detail with reference to one or more of the embodiments illustrated in the drawings, the conference interface may be configured to provide any desirable content and/or functionality and may support various user interface and conferencing features. In some embodiments, the conference interface comprises a computer-simulated virtual conference location that is presented to one or more of the participants of an audio conference via a graphical user interface.
The client devices 102 may comprise any desirable computing device, which is configured to communicate with the conferencing system 106 and the server 108 via the networks 110. The client device 102 may comprise, for example, a personal computer, a desktop computer, a laptop computer, a mobile computing device, a portable computing device, a smart phone, a cellular telephone, a landline telephone, a soft phone, a web-enabled electronic book reader, a tablet computer, or any other computing device capable of communicating with the conferencing system 106 and/or the server 108 via one or more networks 110. The client device 102 may include client software (e.g., a browser, plug-in, or other functionality) configured to facilitate communication with the conferencing system 106 and the server 108. It should be appreciated that the hardware, software, and any other performance specifications of the client device 102 are not critical and may be configured according to the particular context in which the client device 102 is to be used.
The conferencing system 106 generally comprises a communication system for establishing an audio conference 114 between the client devices 102. The conferencing system 106 may support audio via a voice network and/or a data network. In one of a number of possible embodiments, the conferencing system 106 may be configured to support, among other platforms, a Voice Over Internet Protocol (VoIP) conferencing platform such as described in U.S. patent application Ser. No. 11/637,291 entitled “VoIP Conferencing,” filed on Dec. 12, 2006, which is hereby incorporated by reference in its entirety. It should be appreciated that the conferencing system 106 may support various alternative platforms, technologies, protocols, standards, features, etc. Regardless of the communication infrastructure, the conferencing system 106 may be configured to establish an audio connection with the client devices 102a-102d, although in some embodiments the audio portion may be removed. As illustrated in
In the embodiment of
As mentioned above, the virtual conference location 118 comprises a computer-simulated conference location that is presented to the client devices 102. The virtual conference location 118 may be presented to the participants 104a-104d via a graphical user interface 132. The virtual conference location 118 may store in an associated memory various forms of data for managing and presenting the computer-simulated conference locations. In the embodiment illustrated in
It should be appreciated that the graphical representations 128 of the participants 104 may comprise, for example, a 2-D graphic, a 3-D graphic, an avatar, an icon, an uploaded image, or any other suitable graphics, emblems, designs or other marks (each a “graphical representation”) for uniquely or otherwise identifying the participants 104. The user-related information 130 (e.g., name, address, email, telephone number, profile information, etc.) may be displayed in association with, or separately from, the graphical representations 128.
As further illustrated in the embodiment of
As described below in more detail with reference to
While the conference alert application is running, it communicates with the conferencing infrastructure using, for example, a conferencing API 112 (
The application alerts the user by displaying a message on a display of the client device 102. The message may appear for a pre-determined amount of time, which may be configurable in the application's settings. The content of the message may further include the details transmitted in the status update mentioned above. The message display may also provide a mechanism for the user to acknowledge the message by either cancelling or joining a location. If the user chooses to cancel a particular message, subsequent messages will appear as new members join a location or audio bridge, with a running tally indicating the total number of participants. If the user chooses to join their own location, the alerts will cease until the event has ended.
The in-conference participant identification module(s) 406 generally support various techniques for developing and operating a database (e.g., participant ID database 2018—
As illustrated in the embodiment of
At decision block 3704, the conferencing system 106 may determine whether the participant 104 is joining the audio conference 114 via an incoming voice call. If the participant 104 is not joining the audio conference 114 via an incoming voice call (e.g., the participant is joining via a web presence), the system may request that the participant 104 provide participant profile information (block 3706). The participant profile information may comprise any desirable parameters identifying the participant 104 or other information related to the participant 104 (e.g., the parameters identified in the exemplary screen shots of
At block 3712, the conferencing system 106 may present a conference user interface to the computing device 102 associated with the participant 104 (as well as the other devices/participants in the audio conference 114). To identify the participant 104, the conference user interface may display one or more of the specified participant profile parameters in association with an audio indicator 3820 (
The profile information 4104 may comprise one or more of the participant profile parameters. The audio indicator 4106 visually identifies when the associated participant 104 is speaking during the audio conference 114. By monitoring the audio streams 122 for certain audio characteristics, the conferencing system 106 may determine when a participant 104 is speaking. The audio stream 122 may be logically mapped to the corresponding audio indicator 4106 according to the participant identifier 3802 and/or the audio indicator identifier 3820 (
The business card component 4108 comprises a user interface control that, when selected, displays further information about the participant 104. The business card component 4108 may trigger the display of any additional participant profile parameters. In the embodiment illustrated in
Referring again to
It should be appreciated that the participant profile control 4204 provides a convenient mechanism for enabling participants 104 to specify, during the audio conference 114, additional profile information about themselves and/or other participants 104 via the conference user interface. In this manner, the conferencing system 106 may develop a proprietary database (e.g., participant database 2018) for identifying participants 104.
For example, assume that a first participant 104 is an unidentified participant.
During the audio conference 114, a second participant 104 may recognize the identity of the first participant 104 based on the speaker's voice and the state of the audio indicator 4106 in the object 4004. The second participant 104 may select the participant profile edit control 4204 in the object 4004 associated with the first participant 104. In response, the conference user interface 4000 may enable the second participant 104 to specify profile parameters, such as those described above. When selected, the conference user interface may prompt the participant 104 to enter known parameters. In another embodiment, the conference user interface may be configured to enable the second participant 104 to specify information via, for example, a search engine results page, a local or remote contact application, a social networking system, or any other source of profile information. At block 3910, the specified profile parameters may be linked to the participant identifier 3802 (
Referring again to
The client device 102 may include a GPS transceiver that acquires GPS signals. When the client device 102 accesses the conferencing system 106, the GPS coordinates may be passed to the location-based module(s) 408. The conferencing system 106 may also obtain caller ID information in the manner described herein. The caller ID information may be automatically obtained by the conferencing system 106 when the participant 104 joins an audio conference 114. The conferencing system 106 may perform various look-ups to determine the location associated with the telephone number. The conferencing system 106 may translate the area code into a corresponding geographic area. In other embodiments, the conferencing system 106 may use the telephone numbers as an input to a look-up table, web service query, etc. to determine if there is an associated location. The location may be a stored current location associated with a participant identifier (e.g., current location 3814—
In additional embodiments, the location information may be obtained from the participant's social networking data via a request 1904 and response 1906 to a social networking system 3102 (
As illustrated in
In another embodiment, the client device 102 may access the conferencing system 106 and send a Login Request 6418 to the Participant Manager Service 6402. The Participant Manager Service 6402 may authenticate the participant 104. If the login is successful, the Participant Manager Service 6402 may send a getClientPhoneNumber( ) request 6416 to the client device 102. The participant 104 may provide the information via, for example, a conferencing user interface, such as those described herein or others. The entered telephone number may be provided to the Participant Manager Service 6402 as a PhoneNumber response 6422. The Participant Manager Service 6402 may send a getLocationbyPhoneNumber( ) request 6424 to the Caller ID Service 6406, which contains the entered phone number. The Caller ID Service 6406 may provide corresponding location information to the client device in a response 6426.
It should be appreciated that additional information may be requested from the client device 102. For example, the Participant Manager Service 6402 may send a getClientCurrentLocation( ) request 6428, and receive a City/State response 6430 containing the entered city, state, zipcode, etc. The Participant Manger Service 6402 may send a getLocationByCity( ) request 6432 (which may include any of the entered information) to the Location Service 6404. The Location Service 6404 may provide corresponding location information to the client device in a response 6434. Regardless of the manner in which the location information is obtained, the client device 102 may send a getMapParticipantLocation( ) request 6436 to a map service 6408. The map service 6408 may return a showMapWithParticipantDetails response 6438. The conferencing system 106 may perform this process for each participant 104 and then present the combined location information in a map view 1908. An exemplary embodiment of a map view 1908 is illustrated in
Based on the location information, the conference interface may customize the presentation of the interface with location-based information associated with one or more participants 104. For example, the conferencing system 106 may provide a unique conference interface to each participant 104 based on the participant's corresponding location. The customization may involve providing location-based resources, services, functionality, etc. to the participant 104 (e.g., news, weather, traffic, events, etc.). Furthermore, in some embodiments, a virtual location view 124 may be selected by the conferencing system 106 to match the location information obtained from the participant 104 (e.g., a participant 104 in San Francisco may be presented a virtual location view 124 including the Golden Gate Bridge).
In further embodiments, the location information may be used to provide an intelligent conference dial-out and/or dial-in feature, which dynamically provides guidance to the participants 104 on how to join the audio conference 114 (e.g., via a login screen 604 (
The virtual conference location application 116 (or other conference interface applications) may support a real-time speech-to-text functionality that may automatically convert speech from the audio streams 122 (
As illustrated in the embodiment of
The server 108 comprises one or more functional processors for implementing aspects of the overall speech-to-text conversion process. It should be appreciated that the functional processors may be implemented in hardware, software, firmware, or any combination thereof. The overall speech-to-text conversion process and any associated processes are preferably performed in real-time during the audio conference 114. In an embodiment, the functional processors comprise a pre-processing engine 2702, a speech-to-text conversion engine 1704, a relevance engine 2704, and a resource engine 1712. The pre-processing engine 2702 communicates with the conference system 106, which may be integrated with the server(s) 108 or remotely located. The pre-processing engine 2702 receives the audio streams 122 from the conference system 106, extracts a speech signal 2704 from each audio stream 122, and provides the speech signals 2704 to the speech-to-text conversion engine 1704. The speech-to-text conversion engine 1704 receives the speech signals 2704, extracts words 2706 from the speech signals, and provides the words 2706 to the relevance engine 2704. It should be appreciated that any desirable conversion algorithms, models, processes, etc. may be used to quickly and accurately extract the words 2706.
The relevance engine 2704 processes the words 2706 according to, for example, heuristic algorithms, to determine relevant keywords 2708 spoken in the audio conference 114. The relevance engine 2704 provides the relevant keywords 2708 to the resource engine 1712. It should be appreciated that the relevant keywords 2708 may represent, for example, frequently spoken words, statistically significant words, topics, etc. The keywords 2708 may comprise one or more of the words 2706 or, in alternative embodiments, may comprise related words based on the subject matter of the audio conference 114.
The resource engine 1712 receives the keywords 2706 and determines resources 2714. The resources 2714 are selected with the purpose of providing to the participants 104 during the audio conference any desirable information, material, data, or other subject matter related to the keywords 2708. As illustrated in
At block 2604, the audio streams 122 are received and processed by, for example, a pre-processing engine 2702, which converts the audio streams 122 into the corresponding speech signals 2704. At block 2606, words 2706 are extracted from the speech signals 2704 using any suitable algorithms for converting the speech signals 2704 into computer-readable data identifying the words 2706. The words 2706 may be extracted in a real-time stream, in batch mode, or otherwise. At block 2608, the words 2706 are analyzed, either individually or in groups, to determine relevant keyword(s) 2708 being discussed in the audio conference session. The relevant keyword(s) 2708 may comprise an identification of frequently spoken word(s), determination of a particular topic, or otherwise identify meaningful subject matter being spoken in the audio conference session and/or related to one or more extracted words 2706. In this regard, it should be appreciated that, in an embodiment, a keyword 2708 may comprise an extracted word 2706 which is repeated a certain number of times, either in absolute terms or relative to a period of time (e.g., a word occurrence or usage density). A keyword 2708 may also comprise an extracted word 2706 which appears to be of particular importance based on, for example, the identity of the participant 104 speaking the extracted word 2706, the waveform characteristics of the speech signal 2704, etc.
The keyword(s) 2708 may be determined using various algorithms. In the embodiment illustrated in
Referring again to
At decision block 2814, it may be determined whether the relevance score exceeds a predetermined or calculated threshold. If the threshold is not exceeded, flow returns to block 2802. If the threshold is exceeded, at block 2816, it is determined that the extracted word 2902 is relevant, and the system attempts to locate a desirable resource related to the extracted word 2902. At block 2818, the resources 2714 are provided to the participants, in real-time during the audio conference 114.
It should be appreciated that, in an embodiment, the resource(s) 2714 may be identified by, for example, matching the extracted words 2902 to predetermined resources, according to resource identifiers 2916 associated with the extracted word 2902 (
Various embodiments of the conference app store functionality 420 (
As illustrated in
To facilitate certain aspects of the conferencing application store, the conferencing system 106 may comprise a conference application database 4306, a participant database 4306, a participant application control module 4304, and a conference user interface 4400. The conference application database 4306 may store information related to the conferencing applications 410, such as, for example, links to the application code or the application code itself. In this regard, it should be appreciated that the conferencing system 106 need not, but may, store the code associated with the conferencing applications. In some embodiments, the conferencing applications may be served by, for example, a third party system. Regardless, within the conference application database 4306, each conferencing application may be identified by a unique application identifier.
The participant database 4306 may store information related to the participants 104 and their corresponding conferencing applications. An exemplary data structure 4600 is illustrated in
The participant application control modules 4304 comprise the logic, functionality, etc. for performing various features associated with the conferencing application store. The participant application control module(s) 4304 enable the conferencing system to manage which conferencing applications a user has purchased or selected, and presents the appropriate applications via the conference interface when the user joins an audio conference 114. In this regard, it should be appreciated that the conferencing system 106 may provide enterprise-level conferencing services to corporations, organizations, government agencies, etc. In such embodiments, the control modules 4304 may manage access, permissions, etc. for enterprise employees. For example, the enterprise may specify which conferencing applications a particular employee may access based on title, organization role, organizational level, employee ID, etc. This information may be stored in an enterprise database and used by the control modules 4304 to select which conferencing applications are to be made available to the employee.
As illustrated in
The top apps menu 4504 may display another scrollable list of application objects 4508 organized based on, for example, a ranking algorithm. Each application object 4508 is associated with a further user interface screen (e.g., component 4702—
At block 4806, the participant application control module 4304 determines the conferencing applications associated with the participant identifier 3802. The participant application control module 4304 may access this information from a database (e.g., conference app database 4306, participant database 4308) and/or from a social networking system 3102. As mentioned above, in the enterprise context, the conferencing applications associated with an employee may be specified according to permissions, roles, etc. provided by the enterprise. In this manner, at block 4806, the conferencing applications are determined based on the enterprise-related information.
At block 4808, the conference user interface 4400 is presented to the computing device 102 associated with the participant, and the associated conferencing applications are made available for use. The conference user interface 4400 may display the available conferencing applications in, for example, the my apps component 4404 (
At blocks 4810 and 4812, the participant application control module 4304 may automatically launch one or more of the available conferencing applications. Alternatively, the participant 104 may manually launch a conferencing application by selecting the corresponding application control 4406.
The participant 104 may select one or more of the available conferencing applications in the conferencing application store. At decision block 4906, the participant application control module 4304 may determine that one of the application objects has been selected by the participant 104. The selected conferencing application may be launched or made available for launching by the participant. In some embodiments, to access the conferencing application, the participant 104 may be required to purchase it. At block 4908, the participant application control module 4304 may determine the account identifier associated with the participant 104 and authorize the purchase (block 4910). At block 4912, the conferencing application may be added to the participants profile.
Referring again to
Various embodiments of virtual location view(s) 124 are illustrated in
At block 1502, the virtual conference location 118 is configured with a predefined first location view 124. This may be a default location view 124 or one selected by the host and/or the participants 104. At block 1504, one or more of the participants may join the virtual conference location 124. At block 1505, the automated location view configuration module(s) 424 can check with the entertainment module(s) 429 to determine if a participant has a personalized sound effect associated with his or her graphical representation, as may be selected by a user with the button 4222 of
It should be appreciated that the location views 124 may be stored in a database 1602 (
The conferencing system 106 may license the assets from third parties and offer them for purchase by participants 104 for use in a virtual conference location 118. A licensed asset may comprise a licensed location for the virtual conference location 118, or graphics, audio, video, items, etc. that may be licensed from third parties and presented in a location view 1602. As an example, a licensed asset may include displaying a particular celebrity as a participant 104, displaying artwork (e.g., wall paintings, sculptures, etc.) in the location view 1602. Although not necessary to be considered licensed assets, it should be appreciated that the licensed assets may comprise any embodiment of intellectual property rights in any medium that are capable of being presented in the virtual conference location 118.
The conferencing system 106 may be configured to support any desirable conferencing system, such as, for example, a teleconferencing system, a VoIP-based (Voice Over Internet Protocol) system, a web-based or online conferencing system, or any other suitable conferencing platform or system.
The bridge 2130 is SIP-protocol enabled, as illustrated by reference numeral(s) 2134. A control layer (SIPSHIM 2136) may comprise an implementation of a B2BUA, allowing the bridge application 2130 to interact with the caller and the media servers 2118 through generic higher-level commands rather than dealing directly with SIP protocol and SIP signaling events.
When a PSTN user calls into a conference, the call is routed through a gateway 2102, through the proxy 2110 and to the VSD 2112. The VSD 2112 plays a greeting and asks the user for a passcode. Different passcodes may be used to differentiate the conference leader for a given conference, as well as to select a particular conference. These passcodes are validated by the DDS 2124 at the request of the VSD 2112. Based on the DNIS, ANI, passcode, or any combination of these (customer defining code), a specific greeting may be selected by the VSD 2112, rather than playing a generic greeting. Next, the VSD 2112 asks the ACS 2126 which bridge 2130 the conference is assigned to. The VSD 2112 then transfers the caller to the appropriate conferencing bridge, 2130 where the caller's media is joined to a conference.
The back-to-back user agents 2114, 2116 allow the system to handle failures in conferencing resources. The call from the telephone 2104 is terminated at the first user agent 2114. If a media server 2118 stops functioning or gives indication of a pending failure (failure mode), the second user agent 2116 is instructed to reroute the call to another media server 2118. The back-to-back user agents 2114, 2116 also allow the system to handle different protocols. The first user agent 2114 generally receives SIP protocol information, but the second user agent 2116 can use a different protocol if that is convenient. This allows the system 2100 to interoperate between resources that use differing protocols.
It should be appreciated that the systems connected to the SIP/BOC channels may be considered part of the conference control system while those systems connected to the RTP or media data streams can be considered to be part of the data portion of the conference system.
This approach minimizes audio latency by having a common focal point for all child conferences to converge. However, this approach may use more “linking” ports on the parent conference. Hence, the initial conference may be deprecated to be a child conference, while the second conference is assigned to be the parent (or step-parent), and thus the media for all conferences is linked to the second conference as the focal point. When instantiating the second conference, sufficient ports may be reserved to allow linking further child conferences in the future.
This approach of linking conferences may also apply where large numbers of callers are located in different geographical regions, or possibly on different types of networks such as a combination of standard VoIP network or a proprietary network, but these need to be linked together. Rather than having all callers connect to a single location, each region or network could connect to a regional bridge, then the bridges and the media are linked together. This minimizes audio latency for callers in the same region, and may also reduce media transport and/or conversion costs. Each region or network could also use parent and child conferences as needed, and only the two parent (or step-parent) conferences in different regions or networks would have their media linked together.
During the call, the state of the conference and of individual users can be controlled through DTMF by the caller, or from any other mechanism that allows a user to access the bridge 2130 directly or indirectly, such as a web-based interface that ties to the bridge 2130 through the back office. The bridge 2130 will subsequently control the media server(s) in use.
For both the VSD 2112 and the conferencing bridge 2130, when the caller presses a digit on his phone the digit press may be passed on as in-band tones within the RTP audio media stream, or may optionally be converted by the gateway 2102 to a telephony event signaling protocol that is carried inside the RTP. In either case, the digit press is detected by the media server and reported to the VSD 2112 or bridge application. The above describes the basic call flow of typical conference user.
The SIP commands employed in the methods of
SIP: Session Initiation Protocol, as defined primarily by IETF Standard RFC3261. SIP is an application-layer control protocol that can establish, modify, and terminate multimedia sessions such as Internet telephony calls.
INVITE: a SIP Request method used to set up (initiate) or modify a SIP-based communication session (referred to as a SIP “dialog”).
SDP: Session Description Protocol. An IETF protocol that defines a text-based message format for describing a multimedia session. Data such as version number, contact information, broadcast times and audio and video encoding types are included in the message.
ACK: Acknowledgement. A SIP Request used within the SIP INVITE transaction to finalize the establishment or renegotiation of a SIP session or “dialog”.
100, 200, 202: SIP Response codes that are sent back to the originator of a SIP request. A response code indicates a specific result for a given request.
NOTIFY: a SIP Request method that is used to convey information to one SIP session about the state of another SIP session or “dialog”.
REFER: a SIP Request method that is used to transfer one end of a SIP session to a different SIP destination.
Sipfrag: SIP fragment. A fragment of a SIP message (such as a Response code) from another SIP session, that is sent as part of the body of a SIP NOTIFY message.
BYE: a SIP Request method that is used to terminate an existing SIP session or “dialog”.
A conferencing system, such as those described above or other conferencing systems, may interface with a social networking system to provide various enhanced communication features.
It should be appreciated that the social networking integration module(s) 414 may be configured to interface with any desirable social networking system 3102. However, to illustrate the general principles of the integrated systems, various exemplary embodiments of a social networking system 3102 will be described.
The social networking system 3102 generally comprises one or more server(s) 3104 for providing a social networking website 3106 to client devices 102 via, for example, a client or web browser 3110. The social networking system 3102 may expose an application program interface (API) 3108 to other computer systems, such as, the conferencing system 106. The API 3108 enables third party applications to access data, applications, or any other stored content or functionality provided by the social networking system 3102 to members 3201.
The social networking system 3102 offers its members 3201 the ability to communicate and interact with other members 3201 of the social network. Members 3201 may join the social networking system 3102 and then add connections to a number of other members 3201 to whom they desire to be connected. Connections may be explicitly added by a member 3201. For example, the member 3201 may select a particular other member 3201 to be a friend, or the social networking system 3201 may automatically recommend or create connections based on common characteristics of the members (e.g., members who are alumni of the same educational institution, organization, etc.). As used herein, the term “friend” refers to any other member to whom a member has formed a connection, association, or relationship via the social networking system 3102. Connections in social networks are usually in both directions, but need not be, so the terms “member,” “friend,” or “follower” may depend on the frame of reference. For example, if Bob and Joe are both members and connected to each other in the website, Bob and Joe, both members, are also each other's friends. The connection between members 3201 may be a direct connection. However, some embodiments of a social networking system 3201 may allow the connection to be indirect via one or more levels of connections. It should be appreciated that the term friend does not require that the members 3201 are friends in real life. It simply implies a connection in the social networking system 3102.
The social networking system 3102 may be implemented in various types of computer systems. The implementation of the social networking system 3102 may provide mechanisms for members 3201 to communicate with each other, form connections with each other, store information, and share objects of interest, among other things. The implementations described below include a social networking website 3106 that interacts with members 3201 at client devices 102 via a communication network 110, such as a web-based interface (e.g., via the browser 3110). However, other implementations are possible, such as one or more servers 3104 that communicate with clients using various client and server applications (e.g., non-web-based applications). Furthermore, the social networking system 3102 may not include any centralized server, but rather may be implemented as, for example, a peer-to-peer system with peer-to-peer applications running on the client devices 102 that allow members 3201 to communicate and perform other functions. One example is a peer-to-peer network of smart phones communicating via Short Message Service (SMS) over a cellular network. It should be appreciated that the embodiments of a social networking website 3106 described below may be adapted to various other implementations of social networking systems.
In addition to interactions with other members 3201, the social networking website 3106 provides members 3201 with the ability to take actions on various types of items supported by the social networking system 3102. These items may include groups or social networks (a social network refers not to physical communication networks but rather to social networks of people) to which members 3201 may belong, events or calendar entries in which a member 3201 might be interested, computer-based applications that a member 3201 may use via the social networking website 3106, and transactions that allow members 3201 to buy, sell, auction, rent, or exchange items via the social networking website 3106. These are just a few examples of the items upon which a member 3201 may act on the social networking website 3106, and many others are possible.
As illustrated in the embodiment of
The member 3201 of the social networking website 3106 may take specific actions on the social networking website 3106, where each action is associated with one or more objects. The types of actions that a member 3201 may perform in connection with an object are defined for each object and may depend on the type of item represented by the object. A particular action may be associated with multiple objects. Described below are a number of examples of particular types of objects that may be defined for the social networking website 3106, as well as a number of actions that may be taken for each object. The objects and actions are provided for illustration purposes only, and one or ordinary skill in the art will readily appreciate that an unlimited number of variations and features may be provided on the social networking website 3106.
The social networking website 3106 maintains a member profile 3220 for each member of the website 3106. Any action that a particular member 3201 takes with respect to another member 3201 is associated with each member's profile 3220, through information maintained in a database or other data repository, such as the action log 3310 (
A group 3222 may be defined for a group or network of members 3201. For example, a member 3201 may define a group to be a fan club for a particular band. The social networking website 3106 would maintain a group 3222 for that fan club, which might include information about the band, media content (e.g., songs or music videos) by the band, and discussion boards on which members 3201 of the group may comment about the band. In this regard, member actions that are possible with respect to a group 3222 may include joining the group, viewing the content, listening to songs, watching videos, and posting a message on the discussion board.
An event 3216 may be defined for a particular event, such as a birthday party. A member 3201 may create the event 3216 by defining information about the event, such as the time and place and a list of invitees. Other members 3201 may accept the invitation, comment about the event, post their own content (e.g., pictures from the event), and perform any other actions enabled by the social networking website 3106 for the event 3216. The creator of the event 3216, as well as the invitees for the event, may perform various actions that are associated with that event 3216.
The social networking website 3106 also enables members 3201 to add applications 3218 to their profiles. These applications provide enhanced content and interactivity within the social networking website 3106, which maintains an application object 3218 for each application hosted in the social networking system. The applications may be provided by the social networking system 3102, the conferencing system 106, and/or by third party developers. The social networking system 3102 and the conferencing system 106 may share applications between the respective computer systems. The use of any functionality offered by the application may constitute an action by the member 3201 in connection with the application 3218. The actions may be passive and need not require active participation by a member 3201. The scope and type of applications provided is limited only by the imagination and creativity of the application developers. The applications are generally written as server-side code that is run on servers of the social networking website 3106, although in other embodiments an application may also use client-side code as appropriate, or any combination thereof. When a member 3201 logs into the social networking website site 3106, the system determines which applications the user has installed (e.g., registered for, purchased, etc.), and then loads and runs such applications in combination with the underlying functionality of the social networking website 3106.
When a member 3201 takes an action on the social networking website 3106, the action is recorded in an action log 3312. In one embodiment, the social networking website 3106 maintains the action log 3312 as a database of entries. When an action is taken, the social networking website 3106 may add an entry for that action to the log 3312. The action loc 3312 may maintain any of the following or other types of information: a timestamp of when the action occurred; an identifier for the member 3201 who performed the action; an identifier for the member 3201 to whom the action was directed; an identifier for the type of action performed; an identifier for an object acted on by the action (e.g., an application); and content associated with the action. It should be appreciated that many types of actions that are possible in the social networking website 3106 need not require all of this information.
The social networking website 3106 generally comprises a computing system that allows members 3201 to communicate or otherwise interact with each other and access content and/or functionality as described herein. The social networking website 3106 stores member profiles 3220 in, for example, a member profile store 3302. A member profile 3220 may describe the member, including biographic, demographic, and other types of descriptive information, such as work experience, educational history, hobbies or preferences, location, and the like. The social networking website 3106 further stores data describing one or more relationships between different members 3201. The relationship information may indicate members 3201 who have similar or common work experience, group memberships, hobbies, or educational history. The social networking website 3106 may include member-defined relationships between different members 3201, allowing members 3201 to specify their relationships with other members 3201. For example, member-defined relationships may allow members 3201 to generate relationships with other members 3201 that parallel real-life relationships, such as friends, co-workers, partners, and so forth. Members 3201 may select from predefined types of relationships, or define their own relationship types as needed.
To further illustrate the manner in which the conferencing system 106 may share data and/or applications with a social networking system,
The web server(s) 3104 link the social networking website 3106 via the network 110 to the client devices 102. The web server 3104 serves web pages, as well as other web-related content, such as, for example, Java, Flash, XML, and so forth. The web server 3104 may include a mail server or other messaging functionality for receiving and routing messages between the social networking website 3106, the client devices 102, and the conferencing system 106. The messages can be instant messages, queued messages (e.g., email), text and SMS messages, or any other suitable messaging technique, using any suitable protocol(s).
The action logger 3316 is capable of receiving communications from the web server 3104 about member actions on and/or off the social networking website 3106. The action logger 3316 populates the action log 3312 with information about member actions to track them.
As discussed above, the social networking website 3106 maintains data about a number of different types of objects with which a member may interact on the social networking website 3106. In this regard, each of the member profile store 3302, application data store 3306, the group store 3310, and the event store 3308 stores instances of the corresponding type of object(s) maintained by the social networking website 3106. Each object type has information fields that are suitable for storing information appropriate to the type of object. For example, the event store 3308 may contain data structures that include the time and location for an event, whereas the member profile store 3302 may contain data structures with fields suitable for describing a member's profile 3220. When a new object of a particular type is created, the social networking website 3106 may initialize a new data structure of the corresponding type, assign a unique object identifier to it, and begin to add data to the object as needed.
Having described exemplary embodiments of a social networking system 3102 with which the conferencing system 106 may share data and/or functionality, the operation of additional embodiments of the social networking integration module(s) 414 will be described with reference to
In an embodiment, the first portion 3404 may comprise an input mechanism for capturing content, during the audio conference 114, which may be posted to one or more of the social networking communication channels 3202 (
As illustrated in
If the participant 104 is properly authenticated for access to the social networking system 3102, at block 3608, data from the social networking system 3102 (e.g., communication channels 3202) may be integrated with the graphical user interface 3400. The data may be presented in the second portion 3406, and may comprise any data described above, or any other data, content, and/or functionality associated with the social networking system 3102. As mentioned above, the data may be accessed using the API 3108, in which case suitable requests and responses may be sent (block 3608) from, and received by, either the client device 102 or the conferencing system 106. The participant 104 may also access social networking applications 3218 via a user interface control 3408. The participant 104 may select or otherwise engage the control 3408, which may trigger a menu for enabling the participant 104 to access applications 3218 associated with the participant's social networking profile 3220.
Referring to
In the embodiment illustrated in
In general operation, the conferencing notification application 5002 may provide alerts based on various events monitored by the conferencing system 106. For instance, the conferencing notification application 5002 may notify a host when an audio conference 114 or conference has started and alert the host to who has joined the audio conference 114 or accessed the conference by showing, for example, the participant name, the number of current participants, etc. The alerts may be implemented using a push methodology by which the alerts are “pushed” from the conferencing system 106, a pull methodology by which the alerts are “pulled” from the conferencing system 106 by the computing device 102 using, for example, the conferencing API 4302, or other alert protocols, services, methodologies, etc. As participants 104 join the audio conference 114 or the associated conference, the conferencing system 106 maintains a counter of the number and identity of participants 104 and provides related or other information to the host. The conferencing notification application 5002 may also enable the host to conveniently access the conference interface from within the application (e.g., via a menu, key shortcut, or other user interface control), as well as modify conferencing, notification or account settings prior to or during a virtual conference.
The conferencing notification application 5002 may incorporate a user interface control for enabling users to launch the application or conveniently access certain functions or features of the application (e.g., configure remote or local settings, join a virtual conference, etc.). The user interface control may be presented in various ways depending on, for example, the configuration of the operating system 5004, the GUI 132, the display type and/or size, and other hardware and/or software characteristics.
The user interface control 5118 may be displayed anywhere within the desktop 5102. In
The touchscreen display 5004 may comprise a resistive touchscreen panel having two thin, metallic, electrically conductive layers separated by a narrow gap. When an object, such as a finger, presses down on a point on the panel's outer surface the two metallic layers become connected at that point. The touchscreen panel then behaves as a pair of voltage dividers with connected outputs. This causes a change in the electrical current which is registered as a touch event and sent to a controller (e.g., processor 402) for processing.
The touchscreen display 5004 may be implemented using surface acoustic wave (SAW) technology that uses ultrasonic waves that pass over the touchscreen panel. When the panel is touched, a portion of the wave is absorbed. This change in the ultrasonic waves registers the position of the touch event and sends this information to the processor 402.
In another embodiment, the touchscreen display 5004 supports capacitive sensing via a capacitive touchscreen panel. A capacitive touchscreen panel comprises an insulator, such as glass, coated with a transparent conductor, such as indium tin oxide. As the human body is also a conductor, touching the surface of the screen results in a distortion of the local electrostatic field, measurable as a change in capacitance. Different technologies may be used to determine the location of the touch. The location may be passed to the processor 402, which may calculate how the user's touch or gestures relate to the particular functions of the conferencing notification application 5002.
The touchscreen display 5004 may also support surface capacitance implementations, in which only one side of the insulator is coated with a conductive layer. In such implementations, a small voltage is applied to the layer, resulting in a uniform electrostatic field. When a conductor, such as a human finger, touches the uncoated surface, a capacitor is dynamically formed. The sensor controller may determine the location of the touch indirectly from the change in the capacitance as measured from the four corners of the display area 5206.
In a further embodiment, the touchscreen display 5004 implements a projected capacitive touch (PCT) display having an etched conductive layer. An XY array may be formed by, for example, etching a single layer to form a grid pattern of electrodes or by etching two separate perpendicular layers of conductive material with parallel lines or tracks to form the grid. Applying voltage to the array creates a grid of capacitors. Bringing a finger or conductive stylus close to the surface of the sensor changes the local electrostatic field. The capacitance change at every individual point on the grid may be measured to accurately determine the touch location. The use of a grid permits a higher resolution than resistive technology and also allows multi-touch operation. The PCT display may allow operation without direct contact, such that the conducting layers can be coated with further protective insulating layers, and operate even under screen protectors.
The touchscreen display 5004 may be configured to optically sense touch using, for example, an array of infrared (IR) light-emitting diodes (LEDs) on two adjacent bezel edges of a display, with photosensors placed on the two opposite bezel edges to analyze the system and determine a touch event. The LED and photosensor pairs may create a grid of light beams across the display. An object (such as a finger or pen) that touches the screen interrupts the light beams, causing a measured decrease in light at the corresponding photosensors. The measured photosensor outputs can be used to locate a touch-point coordinate.
Another embodiment of the touchscreen technology involves dispersive signal technology, which uses sensors to detect the mechanical energy in the glass that occurs due to a touch. Algorithms stored in memory 404 and executed by processor 402 interpret this information and provide the actual location of the touch.
Acoustic pulse recognition may also be used to detect the touch. In this embodiment, two piezoelectric transducers are located at some positions of the screen to turn the mechanical energy of a touch (i.e., vibration) into an electronic signal. The screen hardware then uses an algorithm to determine the location of the touch based on the transducer signals.
Referring again to
Regardless of the type and configuration of the computing device 102, the conferencing notification application 5002 may be accessed by selecting the user interface control. For example, a user may select the user interface control 5214 (
The iMeet Now button 5406 may enable the user to connect to the conferencing system 106. When the user selects the button 5406, the conferencing notification application 5002 may launch the browser 3110 and enable the user to join an audio conference 114 and access the conference user interface 4400. The Manage Account button 5408 may enable the user to configure the account profile 4602 (
In operation, the conferencing notification application 5002 may communicate with the conferencing system 106 using conferencing API(s) 4302. The conferencing API(s) 4302 may enable the conferencing notification application 5002 to submit requests 5516 to, and receive responses 5514 from, the conferencing system 106. These communications may include, for example, status checks of the user's conferences to determine if there are any active participants 104. In the event that someone has entered the user's conference or joined one of their bridges via a phone, this activity may be transmitted to the conferencing notification application 5002 as a status update or alert. The update may include other information about the newly joined participants, such as, the participant parameters described above and illustrated in
The alerts provided to the conferencing notification application 5002 may be presented on the display.
If the user chooses to cancel a particular message or the message expires without the user joining the conference, the conferencing system 106 may continue to send alerts as events occur. If the user chooses to join the conference, the conferencing system 106 may disable alerts.
To implement the conferencing notification application 5002, the conferencing system 106 may support various web services for exchanging structured information with the conferencing notification application 5002. The web services may be implemented using any suitable protocol. In an embodiment, the web services may be implemented via the Simple Object Access Protocol (SOAP) using Extensible Markup Language (XML) as the messaging format. The conferencing system 106 may respond to web service calls from the conferencing notification application 5002 by either returning the requested information immediately or by initiating the request and then providing the results (later) via a polling action.
The subscribe/unsubscribe service 5502 may be implemented with a Subscribe( ) call that establishes authorization to use the resources provided by the conferencing system 106. The Subscribe( ) call may be the first call made by the conferencing notification application 5002 to the conferencing system 106. In an embodiment, the Subscribe( ) call may require an authorization response before the conferencing notification application 5002 may access other services. In this regard, the subscribe/unsubscribe service 5502 may be configured without a security token in the SOAP header. The other web services may be implemented with the security token (e.g., a session ID obtained with the Subscribe( ) call).
An exemplary XML request for the Subscribe( ) call may be configured as follows:
An exemplary XML response for the Subscribe( ) call may be configured as follows:
An Unsubscribe( ) call may be made to unsubscribe the user from the web services when the conferencing notification application 5002 is closed. The call may terminate the session with the conferencing system 106. Further interactions with the conferencing system 106 may require a subsequent Subscribe( ) call to be made by the conferencing notification application.
An exemplary XML request for the Unsubscribe( ) call may be configured as follows:
An exemplary XML response for the Unsubscribe( ) call may be configured as follows:
The conference watch service 5504 may invoke a SetConferenceWatch( ) call that establishes a conference watch, which enables the conferencing system 106 to begin sending alerts to the conferencing notification application 5002. After setting a conference watch, the user may receive notifications or alerts for conference(s) associated with the user, including, for example, when a participant 104 joins or leaves a conference, when a participant speaks during an audio conference 114, when a participant posts or receives information associated with a social networking system 3102, etc.
The conference watch service 5504 may be useful for hosts who are too busy to join a conference, do not wish to join the conference, or are otherwise unable to join the conference but want to monitor the activity of the conference. For example, the host may be interested in joining the conference, for example, but only after a particular person has joined or some other event has occurred. The host may view the alert messages as they are provided by the conferencing system 106 and displayed by the computing device 102. When the desired event has occurred, the host may elect to join the conference. As described below, the alerts may be retrieved from the conferencing system 106 via the conference polling service 5506.
An exemplary XML request for the SetConferenceWatch( ) call may be configured as follows:
An exemplary XML response for the SetConferenceWatch( ) call may be configured as follows:
The conference watch service 5504 may also invoke a ClearConferenceWatch( ) call that may be used to clear a previously established conference watch. Removing a conference watch may cause the alerts for the specified conference to be disabled. After clearing the conference watch, the user will no longer receive alerts.
An exemplary XML request for the ClearConferenceWatch( ) call may be configured as follows:
An exemplary XML response for the ClearConferenceWatch( ) call may be configured as follows:
The conferencing polling service 5506 may invoke a PollForMessages( ) call, which is used to request events from a watched conference. In response to the request, the conferencing notification application 5502 will receive events associated with the watched conference.
An exemplary XML request for the PollForMessages( ) call may be configured as follows:
An exemplary XML response for the PollForMessages( ) call may be configured as follows:
The authentication service 5508, the conference schedule service 5510, and the join conference service 5512 may enable the conferencing notification application 5002 to interface with a registration system. The authentication service 5508 may invoke a Security ValidateLogOn( ) call to validate a user's logon credentials. The call may return a security token, which may be used to create a login header. The login header may be sent with one or more of the other service calls. An exemplary XML request for the SecurityValidateLogOn( ) call may be configured as follows:
An exemplary XML response for the SecurityValidateLogOn( ) call may be configured as follows:
The conference schedule service 5510 may invoke a FindReservation( ) call that returns a list of conferences. The FindReservation( ) call may be initiated when a user selects the Conference Schedule button 5416, as illustrated in
An exemplary XML request for the FindReservation( ) call may be configured as follows:
An exemplary XML response for the FindReservation( ) call may be configured as follows:
The join conference service 5512 may be invoked when, for example, the user selects the join button 5606 (
An exemplary XML response for the WebHostLogin( ) call may be configured as follows:
An exemplary XML response for the WebHostLogin( ) call may be configured as follows:
Referring briefly to
When the personalized sound effect button 4222 is selected, a graphical user interface may be presented so that a user of the system may select a personalized sound effects from a list of optional sounds or melodies, or the user may be given the option to upload his or her own personal audio file. One of ordinary skill in the art recognizes that any number or a variety of sound effects are available for use with the invention. Such sound effects include, but are not limited to, sounds or noises associated with objects, musical melodies, non-musical sounds, human voices, synthetic voices generated by a computer, sounds from instruments in a nonmusical manner, or any combination of the sounds listed above.
For example, as illustrated in
Referring back to
At block 1512, the configuration module(s) 424 select a new location view 124 and automatically reconfigure the virtual conference location 118 to accommodate the additional participants 104. At block 1514, the configuration module(s) 424 can determine if all scheduled participants for the virtual conference are present. If all scheduled participants for a virtual conference are not present, the method can loop back so that this check is made repeatedly.
If all scheduled conference participants are present, then at block 1516, the entertainment module(s) 429 or automated location view module(s) 424 (or both) can play a sound effect to indicate the starting or initiation of a closed meeting. Similarly, if one of the scheduled participants purposely or accidentally drops from the virtual conference, the entertainment module(s) 429 or automated location view modules can play a sound effect to indicate the ending or opening up of a closed meeting.
Referring briefly back to
In the embodiment illustrated in
For example, in the embodiment of
In this particular embodiment illustrated in
Further, while a traditional card game like poker has been illustrated, any type of games, which may be card-oriented or board-oriented or not, are included within the scope of the invention. As non-limiting examples, games can include those like Old Maid, Fish, Monopoly, Hangman, Sorry, and other types of games as will be described below.
According to one aspect of the invention, these entertainment options, which may include interactive games among conference participants, may be available or active while a small set of conference participants are waiting for remaining participants of a scheduled conference. Alternatively or in addition to that pre-conference or waiting scenario, the entertainment options may be selected and activated at any time during a virtual conference in order to revive or “wake up” or revitalize the virtual conference participants. Such entertainment options can be selected so that the virtual conference participants may take a “break” from any business which may be the topic of the virtual conference. A simple user interface, such as a button 6618, may be provided in which a conference participant can select in order to pause or to activate an entertainment feature, like a card game, for the conference participants.
The audio jukebox 6705 can comprise a now playing window 6709 as well as a menu 6712 which lists available songs that can be selected by a user with the screen pointer 6605. The audio jukebox 6705 can be supported and executed by the entertainment module(s) 429. The now playing window 6709 of the audio jukebox 6705 can list a name or a title of an audio file currently being played to all of the virtual conference participants in the virtual conference location 124. When a user selects an option from the list of options in the menu 6712, that option can be played next after the audio file in the now playing window 6709 is finished. The entertainment module(s) 429 can allow each user to fill up a queue or stack of audio files as they select them from the menu 6712.
The window 6809 may also comprise a menu 6812 that lists different options of video files that can be selected by a conference participant. A user may select a particular video file by using the screen pointer 6605. The video files can comprise any type of video content such as previews for new movies, videos available on various media such as DVDs or memory chips, as well as full-length or full-scale movies that can be played until the button 6618 labeled “Start/Pause Entertainment” has been selected or until the entertainment module(s) 429 determine that all scheduled conference participants are present in the virtual conference location.
One of ordinary skill in the art recognizes that numerous different types of graphical user interfaces can be employed for receiving input from the conference participants who are in the virtual conference location 1200 without departing from the scope of the invention. The invention is not limited to any of the exemplary graphical user interfaces described in this figure as well as any other figures of this disclosure. Further, one of ordinary skill the art will recognize that other games not specifically identified or mentioned fall within the scope of the invention. For example, the invention can easily support other types of fantasy sports games besides fantasy football such as ones for European football or soccer, basketball, baseball, hockey, lacrosse, and other like athletic games.
These selected musical instruments 7009 by the conference participants can be used to play various different musical games, such as, but not limited to the currently popular, Guitar Hero™ brand musical melody game. The conference participants can select a desired instrument by using the screen pointer 6605 two identify a particular instrument 7009 that he or she desires to play during the game. However, one of ordinary skill the art recognizes that other instruments and other similar musical games, though not specifically identified, are fully supported by this disclosure and are within the scope of the invention.
As noted previously, the invention is also not limited to the graphical user interfaces provided in
At block 7104, the entertainment module(s) 429 can display a graphical user interface corresponding to the selected entertainment option. For example, the entertainment module(s) 429 can display the card game of
At block 7106, the entertainment module(s) 429 can receive one or more selections of the entertainment options listed in the graphical user interface. For example, if the audio jukebox 6705 of
At block 7108, the entertainment module(s) can display visuals corresponding to the selected options. For example, in the audio jukebox example of
Next at block 7110, if there is audio associated with the visuals generated in connection with block 7108, then the entertainment module(s) 429 can play such audio. For example as set forth above with respect to the audio jukebox of
At block 7112, if the selected entertainment option is an interactive experience such as in an interactive game like the interactive card game of
At decision block 7114, the entertainment module(s) 429 can determine if all scheduled conference participants are present in the virtual meeting location 124. Also the entertainment module(s) 429 can also monitor and determine if the pause/start button 6618 has been activated by one of the conference participants.
If the meeting is not ready or if the pause/start button 6618 has not been activated by one of the conference participants, then the entertainment module(s) 429 can repeatedly monitor for the change in this status. If the meeting is ready to begin or if the entertainment module(s) 429 determines that the pause/start button 6618 has been activated, then at block 7116, the entertainment module(s) 429 can pause any one of the active entertainment options which were selected by one or more conference participants.
It should be appreciated that one or more of the process or method descriptions associated with the flow charts or block diagrams above may represent modules, segments, logic or portions of code that include one or more executable instructions for implementing logical functions or steps in the process. It should be further appreciated that the logical functions may be implemented in software, hardware, firmware, or any combination thereof. In certain embodiments, the logical functions may be implemented in software or firmware that is stored in memory or non-volatile memory and that is executed by hardware (e.g., microcontroller) or any other processor(s) or suitable instruction execution system associated with the multi-platform virtual conference location system. Furthermore, the logical functions may be embodied in any computer readable medium for use by or in connection with an instruction execution system, apparatus, or device, such as a computer-based system, processor-containing system, or other system associated with the multi-platform virtual conference location system that can fetch the instructions from the instruction execution system, apparatus, or device and execute the instructions.
It should be noted that this disclosure has been presented with reference to one or more exemplary or described embodiments for the purpose of demonstrating the principles and concepts of the invention. The invention is not limited to these embodiments. As will be understood by persons skilled in the art, in view of the description provided herein, many variations may be made to the embodiments described herein and all such variations are within the scope of the invention.