US8701020B1 - Text chat overlay for video chat - Google Patents

Text chat overlay for video chat Download PDF

Info

Publication number
US8701020B1
US8701020B1 US13/250,964 US201113250964A US8701020B1 US 8701020 B1 US8701020 B1 US 8701020B1 US 201113250964 A US201113250964 A US 201113250964A US 8701020 B1 US8701020 B1 US 8701020B1
Authority
US
United States
Prior art keywords
computing device
text
video
mode
display
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Active
Application number
US13/250,964
Inventor
Richard Fulcher
Michael D. Dodd
Evan Miller
Wei Huang
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Google LLC
Original Assignee
Google LLC
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Google LLC filed Critical Google LLC
Priority to US13/250,964 priority Critical patent/US8701020B1/en
Assigned to GOOGLE INC. reassignment GOOGLE INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DODD, MICHAEL D., HUANG, WEI, MILLAR, EVAN, FULCHER, RICHARD
Application granted granted Critical
Publication of US8701020B1 publication Critical patent/US8701020B1/en
Assigned to GOOGLE LLC reassignment GOOGLE LLC CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: GOOGLE INC.
Active legal-status Critical Current
Anticipated expiration legal-status Critical

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0487Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser
    • G06F3/0488Interaction techniques based on graphical user interfaces [GUI] using specific features provided by the input device, e.g. functions controlled by the rotation of a mouse with dual sensing arrangements, or of the nature of the input device, e.g. tap gestures based on pressure sensed by a digitiser using a touch-screen or digitiser, e.g. input of commands through traced gestures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L12/00Data switching networks
    • H04L12/02Details
    • H04L12/16Arrangements for providing special services to substations
    • H04L12/18Arrangements for providing special services to substations for broadcast or conference, e.g. multicast
    • H04L12/1813Arrangements for providing special services to substations for broadcast or conference, e.g. multicast for computer conferences, e.g. chat rooms
    • H04L12/1827Network arrangements for conference optimisation or adaptation
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/414Specialised client platforms, e.g. receiver in car or embedded in a mobile appliance
    • H04N21/41407Specialised client platforms, e.g. receiver in car or embedded in a mobile appliance embedded in a portable device, e.g. video client on a mobile phone, PDA, laptop
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/41Structure of client; Structure of client peripherals
    • H04N21/422Input-only peripherals, i.e. input devices connected to specially adapted client devices, e.g. global positioning system [GPS]
    • H04N21/4223Cameras
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N21/00Selective content distribution, e.g. interactive television or video on demand [VOD]
    • H04N21/40Client devices specifically adapted for the reception of or interaction with content, e.g. set-top-box [STB]; Operations thereof
    • H04N21/47End-user applications
    • H04N21/478Supplemental services, e.g. displaying phone caller identification, shopping application
    • H04N21/4788Supplemental services, e.g. displaying phone caller identification, shopping application communicating with other users, e.g. chatting
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/14Systems for two-way working
    • H04N7/141Systems for two-way working between two video terminals, e.g. videophone

Definitions

  • the disclosure relates to instant messaging and video chat communications between computing devices.
  • Two or more users of computing devices may often engage in real-time video communications, such as video conferencing, where the users exchange live video and audio transmissions (referred to herein as “video chat”).
  • video chat live video and audio transmissions
  • a first user may wish to send a text-based message (referred to herein as “text chat”) to a second user during the video chat.
  • text chat a text-based message
  • the second user is using a computing device with a relatively small screen (such as a mobile phone, PDA, tablet computer, or other mobile device), there is little available room to display the text chat, such that the second user may be unable to receive the text-based message during the video chat.
  • a method includes, receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data; displaying the video data on a display of the first computing device; receiving a text-based message at the first computing device that is sent from the second computing device during the real-time video communication; and overlaying information related to the text-based message onto the video data displayed on the display of the first computing device.
  • a non-transitory computer-readable medium is encoded with instructions for causing a programmable processor to perform operations including: receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data; displaying the video data on a display of the first computing device; receiving a text-based message at the first computing device during the real-time video communication; and overlaying information related to the text-based message onto the video data displayed on the display of the first computing device.
  • a computing device includes one or more processors.
  • the computing device further includes a network interface to receive communication data from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises audio data and video data, and an output device that displays the video data.
  • the computing device further includes means for overlaying, onto the displayed video data, a text-based message received from the second computing device by the computing device during the real-time video communication.
  • FIG. 1 is a block diagram illustrating an example of a computing device that may execute one or more applications and receive a text message during a video chat, in accordance with one or more aspects of the present disclosure.
  • FIG. 2 is a block diagram illustrating further details of one example of the computing device shown in FIG. 1 , in accordance with one or more aspects of the present disclosure.
  • FIG. 3 is a flow chart illustrating an exemplary method that may be performed by a computing device to overlay at least a portion of a text message onto a video chat, in accordance with one or more aspects of the present disclosure.
  • FIG. 4A is a block diagram illustrating one example of a computing device operating in a video mode displaying a text-based message in an overlay box, in accordance with one or more aspects of the present disclosure.
  • FIG. 4B is a block diagram illustrating one example of computing device operating in a text mode during a real-time video communication, in accordance with one or more aspects of the present disclosure.
  • FIG. 1 is a block diagram illustrating an example of a computing device 2 that may execute one or more applications (e.g., chat application 8 ) and receive a text message 29 during a video chat, in accordance with one or more aspects of the present disclosure.
  • Computing device 2 may, in some examples, include or be part of a portable computing device (e.g., a mobile phone, netbook, laptop, personal data assistant (PDA), tablet device, portable gaming device, portable media player, e-book reader, or a watch) as well as non-portable devices (e.g., a desktop computer).
  • a portable computing device e.g., a mobile phone, netbook, laptop, personal data assistant (PDA), tablet device, portable gaming device, portable media player, e-book reader, or a watch
  • non-portable devices e.g., a desktop computer.
  • computing device 2 is described as a portable or mobile device that a user 14 can carry, such as a laptop, or a desktop computer, but aspects of this
  • Computing device 2 may include a display device 12 (e.g., a touch-sensitive device), one or more input devices 38 (e.g., a microphone), a camera 16 , and one or more output devices 40 (e.g., a speaker).
  • display device 12 may comprise a touch-sensitive display 4 .
  • touch-sensitive display 4 may be capable of receiving touch input from a user 14 (e.g., touch screen, track pad, track point, or the like). User 14 may interact with display device 12 , for example, by performing touch input on touch-sensitive display 4 .
  • One example of computing device 2 is more fully described in FIG. 2 , discussed below.
  • Computing device 2 may be connected to second computing device 22 in a peer-to-peer fashion, either directly or through network 32 .
  • a peer-to-peer connection may be a network connection that partitions tasks or workloads between peers (e.g., first and second computing devices 2 and 22 , respectively) without centralized coordination by a server (e.g., server 30 ).
  • first computing device 2 and second computing device 22 exchange communication data 26 via a peer-to-peer connection.
  • server 30 may provide conference calling capabilities in accordance with one aspect of this disclosure.
  • server 30 may manage a three-way video conference call with instant messaging capabilities between computing devices 2 , 22 , and 24 .
  • FIG. 1 will be described in terms of a real-time video communication between first computing device 2 and second computing device 22 .
  • the techniques and examples described in accordance with this disclosure apply to communications having more than two participants.
  • first computing device 2 and second computing device 22 have established a real-time video communication.
  • User 14 operates first computing device 2 and a second user 15 operates the second computing device 22 .
  • an image of second user 17 is displayed on touch-sensitive display 4 of first computing device 2 .
  • User 14 and second user 15 may be engaged in a video chat.
  • first computing device 2 and second computing device 22 exchange communication data 26 , which may be streamed real-time.
  • communication data 26 may include video data 28 (e.g., from camera 16 ) and audio data 27 (e.g., from microphone 38 ).
  • video data 28 and audio data 27 may be transferred between first computing device 2 and second computing device 22 over different channels.
  • video data 28 and audio data 27 may be transferred over a single channel.
  • communication data 26 may be transferred using an Real-time Transport Protocol (“RTP”) standard developed by the Internet Engineering Task Force (“IETF”).
  • RTP Real-time Transport Protocol
  • video data 28 may have a format such as H.263 or H.264.
  • other protocols or formats are used.
  • some or all of communication data 26 or text message 29 may be transferred encrypted, such as, for example, using Secure Real-time Transport Protocol (SRTP), or any other encrypted transfer protocol.
  • SRTP Secure Real-time Transport Protocol
  • video data 28 and audio data 27 may be associated with each other (e.g., audio data 27 is diegetic to video data 28 ). In other examples, video data 28 and audio data 27 may not be associated with each other (e.g., audio data 27 is non-diegetic with video data 28 , for example, a sound track is played along with video data 28 ).
  • communication data 26 may include both audio data 27 and video data 28 ; however, in other examples, communication data 26 may include only one of either audio data 27 or video data 28 . Further, at any given moment during the real-time video communication, either of computing devices 2 and 22 may be sending only audio data 27 , only video data 28 , or both.
  • First computing device 2 includes a chat application 8 that, when executed, provides functionality to first computing device 2 to establish and maintain communications between one or more computing devices (e.g., second computing device 22 ). Chat application 8 may also provide signals to display device 12 to display information related to the communications and to enable user 14 to interact with chat application 8 .
  • chat application 8 may also provide signals to display device 12 to display information related to the communications and to enable user 14 to interact with chat application 8 .
  • Chat application 8 may include a video chat module 6 and a text chat module 10 .
  • Video chat module 6 in various instances, provides first computing device 2 with capabilities to participate in a video conference between first computing device 2 and one or more computing devices.
  • Text chat module 10 in various instances, provides first computing device 2 with capabilities to participate in a text-based conference between first computing device 2 and one or more computing devices.
  • text chat module 10 provides instant messaging capabilities between first computing device 2 and second computing device 22 .
  • chat application 8 contains further communication modules having additional capabilities.
  • Chat application 8 may allow first computing device 2 to operate in a plurality of different modes.
  • video chat module 6 may correspond to a video mode, where received video data 28 may be displayed on computing device 2 .
  • video mode one or more cameras 16 and one or more other input devices 38 of first computing device 2 may be activated.
  • user 14 may point camera 16 at her or his face or another object of interest during video mode in order to transmit a video.
  • Input device 38 such as a microphone, may record any sound incident to the microphone, such as user 14 's voice.
  • First computing device 2 may, in real-time, send this first video data from camera 16 and first audio data from input device 38 to second computing device 22 .
  • second computing device 22 sends second video data and second audio data from similar input devices to first computing device 2 .
  • first computing device 2 may output some or all of this communication data 26 , for example, with output devices 40 (e.g., a speaker) and display device 12 .
  • first computing device 2 may switch between different cameras 16 , such as a front-facing camera and a rear-facing camera.
  • audio data may not be streamed during video mode.
  • multiple audio data may be streamed by first computing device 2 .
  • video data may be sourced from a variety of inputs besides camera 16 , such as, for example, a slideshow of pictures, a pre-recorded video feed, a screencast showing a window, or the like.
  • audio data may be sourced from any audio source, for example, a sound file stored on one of computing devices 2 or 22 .
  • Text chat module 10 may correspond to a text mode, enabling user 14 to compose or send a text message, or to respond to text message 29 received by first computing device 2 . That is, in one example, first computing device 2 may communicate with computing devices 22 and 24 via instant messaging or text chat. For example, while engaged in a real-time video communication with user 14 , second user 15 desires to send an instant message to user 14 . In one example, second user 15 types out, or otherwise inputs, a text-based message to user 14 . This text-based message may then be sent to first computing device 2 as text message 29 . Text message 29 may be any message that at least partially contains text-based information.
  • a text chat may be established between first computing device 2 and second computing device 22 when one of the computing devices 2 or 22 initiates text mode or sends text-based message 29 .
  • a text chat may be established between first computing device 2 and second computing device 22 when the real-time video communication is established between computing devices 2 and 22 .
  • user 14 may toggle between video mode and text mode to initiate either mode.
  • server 30 may facilitate instant messaging between the computing devices 2 , 22 , and 24 .
  • server 30 may route text message 29 sent from second computing device 22 to first computing device 2 during a real-time video conference between the computing devices 2 and 22 .
  • Any protocol or format compatible with text-based messages may be used for transferring text message 29 , such as, but not limited to Extensible Messaging and Presence Protocol (“XMPP”).
  • XMPP Extensible Messaging and Presence Protocol
  • Routing text message 29 through server 30 may enable a searchable text chat history to be stored.
  • server 30 stores at least a part of the text chat history between first computing device 2 and second computing device 22 .
  • server 30 may route communication data 26 between computing devices 2 and 22 in addition to text message 29 .
  • Display device 12 of first computing device 2 may display video data 28 .
  • display device 12 includes a touch-sensitive display 4 that may display video 18 when first computing device 2 is operating in video mode. As shown in FIG. 1 , video 18 may display an image of second user 15 from the video data 28 .
  • touch-sensitive display 4 may display a video corresponding to whichever user (e.g., second user 15 ) is currently speaking.
  • touch-sensitive display 4 may further display an overlay 16 .
  • Overlay 16 may be an image having any shape, size, coloration, or style that is overlaid on top of video 18 .
  • overlay 16 displays information related to text message 29 .
  • overlay 16 may display the textual content of the text message 29 . For example, if the text message 29 included the sentence “Hi, how are you?”, overlay 16 may display “Hi, how are you?” over the video 18 .
  • overlay 16 displays other information related to text message 29 , such as but not limited to, for example, a Uniform Resource Identifier (URI), a Uniform Resource Locator (URL), an image that was included with text message 29 , a link or option to download a file, or a request to upload a file.
  • URI Uniform Resource Identifier
  • URL Uniform Resource Locator
  • audio data 27 may further include speech (for example, user 15 is speaking)
  • Computing device 2 may convert at least a portion of the speech into text. If the speech is in a language other than a selected language (e.g., user 14 's native language, or the language computing device 2 may be set to), computing device 2 may translate the text into the selected language. Computing device 2 may overlay at least a portion of the text or, if applicable, the translated text, onto the video data displayed on the display device 4 . In one example, computing device 2 may display the text or translated text onto display device 4 as video data 28 is streaming.
  • a selected language e.g., user 14 's native language, or the language computing device 2 may be set to
  • computing device 2 may translate the text into the selected language.
  • Computing device 2 may overlay at least a portion of the text or, if applicable, the translated text, onto the video data displayed on the display device 4 .
  • computing device 2 may display the text or translated text onto display device 4 as video data 28 is streaming.
  • FIG. 2 is a block diagram illustrating further details of one example of computing device 2 shown in FIG. 1 .
  • FIG. 2 illustrates only one particular example of computing device 2 , and many other example embodiments of computing device 2 may be used in other instances.
  • computing device 2 includes one or more processors 50 , memory 52 , a network interface 34 , one or more storage devices 36 , one or more input devices 38 , one or more output devices 40 , and battery 42 .
  • Computing device 2 also includes an operating system 44 , which may include chat application 8 executable by computing device 2 .
  • Computing device 2 may include one or more applications 46 and chat application 8 .
  • Chat application 8 may include video chat module 6 and text chat module 10 executable by computing device 2 .
  • Operating system 44 , applications 46 and chat application 8 are also executable by computing device 2 .
  • Each of components 50 , 52 , 34 , 36 , 38 , 40 , 42 , 44 , 46 , 6 , 8 , and 10 may be interconnected (physically, communicatively, and/or operatively) for inter-component communications.
  • Processors 50 may be configured to implement functionality and/or process instructions for execution in computing device 2 .
  • Processors 50 may be capable of processing instructions stored in memory 52 or instructions stored on storage devices 36 .
  • Memory 52 may be configured to store information within computing device 2 during operation. Memory 52 may, in some examples, be described as a non-transitory computer-readable storage medium. In some examples, memory 52 is a temporary memory, meaning that a primary purpose of memory 52 is not long-term storage. Memory 52 may also, in some examples, be described as a volatile memory, meaning that memory 52 does not maintain stored contents when the computer is turned off. Examples of volatile memories include random access memories (RAM), dynamic random access memories (DRAM), static random access memories (SRAM), and other forms of volatile memories known in the art. In some examples, memory 52 may be used to store program instructions for execution by processors 50 . Memory 52 may be used by software or applications running on computing device 2 (e.g., one or more of applications 46 ) to temporarily store information during program execution.
  • RAM random access memories
  • DRAM dynamic random access memories
  • SRAM static random access memories
  • Storage devices 36 may also include one or more computer-readable storage media. Storage devices 36 may be configured to store larger amounts of information than memory 32 . Storage devices 36 may further be configured for long-term storage of information. In some examples, storage devices 36 may include non-volatile storage elements. Examples of such non-volatile storage elements may include magnetic hard discs, optical discs, floppy discs, flash memories, or forms of electrically programmable memories (EPROM) or electrically erasable and programmable (EEPROM) memories.
  • EPROM electrically programmable memories
  • EEPROM electrically erasable and programmable
  • Computing device 2 also includes a network interface 34 .
  • Computing device 2 may utilize network interface 34 to communicate with external devices via one or more networks, such as network 32 .
  • network interface 34 may correspond to an interface for receiving data from computing devices (e.g., computing devices 22 and 24 of FIG. 1 ).
  • input and output network interfaces 34 may be functionally integrated, while in other examples, input and output interfaces may be separate interfaces of network interface 34 .
  • Network interface 34 may be a network interface card, such as an Ethernet card, configured to communication over, for example, Ethernet, transmission control protocol (TCP), Internet protocol (IP), asynchronous transfer mode (ATM), or other network communication protocols.
  • TCP transmission control protocol
  • IP Internet protocol
  • ATM asynchronous transfer mode
  • network interface 34 may be an optical transceiver, a radio frequency transceiver, or any other type of device that can send and receive information. Examples of such network interfaces may include Bluetooth®, 3G and WiFi® radios in mobile computing devices as well as USB. Examples of such wireless networks may include WiFi®, Bluetooth®, and 3G.
  • computing device 2 may utilize network interface 34 to wirelessly communicate with an external device, such as server 30 , a mobile phone, or other networked computing device. In some examples, computing device 2 may include a plurality of either or both input and output interfaces.
  • Computing device 2 may also include one or more input devices 38 .
  • Input device 38 may be configured to receive input from user 14 through tactile, audio, or video feedback.
  • Examples of input device 38 may include a touch-sensitive display, mouse, a keyboard, a voice responsive system, a microphone, video camera 16 , or any other type of device for detecting a command from user 14 .
  • One or more output devices 40 may also be included in computing device 2 , e.g., display device 12 .
  • Output device 40 may be configured to provide output to a user using tactile, audio, or video stimuli.
  • Output device 40 may include a touch-sensitive display, a sound card, a video graphics adapter card, or any other type of device for converting a signal into an appropriate form understandable to humans or machines.
  • Additional examples of output device 40 may include a speaker, a cathode ray tube (CRT) monitor, a liquid crystal display (LCD), or any other type of device that can provide output to user 14 .
  • CTR cathode ray tube
  • LCD liquid crystal display
  • Computing device 2 may include one or more batteries 42 , which may be rechargeable and provide power to computing device 2 .
  • Battery 42 may be made from nickel-cadmium, lithium-ion, or any other suitable material.
  • Computing device 2 may include operating system 44 .
  • Operating system 44 may control the operation of components of computing device 2 .
  • operating system 44 may facilitate the interaction of application 46 or chat application 8 with processors 50 , memory 52 , network interface 34 , storage device 36 , input device 38 , output device 40 , and battery 42 .
  • Examples of operating system 44 may include Android®, Apple iOS®, Blackberry® OS, Symbian OS®, Linux®, Microsoft Windows Phone 7®, or the like.
  • Chat application 8 may additionally include video chat module 6 and text chat module 10 , which may be executed as part of operating system 44 .
  • video chat module 6 and text chat module 10 may be implemented or executed by computing device 2 .
  • Video chat module 6 may process video data, e.g., video data 28 received from second computing device 22 , and may operate first computing device 2 in video mode.
  • text chat module 10 may process text data, e.g., text message 29 received from second computing device 22 , and may operate first computing device 2 in text mode.
  • video chat module 6 and text chat module 10 may receive input from a component such as processors 50 , memory 52 , network interface 34 , storage devices 36 , one or more output devices 40 , battery 42 , or operating system 44 .
  • video chat module 6 and text chat module 10 may perform additional processing on communication data 26 .
  • video chat module 6 or text chat module 10 may transmit input to an application, e.g. application 46 , or other component in computing device 2 .
  • Any applications, e.g. application 46 or chat application 8 , implemented within or executed by computing device 2 may be implemented or contained within, operable by, executed by, and/or be operatively/communicatively coupled to components of computing device 2 , e.g., processors 50 , memory 52 , network interface 34 , and/or storage devices 36 .
  • FIG. 3 is a flow chart illustrating an exemplary method that may be performed by a computing device to overlay at least a portion of a text message onto a video chat, in accordance with one or more aspects of the present disclosure.
  • method 60 may be performed by computing devices 2 , 22 , or 24 shown in FIG. 1 or 2 .
  • method 60 may display at least a portion of the text message without interrupting the video chat.
  • Method 60 includes receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data ( 62 ).
  • first computing device 2 and second computing device 22 may be engaged in a real-time video communication and may be exchanging video data 28 .
  • Method 60 further includes displaying the video data on a screen of the first computing device ( 64 ).
  • first computing device 2 displays video 18 of second user 15 on touch-sensitive display 4 .
  • method 60 further includes receiving a text-based message at the first computing device that is sent from the second computing device during the video communication ( 66 ).
  • second computing device 22 sends text message 29 to first computing device 2 .
  • Method 60 may also include overlaying information related to the text-based message over the video data displayed on the screen of the first computing device ( 68 ).
  • first computing device 2 may display overlay 16 containing at least a portion of text message 29 over video 18 .
  • another computing device not engaged in the real-time video communication sends the first computing device a text message. In that example, at least a portion of the text message is overlaid on the video data from the second computing device.
  • the information related to the text-based message may be at least one of a textual content of the text-based message, a Uniform Resource Identifier (URI), an image, a link to a file, and combinations thereof.
  • overlaying the information related to the text-based message over the video data may further include displaying an overlay over the video data that contains text from the text-based message, wherein at least a portion of the overlay corresponds to a touch-target.
  • the overlay may further provides a graphical user indication identifying that the text-based message is sent from the second computing device.
  • method 60 further includes providing a touch-target on the display that, when activated by a user, toggles the first computing device between operating in an video mode and a text mode, wherein the display comprises a touch-sensitive display.
  • the touch-target when activated, further performs an action related to the text-based message.
  • the information related to the text-based message may be a Uniform Resource Locator (URL) link, and the action related to the text-based message may link the user to a webpage corresponding to the URL link.
  • the touch-target when activated by the user while the first computing device is in the video mode, may bypass the text mode to perform the action related to the text-based message.
  • method 60 further includes switching the first computing device into text mode when the touch-target is activated.
  • method 60 includes providing an operation indication to the second computing device that the first computing device is operating in text mode when the first computing device switches to text mode.
  • method 60 further includes disabling a camera of the first computing device when the first computing device switches to text mode.
  • method 60 may include displaying a smaller view of the video data when the first computing device is operating in text mode.
  • method 60 may also include outputting first audio data at the first computing device, wherein the communication data comprises the first audio data and sending second audio data from the first computing device to the second computing device during the real-time video communication while the first computing device is operating in text mode.
  • method 60 may include buffering, by the first computing device, the video data while the first computing device is operating in text mode.
  • At least a third computing device may be participating in the real-time video communication between the first computing device and the second computing device.
  • method 60 may further include receiving a second text-based message at the first computing device that is sent from the third computing device during the real-time video communication.
  • Method 60 may further include overlaying information related to the second text-based message onto the video data displayed on the display of the first computing device.
  • Method 60 may additionally include graphically indicating that the information related to the first text-based message is sent from the second computing device and graphically indicating that the information related to the second text-based message is sent from the third computing device.
  • method 60 may include removing the information related to the text-based message from the display after a selected timeout period.
  • receiving the communication data may further include receiving the communication data over a peer-to-peer connection between the first computing device and the second computing device.
  • receiving the text-based message may further include receiving the text-based message from a server communicatively coupled to the first computing device and to the second computing device.
  • receiving communication data may further include receiving the communication data from the server.
  • the communication data may further include audio data that has speech.
  • method 60 further includes converting at least a portion of the speech into text.
  • method 60 further includes translating the text into the selected language.
  • method 60 further includes overlaying at least a portion of the text onto the video data displayed on the display of the first computing device.
  • FIG. 4A is a block diagram illustrating one example of a computing device 2 operating in a video mode displaying a text-based message in an overlay 72 , in accordance with one or more aspects of the present disclosure.
  • Computing device 2 includes a touch-sensitive display 70 .
  • computing device 2 may be engaged in a real-time video communication with another computing device, such as second computing device 22 used by second user 15 .
  • Computing device 2 has received a text message 74 from second user 15 .
  • Touch-sensitive display 70 may display video 18 received from second computing device 22 . Additionally, touch-sensitive display 70 may display a camera display 78 . Camera display 78 may be an image that first computing device 2 is providing to second computing device 22 , for example, via input to camera 16 . Camera display 78 may be a small video overlay placed over video 18 in order to aid user 14 in properly framing camera 16 .
  • Overlay 72 may be an image overlaid on top of video 18 . Overlay 72 may be positioned anywhere on touch-sensitive display 70 . Overlay 72 may contain a portion of or the entire textual content of text message 74 , a URL link, a link to download a file, a link to initiate an action, or any other text-based content that conveys information. Overlay 72 may contain information related to received text message 74 , as in the example of FIG. 4A , the message “Here's that URL: http://www.google.com/talk/”. Text message 74 contains a URL 76 that links to a website or webpage. Overlay 72 may further comprise a user indication 80 that may indicate which user in the real-time video communication sent text message 74 . As shown in FIG. 4A , second user 15 sent text message 74 . User 14 may be able to receive information relating to text message 74 without interrupting the video chat.
  • a touch target 82 may be an image or icon displayed on touch-sensitive display 70 that, when activated by a user, causes computing device 2 to perform an action.
  • User 14 may activate the touch target 82 by touching touch-sensitive display 70 where touch target 82 is located, or otherwise performing some gesture on touch-sensitive display 70 .
  • user 14 may activate touch target 82 by tapping anywhere on touch-sensitive display 70 where overlay 72 is displayed.
  • Activating touch target 82 may cause computing device 2 to perform an action related to text message 74 .
  • touching touch target 82 may change the operating mode of computing device 2 (e.g., chat application 8 ) from video mode to text mode.
  • text mode user 14 may be able to respond to text message 74 .
  • touching touch target 82 may perform another action while bypassing text mode.
  • activating touch target 82 may link user 14 directly to a webpage corresponding to URL 76 without going into text mode. Text mode is described in more detail with respect to FIG. 4B .
  • activating touch target 82 initiates a file transfer, selects a virtual button, or the like.
  • touch-sensitive display 70 may also display information relating to a second text message corresponding to another user.
  • the information relating to the second text message may include a user indication 80 describing which user sent the second text message.
  • the user indication 80 may be a callout displaying a name appended to the text message in overlay 72 or may consist of displaying text message 74 in a unique color assigned to the user who sent text message 74 .
  • touch-sensitive display 70 may include an overlay containing identification information for each participant in the chat. In yet another example, such an overlay may provide status information for each participant, including, for example, what mode each user is in, whether the user is currently speaking, whether the user is currently available, etc.
  • text messages may be displayed in overlay 72 in chronological order.
  • a plurality of text messages may be displayed in a plurality of overlay boxes.
  • text message 74 is faded out or otherwise removed from overlay 72 after a selected timeout period has expired (e.g., after being displayed for 30 seconds).
  • user 14 may remove the overlay before the selected timeout period by tapping the display device 4 in an area outside of overlay 72 .
  • Any method or style of displaying and removing text message 74 in overlay 72 is contemplated herein.
  • overlay 72 may be an approximately rectangular shape having an opaque, darkened background with lighter text.
  • text message 74 may be saved in a cache.
  • text message 74 may be removed from the cache when a selected decay period expires.
  • text message 74 may be removed from the cache upon the occurrence of a triggering action.
  • the triggering action may include ending the text chat, ending the video chat, user 14 selecting a delete option, an additional participant joining either the text chat or video chat, or the like.
  • a camera corresponding to computing device 2 may be active and transmitting an image to second computing device 22 .
  • a microphone corresponding to computing device 2 may be active and transmitting sound to second computing device 22 during video mode.
  • the microphone may be inactive and not transmitting sound to second computing device 22 during video mode, if, for example, user 14 is not speaking.
  • Computing device 2 may also provide an operation indication signal to second computing device 22 indicating that computing device 2 is operating in video mode.
  • FIG. 4B is a block diagram illustrating one example of a computing device operating in a text mode during a real-time video communication, in accordance with one or more aspects of the present disclosure.
  • text mode computing device 2 may still be engaged in a video chat.
  • text mode allows user 14 to compose and send a text message 84 , which may be in response to a previous text message, such as text message 74 .
  • touch sensitive screen 70 may provide a text input area 86 for user 14 to input text.
  • text input area 86 may be a virtual keyboard or an area to input handwriting.
  • touch sensitive screen 70 may display previously received text messages, such as text message 74 .
  • touch sensitive screen 70 may display a touch target 88 that may be used to switch computing device 2 into video mode.
  • touch target 88 may be an icon showing video data from second computing device 22 .
  • touch target 88 may be a block indicating that, when activated, computing device 2 may operate in video mode.
  • touch sensitive screen 70 may display a smaller view of video data 28 when the first computing device 2 is operating in a mode other than video mode (e.g., in text mode).
  • touch-sensitive display 4 does not display video data 28 when first computing device 2 is operating in text mode.
  • computing device 2 may pause and buffer the received video data while in text mode.
  • the buffered video may be available for playback.
  • user 14 may select to playback the buffered video once computing device 2 is back in video mode.
  • computing device 2 does not buffer the received video data during text mode.
  • computing device 2 while operating in text mode, outputs first audio data received from the second computing device 22 and sends second audio data generated by the computing device 2 to the second computing device 22 .
  • microphone 38 may be inactive during text mode.
  • computing device 2 provides user 14 with an option regarding whether camera 16 or microphone 38 should be active or inactive during text mode.
  • Computing device 2 may also provide an operation indication signal to second computing device 22 indicating that computing device 2 is operating in text mode.
  • computing device 2 may provide a signal to second computing device 22 indicating that camera 16 is off while in text mode.
  • computing device 2 may switch to video mode and activate camera 16 .
  • Techniques of the present disclosure may allow a user to receive text messages without interrupting a real-time video conference. This allows users of mobile devices, such as those with small screens, to participate in video chat and instant messaging. Techniques described herein may enable a text signal to be presented simultaneously with a streaming video on a mobile device. Other techniques of the present disclosure may allow a user to switch between a video mode and a text mode for communicating via video chat or text chat, respectively, without interrupting either the video chat or the text chat. Techniques of the present disclosure extend to conference calls with more than two participating computing devices. A display may be altered based on how many participants are in a given conference call.
  • processors including one or more microprocessors, digital signal processors (DSPs), application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), or any other equivalent integrated or discrete logic circuitry, as well as any combinations of such components.
  • DSPs digital signal processors
  • ASICs application specific integrated circuits
  • FPGAs field programmable gate arrays
  • processors may generally refer to any of the foregoing logic circuitry, alone or in combination with other logic circuitry, or any other equivalent circuitry.
  • a control unit including hardware may also perform one or more of the techniques of this disclosure.
  • Such hardware, software, and firmware may be implemented within the same device or within separate devices to support the various techniques described herein.
  • any of the described units, modules or components may be implemented together or separately as discrete but interoperable logic devices. Depiction of different features as modules or units is intended to highlight different functional aspects and does not necessarily imply that such modules or units are realized by separate hardware, firmware, or software components. Rather, functionality associated with one or more modules or units may be performed by separate hardware, firmware, or software components, or integrated within common or separate hardware, firmware, or software components.
  • Techniques described herein may also be embodied or encoded in an article of manufacture including a computer-readable storage medium encoded with instructions. Instructions embedded or encoded in an article of manufacture including an encoded computer-readable storage medium, may cause one or more programmable processors, or other processors, to implement one or more of the techniques described herein, such as when instructions included or encoded in the computer-readable storage medium are executed by the one or more processors.
  • Computer readable storage media may include random access memory (RAM), read only memory (ROM), programmable read only memory (PROM), erasable programmable read only memory (EPROM), electronically erasable programmable read only memory (EEPROM), flash memory, a hard disk, a compact disc ROM (CD-ROM), a floppy disk, a cassette, magnetic media, optical media, or other computer readable media.
  • RAM random access memory
  • ROM read only memory
  • PROM programmable read only memory
  • EPROM erasable programmable read only memory
  • EEPROM electronically erasable programmable read only memory
  • flash memory a hard disk, a compact disc ROM (CD-ROM), a floppy disk, a cassette, magnetic media, optical media, or other computer readable media.
  • an article of manufacture may comprise one or more computer-readable storage media.

Abstract

In general, this disclosure describes techniques for overlaying information related to a text message onto a video. In one example, a method includes receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data. The method also includes displaying the video data on a display of the first computing device and receiving a text-based message at the first computing device that is sent from the second computing device during the real-time video communication. The method further includes overlaying information related to the text-based message onto the video data displayed on the display of the first computing device.

Description

This application is a continuation of U.S. application Ser. No. 13/019,203, filed Feb. 1, 2011, which is assigned to the assignee hereof and is hereby expressly incorporated by reference herein.
TECHNICAL FIELD
The disclosure relates to instant messaging and video chat communications between computing devices.
BACKGROUND
Two or more users of computing devices may often engage in real-time video communications, such as video conferencing, where the users exchange live video and audio transmissions (referred to herein as “video chat”). Sometimes, a first user may wish to send a text-based message (referred to herein as “text chat”) to a second user during the video chat. When the second user is using a computing device with a relatively small screen (such as a mobile phone, PDA, tablet computer, or other mobile device), there is little available room to display the text chat, such that the second user may be unable to receive the text-based message during the video chat.
SUMMARY
In one example, a method includes, receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data; displaying the video data on a display of the first computing device; receiving a text-based message at the first computing device that is sent from the second computing device during the real-time video communication; and overlaying information related to the text-based message onto the video data displayed on the display of the first computing device.
In another example, a non-transitory computer-readable medium is encoded with instructions for causing a programmable processor to perform operations including: receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data; displaying the video data on a display of the first computing device; receiving a text-based message at the first computing device during the real-time video communication; and overlaying information related to the text-based message onto the video data displayed on the display of the first computing device.
In one example, a computing device includes one or more processors. The computing device further includes a network interface to receive communication data from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises audio data and video data, and an output device that displays the video data. The computing device further includes means for overlaying, onto the displayed video data, a text-based message received from the second computing device by the computing device during the real-time video communication.
The details of one or more aspects of the disclosure are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the disclosure will be apparent from the description and drawings, and from the claims.
BRIEF DESCRIPTION OF DRAWINGS
FIG. 1 is a block diagram illustrating an example of a computing device that may execute one or more applications and receive a text message during a video chat, in accordance with one or more aspects of the present disclosure.
FIG. 2 is a block diagram illustrating further details of one example of the computing device shown in FIG. 1, in accordance with one or more aspects of the present disclosure.
FIG. 3 is a flow chart illustrating an exemplary method that may be performed by a computing device to overlay at least a portion of a text message onto a video chat, in accordance with one or more aspects of the present disclosure.
FIG. 4A is a block diagram illustrating one example of a computing device operating in a video mode displaying a text-based message in an overlay box, in accordance with one or more aspects of the present disclosure.
FIG. 4B is a block diagram illustrating one example of computing device operating in a text mode during a real-time video communication, in accordance with one or more aspects of the present disclosure.
In accordance with common practice, the various described features are not drawn to scale and are drawn to emphasize features relevant to the present invention. Like reference characters denote like elements throughout the figures and text.
DETAILED DESCRIPTION
Techniques of the present disclosure allow a computing device to display at least a portion of a text message while simultaneously displaying a video chat, without interrupting the video chat. A first user of a first computing device, for example, a mobile device, may correspond with a second user of a second computing device over a real-time video communication. The first computing device may include a touch-sensitive display in which a video stream from the second user is displayed. The second user, or another user not participating in the video chat, may compose and send a text message to the first user during the real-time video communication. The content of the text message may be displayed as an overlay on the video without interrupting the video. In some examples, the text message is displayed in an interactive overlay box. The first user may interact with the overlay box to switch the computing device between different operating modes or to perform an action related to the text message.
FIG. 1 is a block diagram illustrating an example of a computing device 2 that may execute one or more applications (e.g., chat application 8) and receive a text message 29 during a video chat, in accordance with one or more aspects of the present disclosure. Computing device 2 may, in some examples, include or be part of a portable computing device (e.g., a mobile phone, netbook, laptop, personal data assistant (PDA), tablet device, portable gaming device, portable media player, e-book reader, or a watch) as well as non-portable devices (e.g., a desktop computer). For purposes of illustration only, in this disclosure, computing device 2 is described as a portable or mobile device that a user 14 can carry, such as a laptop, or a desktop computer, but aspects of this disclosure should not be considered limited to such devices.
Computing device 2 may include a display device 12 (e.g., a touch-sensitive device), one or more input devices 38 (e.g., a microphone), a camera 16, and one or more output devices 40 (e.g., a speaker). In some examples, display device 12 may comprise a touch-sensitive display 4. In some examples, touch-sensitive display 4 may be capable of receiving touch input from a user 14 (e.g., touch screen, track pad, track point, or the like). User 14 may interact with display device 12, for example, by performing touch input on touch-sensitive display 4. One example of computing device 2 is more fully described in FIG. 2, discussed below.
Computing device 2 may connect to a network 32, including a wired or wireless network, as well as to a server 30, via a network interface 34. Computing device 2 may connect to a second computing device 22 and a third computing device 24, or any other number of computing devices. Server 30 and computing devices 22 and 24 may be connected to network 32 via wired and/or wireless links. Computing devices 2, 22, and 24 may send data to or receive data from server 30 via network 32. Network 32 may include a wide-area network such as the Internet, a local-area network (LAN), an enterprise network, a wireless network, a cellular network, a telephony network, a Metropolitan area network (e.g., Wi-Fi, WAN, or WiMAX), one or more other types of networks, or a combination of two or more different types of networks (e.g., a combination of a cellular network and the Internet). Server 30 may be any of several different types of network devices. For instance, server 30 may be a conventional web server, specialized media server, personal computer operating in a peer-to-peer fashion, or other types of network devices.
Computing device 2 may be connected to second computing device 22 in a peer-to-peer fashion, either directly or through network 32. A peer-to-peer connection may be a network connection that partitions tasks or workloads between peers (e.g., first and second computing devices 2 and 22, respectively) without centralized coordination by a server (e.g., server 30). In the example shown in FIG. 1, first computing device 2 and second computing device 22 exchange communication data 26 via a peer-to-peer connection. In other examples, server 30 may provide conference calling capabilities in accordance with one aspect of this disclosure. For example, server 30 may manage a three-way video conference call with instant messaging capabilities between computing devices 2, 22, and 24.
Although the systems and techniques described herein support conferencing capabilities, for illustrative purposes only, FIG. 1 will be described in terms of a real-time video communication between first computing device 2 and second computing device 22. However, it is to be understood that the techniques and examples described in accordance with this disclosure apply to communications having more than two participants.
In FIG. 1, first computing device 2 and second computing device 22 have established a real-time video communication. User 14 operates first computing device 2 and a second user 15 operates the second computing device 22. As shown in FIG. 1, an image of second user 17 is displayed on touch-sensitive display 4 of first computing device 2. User 14 and second user 15 may be engaged in a video chat.
In one example, first computing device 2 and second computing device 22 exchange communication data 26, which may be streamed real-time. In some examples, communication data 26 may include video data 28 (e.g., from camera 16) and audio data 27 (e.g., from microphone 38). In some examples, video data 28 and audio data 27 may be transferred between first computing device 2 and second computing device 22 over different channels. In other examples, video data 28 and audio data 27 may be transferred over a single channel. In one example, communication data 26 may be transferred using an Real-time Transport Protocol (“RTP”) standard developed by the Internet Engineering Task Force (“IETF”). In examples using RTP, video data 28 may have a format such as H.263 or H.264. In other examples, other protocols or formats are used. In other examples, some or all of communication data 26 or text message 29 may be transferred encrypted, such as, for example, using Secure Real-time Transport Protocol (SRTP), or any other encrypted transfer protocol.
In one example, video data 28 and audio data 27 may be associated with each other (e.g., audio data 27 is diegetic to video data 28). In other examples, video data 28 and audio data 27 may not be associated with each other (e.g., audio data 27 is non-diegetic with video data 28, for example, a sound track is played along with video data 28). In some examples, communication data 26 may include both audio data 27 and video data 28; however, in other examples, communication data 26 may include only one of either audio data 27 or video data 28. Further, at any given moment during the real-time video communication, either of computing devices 2 and 22 may be sending only audio data 27, only video data 28, or both.
First computing device 2 includes a chat application 8 that, when executed, provides functionality to first computing device 2 to establish and maintain communications between one or more computing devices (e.g., second computing device 22). Chat application 8 may also provide signals to display device 12 to display information related to the communications and to enable user 14 to interact with chat application 8.
Chat application 8 may include a video chat module 6 and a text chat module 10. Video chat module 6, in various instances, provides first computing device 2 with capabilities to participate in a video conference between first computing device 2 and one or more computing devices. Text chat module 10, in various instances, provides first computing device 2 with capabilities to participate in a text-based conference between first computing device 2 and one or more computing devices. For example, text chat module 10 provides instant messaging capabilities between first computing device 2 and second computing device 22. In other examples, chat application 8 contains further communication modules having additional capabilities.
Chat application 8 may allow first computing device 2 to operate in a plurality of different modes. For example, video chat module 6 may correspond to a video mode, where received video data 28 may be displayed on computing device 2. In video mode, one or more cameras 16 and one or more other input devices 38 of first computing device 2 may be activated. For example, user 14 may point camera 16 at her or his face or another object of interest during video mode in order to transmit a video. Input device 38, such as a microphone, may record any sound incident to the microphone, such as user 14's voice. First computing device 2 may, in real-time, send this first video data from camera 16 and first audio data from input device 38 to second computing device 22.
Likewise, second computing device 22 sends second video data and second audio data from similar input devices to first computing device 2. During video mode, first computing device 2 may output some or all of this communication data 26, for example, with output devices 40 (e.g., a speaker) and display device 12. In some examples, first computing device 2 may switch between different cameras 16, such as a front-facing camera and a rear-facing camera. In further examples, audio data may not be streamed during video mode. In another example, multiple audio data may be streamed by first computing device 2. In other examples, video data may be sourced from a variety of inputs besides camera 16, such as, for example, a slideshow of pictures, a pre-recorded video feed, a screencast showing a window, or the like. Similarly, audio data may be sourced from any audio source, for example, a sound file stored on one of computing devices 2 or 22.
Text chat module 10 may correspond to a text mode, enabling user 14 to compose or send a text message, or to respond to text message 29 received by first computing device 2. That is, in one example, first computing device 2 may communicate with computing devices 22 and 24 via instant messaging or text chat. For example, while engaged in a real-time video communication with user 14, second user 15 desires to send an instant message to user 14. In one example, second user 15 types out, or otherwise inputs, a text-based message to user 14. This text-based message may then be sent to first computing device 2 as text message 29. Text message 29 may be any message that at least partially contains text-based information.
In some examples, a text chat may be established between first computing device 2 and second computing device 22 when one of the computing devices 2 or 22 initiates text mode or sends text-based message 29. In other examples, a text chat may be established between first computing device 2 and second computing device 22 when the real-time video communication is established between computing devices 2 and 22. In other examples, user 14 may toggle between video mode and text mode to initiate either mode.
In some examples, server 30 may facilitate instant messaging between the computing devices 2, 22, and 24. For example, server 30 may route text message 29 sent from second computing device 22 to first computing device 2 during a real-time video conference between the computing devices 2 and 22. Any protocol or format compatible with text-based messages may be used for transferring text message 29, such as, but not limited to Extensible Messaging and Presence Protocol (“XMPP”). Routing text message 29 through server 30 may enable a searchable text chat history to be stored. In one example, server 30 stores at least a part of the text chat history between first computing device 2 and second computing device 22. In further examples, server 30 may route communication data 26 between computing devices 2 and 22 in addition to text message 29.
Display device 12 of first computing device 2 may display video data 28. In one example, display device 12 includes a touch-sensitive display 4 that may display video 18 when first computing device 2 is operating in video mode. As shown in FIG. 1, video 18 may display an image of second user 15 from the video data 28. In conference call examples, touch-sensitive display 4 may display a video corresponding to whichever user (e.g., second user 15) is currently speaking.
In addition to displaying video 18 during video mode, touch-sensitive display 4 may further display an overlay 16. Overlay 16 may be an image having any shape, size, coloration, or style that is overlaid on top of video 18. In one example, overlay 16 displays information related to text message 29. For example, overlay 16 may display the textual content of the text message 29. For example, if the text message 29 included the sentence “Hi, how are you?”, overlay 16 may display “Hi, how are you?” over the video 18. In other examples, overlay 16 displays other information related to text message 29, such as but not limited to, for example, a Uniform Resource Identifier (URI), a Uniform Resource Locator (URL), an image that was included with text message 29, a link or option to download a file, or a request to upload a file.
In yet another example, audio data 27 may further include speech (for example, user 15 is speaking) Computing device 2 may convert at least a portion of the speech into text. If the speech is in a language other than a selected language (e.g., user 14's native language, or the language computing device 2 may be set to), computing device 2 may translate the text into the selected language. Computing device 2 may overlay at least a portion of the text or, if applicable, the translated text, onto the video data displayed on the display device 4. In one example, computing device 2 may display the text or translated text onto display device 4 as video data 28 is streaming.
FIG. 2 is a block diagram illustrating further details of one example of computing device 2 shown in FIG. 1. FIG. 2 illustrates only one particular example of computing device 2, and many other example embodiments of computing device 2 may be used in other instances.
As shown in the specific example of FIG. 2, computing device 2 includes one or more processors 50, memory 52, a network interface 34, one or more storage devices 36, one or more input devices 38, one or more output devices 40, and battery 42. Computing device 2 also includes an operating system 44, which may include chat application 8 executable by computing device 2. Computing device 2 may include one or more applications 46 and chat application 8. Chat application 8 may include video chat module 6 and text chat module 10 executable by computing device 2. Operating system 44, applications 46 and chat application 8 are also executable by computing device 2. Each of components 50, 52, 34, 36, 38, 40, 42, 44, 46, 6, 8, and 10 may be interconnected (physically, communicatively, and/or operatively) for inter-component communications.
Processors 50 may be configured to implement functionality and/or process instructions for execution in computing device 2. Processors 50 may be capable of processing instructions stored in memory 52 or instructions stored on storage devices 36.
Memory 52 may be configured to store information within computing device 2 during operation. Memory 52 may, in some examples, be described as a non-transitory computer-readable storage medium. In some examples, memory 52 is a temporary memory, meaning that a primary purpose of memory 52 is not long-term storage. Memory 52 may also, in some examples, be described as a volatile memory, meaning that memory 52 does not maintain stored contents when the computer is turned off. Examples of volatile memories include random access memories (RAM), dynamic random access memories (DRAM), static random access memories (SRAM), and other forms of volatile memories known in the art. In some examples, memory 52 may be used to store program instructions for execution by processors 50. Memory 52 may be used by software or applications running on computing device 2 (e.g., one or more of applications 46) to temporarily store information during program execution.
Storage devices 36 may also include one or more computer-readable storage media. Storage devices 36 may be configured to store larger amounts of information than memory 32. Storage devices 36 may further be configured for long-term storage of information. In some examples, storage devices 36 may include non-volatile storage elements. Examples of such non-volatile storage elements may include magnetic hard discs, optical discs, floppy discs, flash memories, or forms of electrically programmable memories (EPROM) or electrically erasable and programmable (EEPROM) memories.
Computing device 2 also includes a network interface 34. Computing device 2 may utilize network interface 34 to communicate with external devices via one or more networks, such as network 32. In one example, network interface 34 may correspond to an interface for receiving data from computing devices (e.g., computing devices 22 and 24 of FIG. 1). In some examples, input and output network interfaces 34 may be functionally integrated, while in other examples, input and output interfaces may be separate interfaces of network interface 34. Network interface 34 may be a network interface card, such as an Ethernet card, configured to communication over, for example, Ethernet, transmission control protocol (TCP), Internet protocol (IP), asynchronous transfer mode (ATM), or other network communication protocols. In other examples, network interface 34 may be an optical transceiver, a radio frequency transceiver, or any other type of device that can send and receive information. Examples of such network interfaces may include Bluetooth®, 3G and WiFi® radios in mobile computing devices as well as USB. Examples of such wireless networks may include WiFi®, Bluetooth®, and 3G. In some examples, computing device 2 may utilize network interface 34 to wirelessly communicate with an external device, such as server 30, a mobile phone, or other networked computing device. In some examples, computing device 2 may include a plurality of either or both input and output interfaces.
Computing device 2 may also include one or more input devices 38. Input device 38 may be configured to receive input from user 14 through tactile, audio, or video feedback. Examples of input device 38 may include a touch-sensitive display, mouse, a keyboard, a voice responsive system, a microphone, video camera 16, or any other type of device for detecting a command from user 14.
One or more output devices 40 may also be included in computing device 2, e.g., display device 12. Output device 40 may be configured to provide output to a user using tactile, audio, or video stimuli. Output device 40 may include a touch-sensitive display, a sound card, a video graphics adapter card, or any other type of device for converting a signal into an appropriate form understandable to humans or machines. Additional examples of output device 40 may include a speaker, a cathode ray tube (CRT) monitor, a liquid crystal display (LCD), or any other type of device that can provide output to user 14.
Computing device 2 may include one or more batteries 42, which may be rechargeable and provide power to computing device 2. Battery 42 may be made from nickel-cadmium, lithium-ion, or any other suitable material.
Computing device 2 may include operating system 44. Operating system 44 may control the operation of components of computing device 2. For example, operating system 44 may facilitate the interaction of application 46 or chat application 8 with processors 50, memory 52, network interface 34, storage device 36, input device 38, output device 40, and battery 42. Examples of operating system 44 may include Android®, Apple iOS®, Blackberry® OS, Symbian OS®, Linux®, Microsoft Windows Phone 7®, or the like.
Chat application 8 may additionally include video chat module 6 and text chat module 10, which may be executed as part of operating system 44. In other cases, video chat module 6 and text chat module 10 may be implemented or executed by computing device 2. Video chat module 6 may process video data, e.g., video data 28 received from second computing device 22, and may operate first computing device 2 in video mode. Similarly, text chat module 10 may process text data, e.g., text message 29 received from second computing device 22, and may operate first computing device 2 in text mode. Additionally, video chat module 6 and text chat module 10 may receive input from a component such as processors 50, memory 52, network interface 34, storage devices 36, one or more output devices 40, battery 42, or operating system 44. In some cases, video chat module 6 and text chat module 10 may perform additional processing on communication data 26. In other cases, video chat module 6 or text chat module 10 may transmit input to an application, e.g. application 46, or other component in computing device 2.
Any applications, e.g. application 46 or chat application 8, implemented within or executed by computing device 2 may be implemented or contained within, operable by, executed by, and/or be operatively/communicatively coupled to components of computing device 2, e.g., processors 50, memory 52, network interface 34, and/or storage devices 36.
FIG. 3 is a flow chart illustrating an exemplary method that may be performed by a computing device to overlay at least a portion of a text message onto a video chat, in accordance with one or more aspects of the present disclosure. For example, method 60 may be performed by computing devices 2, 22, or 24 shown in FIG. 1 or 2. In one example, method 60 may display at least a portion of the text message without interrupting the video chat.
Method 60 includes receiving communication data at a first computing device that is sent from a second computing device while the first and second computing devices are engaged in a real-time video communication, wherein the communication data comprises video data (62). For example, first computing device 2 and second computing device 22 may be engaged in a real-time video communication and may be exchanging video data 28. Method 60 further includes displaying the video data on a screen of the first computing device (64). For example, first computing device 2 displays video 18 of second user 15 on touch-sensitive display 4.
In this example, method 60 further includes receiving a text-based message at the first computing device that is sent from the second computing device during the video communication (66). For example, second computing device 22 sends text message 29 to first computing device 2. Method 60 may also include overlaying information related to the text-based message over the video data displayed on the screen of the first computing device (68). For example, first computing device 2 may display overlay 16 containing at least a portion of text message 29 over video 18. In another example, another computing device not engaged in the real-time video communication sends the first computing device a text message. In that example, at least a portion of the text message is overlaid on the video data from the second computing device.
In another example, the information related to the text-based message may be at least one of a textual content of the text-based message, a Uniform Resource Identifier (URI), an image, a link to a file, and combinations thereof. In one example, overlaying the information related to the text-based message over the video data may further include displaying an overlay over the video data that contains text from the text-based message, wherein at least a portion of the overlay corresponds to a touch-target. In another example, the overlay may further provides a graphical user indication identifying that the text-based message is sent from the second computing device.
In another example, method 60 further includes providing a touch-target on the display that, when activated by a user, toggles the first computing device between operating in an video mode and a text mode, wherein the display comprises a touch-sensitive display. In one example, the touch-target, when activated, further performs an action related to the text-based message. In yet another example, the information related to the text-based message may be a Uniform Resource Locator (URL) link, and the action related to the text-based message may link the user to a webpage corresponding to the URL link. In a further example, the touch-target, when activated by the user while the first computing device is in the video mode, may bypass the text mode to perform the action related to the text-based message.
In another example, method 60 further includes switching the first computing device into text mode when the touch-target is activated. In yet another example, method 60 includes providing an operation indication to the second computing device that the first computing device is operating in text mode when the first computing device switches to text mode. In one example, method 60 further includes disabling a camera of the first computing device when the first computing device switches to text mode. In a further example, method 60 may include displaying a smaller view of the video data when the first computing device is operating in text mode. In another example, method 60 may also include outputting first audio data at the first computing device, wherein the communication data comprises the first audio data and sending second audio data from the first computing device to the second computing device during the real-time video communication while the first computing device is operating in text mode. In a further example, method 60 may include buffering, by the first computing device, the video data while the first computing device is operating in text mode.
In another example, at least a third computing device may be participating in the real-time video communication between the first computing device and the second computing device. In such an example, method 60 may further include receiving a second text-based message at the first computing device that is sent from the third computing device during the real-time video communication. Method 60 may further include overlaying information related to the second text-based message onto the video data displayed on the display of the first computing device. Method 60 may additionally include graphically indicating that the information related to the first text-based message is sent from the second computing device and graphically indicating that the information related to the second text-based message is sent from the third computing device.
In yet another example, method 60 may include removing the information related to the text-based message from the display after a selected timeout period. In a further example, receiving the communication data may further include receiving the communication data over a peer-to-peer connection between the first computing device and the second computing device. In another example, receiving the text-based message may further include receiving the text-based message from a server communicatively coupled to the first computing device and to the second computing device. In yet another example, receiving communication data may further include receiving the communication data from the server.
In yet another example, the communication data may further include audio data that has speech. In one example, method 60 further includes converting at least a portion of the speech into text. When the speech is in a language other than a selected language (e.g., user 14's native language), method 60 further includes translating the text into the selected language. In another example, method 60 further includes overlaying at least a portion of the text onto the video data displayed on the display of the first computing device.
FIG. 4A is a block diagram illustrating one example of a computing device 2 operating in a video mode displaying a text-based message in an overlay 72, in accordance with one or more aspects of the present disclosure. Computing device 2 includes a touch-sensitive display 70. In the example of FIG. 4A, computing device 2 may be engaged in a real-time video communication with another computing device, such as second computing device 22 used by second user 15. Computing device 2 has received a text message 74 from second user 15.
Touch-sensitive display 70 may display video 18 received from second computing device 22. Additionally, touch-sensitive display 70 may display a camera display 78. Camera display 78 may be an image that first computing device 2 is providing to second computing device 22, for example, via input to camera 16. Camera display 78 may be a small video overlay placed over video 18 in order to aid user 14 in properly framing camera 16.
Overlay 72 may be an image overlaid on top of video 18. Overlay 72 may be positioned anywhere on touch-sensitive display 70. Overlay 72 may contain a portion of or the entire textual content of text message 74, a URL link, a link to download a file, a link to initiate an action, or any other text-based content that conveys information. Overlay 72 may contain information related to received text message 74, as in the example of FIG. 4A, the message “Here's that URL: http://www.google.com/talk/”. Text message 74 contains a URL 76 that links to a website or webpage. Overlay 72 may further comprise a user indication 80 that may indicate which user in the real-time video communication sent text message 74. As shown in FIG. 4A, second user 15 sent text message 74. User 14 may be able to receive information relating to text message 74 without interrupting the video chat.
At least a portion of overlay 72 may correspond to a touch target 82. A touch target 82 may be an image or icon displayed on touch-sensitive display 70 that, when activated by a user, causes computing device 2 to perform an action. User 14 may activate the touch target 82 by touching touch-sensitive display 70 where touch target 82 is located, or otherwise performing some gesture on touch-sensitive display 70. For example, user 14 may activate touch target 82 by tapping anywhere on touch-sensitive display 70 where overlay 72 is displayed.
Activating touch target 82 may cause computing device 2 to perform an action related to text message 74. In one example, touching touch target 82 may change the operating mode of computing device 2 (e.g., chat application 8) from video mode to text mode. In text mode, user 14 may be able to respond to text message 74. In another example, touching touch target 82 may perform another action while bypassing text mode. As shown in FIG. 4A, activating touch target 82 may link user 14 directly to a webpage corresponding to URL 76 without going into text mode. Text mode is described in more detail with respect to FIG. 4B. In another example, activating touch target 82 initiates a file transfer, selects a virtual button, or the like.
When the real-time video communication is a video conference between three or more participants, touch-sensitive display 70 may also display information relating to a second text message corresponding to another user. The information relating to the second text message may include a user indication 80 describing which user sent the second text message. In some examples, the user indication 80 may be a callout displaying a name appended to the text message in overlay 72 or may consist of displaying text message 74 in a unique color assigned to the user who sent text message 74. In another example, touch-sensitive display 70 may include an overlay containing identification information for each participant in the chat. In yet another example, such an overlay may provide status information for each participant, including, for example, what mode each user is in, whether the user is currently speaking, whether the user is currently available, etc.
In one example, text messages may be displayed in overlay 72 in chronological order. In another example, a plurality of text messages may be displayed in a plurality of overlay boxes. In yet another example, text message 74 is faded out or otherwise removed from overlay 72 after a selected timeout period has expired (e.g., after being displayed for 30 seconds). In another example, user 14 may remove the overlay before the selected timeout period by tapping the display device 4 in an area outside of overlay 72. Any method or style of displaying and removing text message 74 in overlay 72 is contemplated herein. For example, overlay 72 may be an approximately rectangular shape having an opaque, darkened background with lighter text.
In a further example, text message 74 may be saved in a cache. In another example, text message 74 may be removed from the cache when a selected decay period expires. In another example, text message 74 may be removed from the cache upon the occurrence of a triggering action. For example, the triggering action may include ending the text chat, ending the video chat, user 14 selecting a delete option, an additional participant joining either the text chat or video chat, or the like.
In video mode, a camera corresponding to computing device 2, such as camera 16, may be active and transmitting an image to second computing device 22. Furthermore, a microphone corresponding to computing device 2 may be active and transmitting sound to second computing device 22 during video mode. In another example, the microphone may be inactive and not transmitting sound to second computing device 22 during video mode, if, for example, user 14 is not speaking. Computing device 2 may also provide an operation indication signal to second computing device 22 indicating that computing device 2 is operating in video mode.
FIG. 4B is a block diagram illustrating one example of a computing device operating in a text mode during a real-time video communication, in accordance with one or more aspects of the present disclosure. In text mode, computing device 2 may still be engaged in a video chat. In some examples, text mode allows user 14 to compose and send a text message 84, which may be in response to a previous text message, such as text message 74. In text mode, touch sensitive screen 70 may provide a text input area 86 for user 14 to input text. For example, text input area 86 may be a virtual keyboard or an area to input handwriting.
In one example, in text mode, touch sensitive screen 70 may display previously received text messages, such as text message 74. In text mode, touch sensitive screen 70 may display a touch target 88 that may be used to switch computing device 2 into video mode. In one example, touch target 88 may be an icon showing video data from second computing device 22. In other examples, touch target 88 may be a block indicating that, when activated, computing device 2 may operate in video mode. In other examples, touch sensitive screen 70 may display a smaller view of video data 28 when the first computing device 2 is operating in a mode other than video mode (e.g., in text mode). In yet other examples, touch-sensitive display 4 does not display video data 28 when first computing device 2 is operating in text mode. In some examples, computing device 2 may pause and buffer the received video data while in text mode. In some examples, the buffered video may be available for playback. For example, user 14 may select to playback the buffered video once computing device 2 is back in video mode. In other examples, computing device 2 does not buffer the received video data during text mode.
In text mode, a camera corresponding to computing device 2, such as camera 16, may be inactive and not transmitting an image to second computing device 22. In other examples, camera 16 may remain active during text mode. For example, switching to text mode may cause computing device 2 to turn off camera 16 while continuing to send audio and output received audio. In such an example, a last frame sent from camera 16 before computing device 2 is toggled into text mode may be continued to be displayed on second computing device 22. Furthermore, a microphone corresponding to computing device 2, for example, microphone 38, may be active and transmitting sound to second computing device 22 during text mode. In one example, while operating in text mode, computing device 2 outputs first audio data received from the second computing device 22 and sends second audio data generated by the computing device 2 to the second computing device 22. In other examples, microphone 38 may be inactive during text mode. In some examples, computing device 2 provides user 14 with an option regarding whether camera 16 or microphone 38 should be active or inactive during text mode.
Computing device 2 may also provide an operation indication signal to second computing device 22 indicating that computing device 2 is operating in text mode. In another example, computing device 2 may provide a signal to second computing device 22 indicating that camera 16 is off while in text mode. When user 14 taps or otherwise activates touch target 88, computing device 2 may switch to video mode and activate camera 16.
Techniques of the present disclosure may allow a user to receive text messages without interrupting a real-time video conference. This allows users of mobile devices, such as those with small screens, to participate in video chat and instant messaging. Techniques described herein may enable a text signal to be presented simultaneously with a streaming video on a mobile device. Other techniques of the present disclosure may allow a user to switch between a video mode and a text mode for communicating via video chat or text chat, respectively, without interrupting either the video chat or the text chat. Techniques of the present disclosure extend to conference calls with more than two participating computing devices. A display may be altered based on how many participants are in a given conference call.
Techniques described herein may be implemented, at least in part, in hardware, software, firmware, or any combination thereof. For example, various aspects of the described embodiments may be implemented within one or more processors, including one or more microprocessors, digital signal processors (DSPs), application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), or any other equivalent integrated or discrete logic circuitry, as well as any combinations of such components. The term “processor” or “processing circuitry” may generally refer to any of the foregoing logic circuitry, alone or in combination with other logic circuitry, or any other equivalent circuitry. A control unit including hardware may also perform one or more of the techniques of this disclosure.
Such hardware, software, and firmware may be implemented within the same device or within separate devices to support the various techniques described herein. In addition, any of the described units, modules or components may be implemented together or separately as discrete but interoperable logic devices. Depiction of different features as modules or units is intended to highlight different functional aspects and does not necessarily imply that such modules or units are realized by separate hardware, firmware, or software components. Rather, functionality associated with one or more modules or units may be performed by separate hardware, firmware, or software components, or integrated within common or separate hardware, firmware, or software components.
Techniques described herein may also be embodied or encoded in an article of manufacture including a computer-readable storage medium encoded with instructions. Instructions embedded or encoded in an article of manufacture including an encoded computer-readable storage medium, may cause one or more programmable processors, or other processors, to implement one or more of the techniques described herein, such as when instructions included or encoded in the computer-readable storage medium are executed by the one or more processors. Computer readable storage media may include random access memory (RAM), read only memory (ROM), programmable read only memory (PROM), erasable programmable read only memory (EPROM), electronically erasable programmable read only memory (EEPROM), flash memory, a hard disk, a compact disc ROM (CD-ROM), a floppy disk, a cassette, magnetic media, optical media, or other computer readable media. In some examples, an article of manufacture may comprise one or more computer-readable storage media.
In some examples, computer-readable storage media may comprise non-transitory media. The term “non-transitory” is used to indicate that the storage medium is not embodied in a carrier wave or a propagated signal. In certain examples, a non-transitory storage medium may store data that can, over time, change (e.g., in RAM or cache).
Various aspects of the disclosure have been described. Aspects or features of examples described herein may be combined with any other aspect or feature described in another example. These and other embodiments are within the scope of the following claims.

Claims (15)

The invention claimed is:
1. A method, comprising:
receiving, by a first computing device, communication data sent from a second computing device while the first computing device and the second computing device are engaged in a real-time video communication session, wherein the communication data comprises first video data;
while the first computing device is operating in a video mode, outputting, by the first computing device and for display at a touch-sensitive display, the first video data;
receiving, by the first computing device, a text-based message from the second computing device during the real-time video communication session;
overlaying, by the first computing device and at the touch-sensitive display, information related to the text-based message onto a display of the first video data;
outputting, by the first computing device and for display at the touch-sensitive display, a touch target that, upon activation, toggles the first computing device between operating in the video mode and a text mode;
while the first computing device is operating in the video mode, receiving, by the first computing device, one or more activation signals indicating that the touch target is activated;
responsive to receiving the one or more activation signals while the first computing device is operating in the video mode, switching the first computing device to operate in the text mode and providing an operation indication to the second computing device indicating that the first computing device is operating in the text mode;
while the first computing device is operating in the text mode:
transmitting, by the first computing device and to the second computing device during the real-time video communication session, second video data provided by a camera of the first computing device;
buffering, by the first computing device, third video data that is received by the first computing device from the second computing device; and
after buffering the third video data, switching the first computing device to operate in the video mode; and
while the first computing device is operating in the video mode, outputting, by the first computing device and for display at the touch-sensitive display, the third video data.
2. The method of claim 1, wherein the information related to the text-based message comprises at least one of a textual content of the text-based message, a Uniform Resource Identifier (URI), an image, a link to a file, and combinations thereof.
3. The method of claim 1, wherein the first computing device, responsive to receiving the one or more activation signals, further performs an action related to the text-based message.
4. The method of claim 3, wherein the information related to the text-based message comprises a Uniform Resource Locator (URL) link, and wherein the action related to the text-based message opens a webpage addressed by the URL link.
5. The method of claim 1, further comprising:
outputting, by the first computing device, first audio data, wherein the communication data comprises the first audio data; and
while the first computing device is operating in the text mode, sending second audio data from the first computing device to the second computing device during the real-time video communication session.
6. The method of claim 1, wherein overlaying the information related to the text-based message over the display of the first video data further comprises providing an overlay over the display of the first video data that contains text from the text-based message, wherein at least a portion of the overlay corresponds to the touch target.
7. The method of claim 6, wherein the overlay further provides a graphical user indication indicating that the text-based message is sent from the second computing device.
8. The method of claim 1, wherein the communication data further comprises audio data including speech, the method further comprising:
converting at least a portion of the speech into text;
translating the text into translated text of the selected language; and
overlaying, by the first computing device and for display, at least a portion of the text or the translated text onto the display of the first video.
9. The method of claim 1, wherein the text-based message comprises a first text-based message, wherein at least a third computing device is further participating in the real-time video communication session between the first computing device and the second computing device, the method further comprising:
receiving, by the first computing device and during the real-time video communication session, a second text-based message sent from the third computing device;
overlaying, by the first computing device, information related to the second text-based message onto the display of the first video;
graphically indicating that the information related to the first text-based message is sent from the second computing device; and
graphically indicating that the information related to the second text-based message is sent from the third computing device.
10. The method of claim 1, further comprising:
removing, by the first computing device and from display, the information related to the text-based message after a selected timeout period.
11. The method of claim 1, wherein receiving the communication data further comprises receiving the communication data over a peer-to-peer connection between the first computing device and the second computing device.
12. The method of claim 1, wherein receiving the text-based message further comprises receiving the text-based message from a server communicatively coupled to the first computing device and to the second computing device.
13. The method of claim 12, wherein receiving the communication data further comprises receiving the communication data from the server.
14. A non-transitory computer-readable medium comprising instructions for causing at least one programmable processor to perform operations comprising:
receiving, by a first computing device, communication data that is sent from a second computing device while the first computing device and the second computing device are engaged in a real-time video communication session, wherein the communication data comprises first video data;
while the first computing device is operating in a video mode, outputting, by the first computing device and for display at a touch-sensitive display, the first video data;
receiving, by the first computing device and from the second computing device during the real-time video communication session, a text-based message;
overlaying, by the first computing device and at the touch-sensitive display, information related to the text-based message onto a display of the first video data;
outputting, by the first computing device and for display at the touch-sensitive display, a touch target that, upon activation, toggles the first computing device between operating in the video mode and a text mode;
while the first computing device is operating in the video mode, receiving, by the first computing device, one or more activation signals indicating that the touch target is activated;
responsive to receiving the one or more activation signals while the first computing device is operating in the video mode, switching the first computing device into the text mode and providing an operation indication to the second computing device indicating that the first computing device is operating in the text mode;
while the first computing device is operating in the text mode:
transmitting, by the first computing device and to the second computing device during the real-time video communication session, second video data provided by a camera of the first computing device;
buffering, by the first computing device, third video data that is received by the first computing device from the second computing device; and
after buffering the third video data, switching the first computing device to operate in the video mode; and
while the first computing device is operating in video mode, outputting, by the first computing device and for display at the touch-sensitive display, the third video data.
15. A first computing device, comprising:
one or more processors;
a network interface to receive communication data from a second computing device while the first computing device and the second computing device are engaged in a real-time video communication session, wherein the communication data comprises audio data and first video data;
a camera; and
a touch-sensitive display that displays the first video data while the first computing device is operating in a video mode;
wherein the one or more processors are configured to overlay, onto a display of the first video data, information related to a text-based message received by the first computing device and from the second computing device during the real-time video communication session, output, by the first computing device and for display at the touch-sensitive display, a touch target that, upon activation, toggles the first computing device between operating in the video mode and a text mode, while operating in the video mode, receive, by the first computing device, one or more activation signals indicating the touch target is activated, responsive to receiving the one or more activation signals, switch the first computing device into the text mode and provide an operation indication to the second computing device indicating that the first computing device is operating in the text mode, while the first computing device is operating in the text mode:
transmit, by the first computing device and to the second computing device during the real-time video communication session, second video data provided by the camera, buffer, by the first computing device, third video data received by the first computing device from the second computing device, and after buffering the third video data, switching the first computing device to operate in the video mode; and
while the first computing device is operating in the video mode, cause the touch-sensitive display to display the third video data.
US13/250,964 2011-02-01 2011-09-30 Text chat overlay for video chat Active US8701020B1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/250,964 US8701020B1 (en) 2011-02-01 2011-09-30 Text chat overlay for video chat

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US201113019203A 2011-02-01 2011-02-01
US13/250,964 US8701020B1 (en) 2011-02-01 2011-09-30 Text chat overlay for video chat

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US201113019203A Continuation 2011-02-01 2011-02-01

Publications (1)

Publication Number Publication Date
US8701020B1 true US8701020B1 (en) 2014-04-15

Family

ID=50441616

Family Applications (1)

Application Number Title Priority Date Filing Date
US13/250,964 Active US8701020B1 (en) 2011-02-01 2011-09-30 Text chat overlay for video chat

Country Status (1)

Country Link
US (1) US8701020B1 (en)

Cited By (29)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130246633A1 (en) * 2011-10-03 2013-09-19 Curtis Gibbs Giesen System and method for communications
US20140282086A1 (en) * 2013-03-18 2014-09-18 Lenovo (Beijing) Co., Ltd. Information processing method and apparatus
US20150025882A1 (en) * 2013-07-16 2015-01-22 Samsung Electronics Co., Ltd. Method for operating conversation service based on messenger, user interface and electronic device using the same
US20150046834A1 (en) * 2013-08-09 2015-02-12 Lenovo (Beijing) Co., Ltd. Information processing apparatus and information processing method
US20150094106A1 (en) * 2013-10-01 2015-04-02 Filmstrip, Llc Image and message integration system and method
US20150123991A1 (en) * 2013-11-04 2015-05-07 At&T Intellectual Property I, Lp System and Method for Enabling Mirror Video Chat Using a Wearable Display Device
US20150185980A1 (en) * 2013-12-30 2015-07-02 Samsung Electronics Co., Ltd. Method and device for switching screens
US9373121B1 (en) * 2012-08-09 2016-06-21 Sprint Communications Company L.P. User communication device control with operating system action request messages
US9894022B2 (en) 2013-07-19 2018-02-13 Ambient Consulting, LLC Image with audio conversation system and method
DK201670596A1 (en) * 2016-06-12 2018-02-19 Apple Inc Digital touch on live video
US9898162B2 (en) 2014-05-30 2018-02-20 Apple Inc. Swiping functions for messaging applications
US9977591B2 (en) 2013-10-01 2018-05-22 Ambient Consulting, LLC Image with audio conversation system and method
EP3364281A1 (en) * 2017-02-17 2018-08-22 LG Electronics Inc. Mobile terminal and controlling method thereof
US10061467B2 (en) 2015-04-16 2018-08-28 Microsoft Technology Licensing, Llc Presenting a message in a communication session
US10180776B2 (en) 2013-10-01 2019-01-15 Ambient Consulting, LLC Image grouping with audio commentaries system and method
US20190044985A1 (en) * 2017-04-06 2019-02-07 Smoothy Inc. Method, system and non-transitory computer-readable recording medium for providing a multilateral communication service
US10250735B2 (en) 2013-10-30 2019-04-02 Apple Inc. Displaying relevant user interface objects
US10325394B2 (en) 2008-06-11 2019-06-18 Apple Inc. Mobile communication terminal and data input method
US20190297224A1 (en) * 2013-01-05 2019-09-26 Duvon Corporation Secured communication distribution system and method
US10778947B2 (en) 2017-03-07 2020-09-15 Filmic Inc. Sympathetic assistive mutation of live camera preview/display image stream
US10788927B2 (en) 2014-09-02 2020-09-29 Apple Inc. Electronic communication based on user input and determination of active execution of application for playback
US10834455B2 (en) 2018-06-27 2020-11-10 At&T Intellectual Property I, L.P. Integrating real-time text with video services
US11335121B2 (en) * 2020-03-31 2022-05-17 Snap Inc. Global configuration interface for default self-images
US20220215444A1 (en) * 2010-02-12 2022-07-07 Mary Anne Fletcher Mobile device streaming media application
US11477139B2 (en) 2016-02-25 2022-10-18 Meta Platforms, Inc. Techniques for messaging bot rich communication
US11552816B2 (en) 2021-06-02 2023-01-10 Microsoft Technology Licensing, Llc Targeted positioning of message content for interfaces identifying multiple users
US20230130806A1 (en) * 2020-09-25 2023-04-27 Beijing Zitiao Network Technology Co., Ltd. Method, apparatus, device and medium for generating video in text mode
US11949923B1 (en) * 2022-12-19 2024-04-02 Adobe Inc. Trigger based digital content caching
US11966952B1 (en) * 2024-01-25 2024-04-23 Weple Ip Holdings Llc Mobile device streaming media application

Citations (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5444477A (en) * 1992-10-23 1995-08-22 Hitachi, Ltd. Video telephone system
US5610653A (en) * 1992-02-07 1997-03-11 Abecassis; Max Method and system for automatically tracking a zoomed video image
US5815196A (en) * 1995-12-29 1998-09-29 Lucent Technologies Inc. Videophone with continuous speech-to-subtitles translation
US20020093531A1 (en) * 2001-01-17 2002-07-18 John Barile Adaptive display for video conferences
US20030074451A1 (en) 2001-10-16 2003-04-17 Parker Benjamin J. Integration of video telephony with chat and instant messaging environments
US6731323B2 (en) * 2002-04-10 2004-05-04 International Business Machines Corporation Media-enhanced greetings and/or responses in communication systems
US20040145652A1 (en) 2003-01-29 2004-07-29 Fujitsu Limited Communication assistance method, communication assistance device, communication assistance program, and computer readable storage medium on which a communication assistance program is stored
US20040155902A1 (en) * 2001-09-14 2004-08-12 Dempski Kelly L. Lab window collaboration
US20060053466A1 (en) * 2004-09-08 2006-03-09 Nec Corporation Television telephone system, communication terminal device, character information transmission method used therefor, and program
US20060148512A1 (en) * 2004-11-19 2006-07-06 Nokia Corporation Method, apparatus and computer program product providing graphical user interface that facilitates management of multiple simultaneous communication sessions
US20080059580A1 (en) 2006-08-30 2008-03-06 Brian Kalinowski Online video/chat system
US20080059581A1 (en) 2006-09-05 2008-03-06 Andrew Pepperell Viewing data as part of a video conference
US20080134057A1 (en) * 2006-11-14 2008-06-05 Samsung Electronics Co., Ltd. Mobile communication terminal for video calling and method for saving chat messages thereof
US20080201438A1 (en) * 2007-02-20 2008-08-21 Indrek Mandre Instant messaging activity notification
US20080231545A1 (en) * 2005-11-24 2008-09-25 Tencent Technology (Shenzhen) Company Ltd. Video picture management equipment and method for video picture management
US20080273077A1 (en) 2007-05-02 2008-11-06 Demand Media, Inc. Virtual video message answering machine platform
US20090119725A1 (en) * 2007-11-05 2009-05-07 Samsung Electronics Co., Ltd. Method for providing video telephony using broadcast receiving apparatus
US7565680B1 (en) * 2000-06-30 2009-07-21 Comcast Ip Holdings I, Llc Advanced set top terminal having a video call feature
US20090199078A1 (en) * 2008-02-04 2009-08-06 Siemens Communications, Inc. Method and apparatus for enhanced video mixing
US20100037151A1 (en) 2008-08-08 2010-02-11 Ginger Ackerman Multi-media conferencing system
US20100246571A1 (en) 2009-03-30 2010-09-30 Avaya Inc. System and method for managing multiple concurrent communication sessions using a graphical call connection metaphor
US20110107220A1 (en) * 2002-12-10 2011-05-05 Perlman Stephen G User interface, system and method for controlling a video stream
US8582474B2 (en) * 2010-12-09 2013-11-12 At&T Intellectual Property I, L.P. Video conference system and method

Patent Citations (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5610653A (en) * 1992-02-07 1997-03-11 Abecassis; Max Method and system for automatically tracking a zoomed video image
US5444477A (en) * 1992-10-23 1995-08-22 Hitachi, Ltd. Video telephone system
US5815196A (en) * 1995-12-29 1998-09-29 Lucent Technologies Inc. Videophone with continuous speech-to-subtitles translation
US7565680B1 (en) * 2000-06-30 2009-07-21 Comcast Ip Holdings I, Llc Advanced set top terminal having a video call feature
US20020093531A1 (en) * 2001-01-17 2002-07-18 John Barile Adaptive display for video conferences
US20040155902A1 (en) * 2001-09-14 2004-08-12 Dempski Kelly L. Lab window collaboration
US20030074451A1 (en) 2001-10-16 2003-04-17 Parker Benjamin J. Integration of video telephony with chat and instant messaging environments
US6731323B2 (en) * 2002-04-10 2004-05-04 International Business Machines Corporation Media-enhanced greetings and/or responses in communication systems
US20110107220A1 (en) * 2002-12-10 2011-05-05 Perlman Stephen G User interface, system and method for controlling a video stream
US20040145652A1 (en) 2003-01-29 2004-07-29 Fujitsu Limited Communication assistance method, communication assistance device, communication assistance program, and computer readable storage medium on which a communication assistance program is stored
US20060053466A1 (en) * 2004-09-08 2006-03-09 Nec Corporation Television telephone system, communication terminal device, character information transmission method used therefor, and program
US20060148512A1 (en) * 2004-11-19 2006-07-06 Nokia Corporation Method, apparatus and computer program product providing graphical user interface that facilitates management of multiple simultaneous communication sessions
US20080231545A1 (en) * 2005-11-24 2008-09-25 Tencent Technology (Shenzhen) Company Ltd. Video picture management equipment and method for video picture management
US20080059580A1 (en) 2006-08-30 2008-03-06 Brian Kalinowski Online video/chat system
US20080059581A1 (en) 2006-09-05 2008-03-06 Andrew Pepperell Viewing data as part of a video conference
US20080134057A1 (en) * 2006-11-14 2008-06-05 Samsung Electronics Co., Ltd. Mobile communication terminal for video calling and method for saving chat messages thereof
US20080201438A1 (en) * 2007-02-20 2008-08-21 Indrek Mandre Instant messaging activity notification
US20080273077A1 (en) 2007-05-02 2008-11-06 Demand Media, Inc. Virtual video message answering machine platform
US20090119725A1 (en) * 2007-11-05 2009-05-07 Samsung Electronics Co., Ltd. Method for providing video telephony using broadcast receiving apparatus
US20090199078A1 (en) * 2008-02-04 2009-08-06 Siemens Communications, Inc. Method and apparatus for enhanced video mixing
US20100037151A1 (en) 2008-08-08 2010-02-11 Ginger Ackerman Multi-media conferencing system
US20100246571A1 (en) 2009-03-30 2010-09-30 Avaya Inc. System and method for managing multiple concurrent communication sessions using a graphical call connection metaphor
US8582474B2 (en) * 2010-12-09 2013-11-12 At&T Intellectual Property I, L.P. Video conference system and method

Non-Patent Citations (18)

* Cited by examiner, † Cited by third party
Title
"CU-SeeMe" Wikipedia, the free encyclopedia [online]. Wikimedia Foundation, Inc. Last modified on Feb. 15, 2011. Retrieved from the Internet: (3 pgs.)
"Mobile Mouse Pro, Mobile Mouse for the iPhone, iPod & iPad", MobileMouse.com. Retrieved from the Internet: YouTube video also available at: Posted Dec. 20, 2010, 8 pgs.
"Open Communications," Google Talk for Developers (Labs), Google code labs [online]. Google Inc. 2011. Retrieved from the Internet on Jan. 25, 2011: (3 pgs.).
"CU-SeeMe" Wikipedia, the free encyclopedia [online]. Wikimedia Foundation, Inc. Last modified on Feb. 15, 2011. Retrieved from the Internet: <URL: http://en.wikipedia.org/wiki/CU-SeeMe> (3 pgs.)
"Mobile Mouse Pro, Mobile Mouse for the iPhone, iPod & iPad", MobileMouse.com. Retrieved from the Internet: <http://mobilemouse.com/overviewClipboard.html> YouTube video also available at: <http://www.youtube.com/watch?v=NCqwKgIZoo8> Posted Dec. 20, 2010, 8 pgs.
"Open Communications," Google Talk for Developers (Labs), Google code labs [online]. Google Inc. 2011. Retrieved from the Internet on Jan. 25, 2011: <http://code.google.com/apis/talk/open—communications.html> (3 pgs.).
Cline, Jason, Connect to the Mobile Web with SMS, SitePen, available at http://www.sitepen.com/blog/2008/06/30/connect-to-the-mobile-web-with-sms/ (Jun. 30, 2008). *
Mobile Mouse Pro, Mobile Mouse for the iPhone, iPod & iPad, MobileMouse.com, available at http://mobilemouse.com/overviewClipboard.html, YouTube video also available at http://www.youtube.com/watch?v=NCqwKgIZoo8 (posted Dec. 20, 2010). *
Office Action from U.S. Appl. No. 13/019,203, dated May 22, 2012, 14 pp.
Office Action from U.S. Appl. No. 13/019,203, dated Nov. 25, 2011, 24 pp.
Pogue, David, iPhone: The Missing Manual, Fourth Edition, O'Reilly Media, Inc., (published Dec. 1997). *
Response to Office Action dated Nov. 25, 2011, from U.S. Appl. No. 13/019,203, filed Feb. 27, 2012, 22 pp.
Skype, Introducing the new Skype for Mac, YouTube, available at http://www.youtube.com/watch?v=atvAdN9bENc (posted Jan. 26, 2011). *
Slack, S.E., "Use instant messaging and video chat to stay in touch," Instant video messaging-free webcam chat via Windows Live Messenger calls [online]. Microsoft, 2011. Retrieved from the Internet on Jan. 24, 2011: (4 pgs.).
Slack, S.E., "Use instant messaging and video chat to stay in touch," Instant video messaging—free webcam chat via Windows Live Messenger calls [online]. Microsoft, 2011. Retrieved from the Internet on Jan. 24, 2011: <URL: http://www.microsoft.com/athome/photos/imvideo.aspx> (4 pgs.).
U.S. Appl. No. 13/019,203, by Richard Fulcher, filed Feb. 1, 2011.
York, Dan, Skype 5.0 Beta for Mac OS X: A First Look with Screenshots, Disruptive Telephony, available at http://www.disruptivetelephony.com/2010/11/skype-50-beta-for-mac-os-x-a-first-look-with-screenshots.html (Nov. 4, 2010). *
YourUpdate, Bringing the Face Time to Online Communication, YouTube, tokbox.com, available at http://www.youtube.com/watch?v=fvBEsfh7vS0 (uploaded May 19, 2009). *

Cited By (46)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10325394B2 (en) 2008-06-11 2019-06-18 Apple Inc. Mobile communication terminal and data input method
US11734730B2 (en) * 2010-02-12 2023-08-22 Weple Ip Holdings Llc Mobile device streaming media application
US20220215444A1 (en) * 2010-02-12 2022-07-07 Mary Anne Fletcher Mobile device streaming media application
US20130246633A1 (en) * 2011-10-03 2013-09-19 Curtis Gibbs Giesen System and method for communications
US9373121B1 (en) * 2012-08-09 2016-06-21 Sprint Communications Company L.P. User communication device control with operating system action request messages
US20190297224A1 (en) * 2013-01-05 2019-09-26 Duvon Corporation Secured communication distribution system and method
US11582366B2 (en) * 2013-01-05 2023-02-14 Duvon Corporation Secured communication distribution system and method
US20140282086A1 (en) * 2013-03-18 2014-09-18 Lenovo (Beijing) Co., Ltd. Information processing method and apparatus
US10712936B2 (en) * 2013-03-18 2020-07-14 Lenovo (Beijing) Co., Ltd. First electronic device and information processing method applicable to first or second electronic device comprising a first application
US20150025882A1 (en) * 2013-07-16 2015-01-22 Samsung Electronics Co., Ltd. Method for operating conversation service based on messenger, user interface and electronic device using the same
US9894022B2 (en) 2013-07-19 2018-02-13 Ambient Consulting, LLC Image with audio conversation system and method
US9608944B2 (en) * 2013-08-09 2017-03-28 Beijing Lenovo Software Ltd. Information processing apparatus and information processing method
US20150046834A1 (en) * 2013-08-09 2015-02-12 Lenovo (Beijing) Co., Ltd. Information processing apparatus and information processing method
US10180776B2 (en) 2013-10-01 2019-01-15 Ambient Consulting, LLC Image grouping with audio commentaries system and method
US20150094106A1 (en) * 2013-10-01 2015-04-02 Filmstrip, Llc Image and message integration system and method
US9977591B2 (en) 2013-10-01 2018-05-22 Ambient Consulting, LLC Image with audio conversation system and method
US10057731B2 (en) * 2013-10-01 2018-08-21 Ambient Consulting, LLC Image and message integration system and method
US11316968B2 (en) 2013-10-30 2022-04-26 Apple Inc. Displaying relevant user interface objects
US10972600B2 (en) 2013-10-30 2021-04-06 Apple Inc. Displaying relevant user interface objects
US10250735B2 (en) 2013-10-30 2019-04-02 Apple Inc. Displaying relevant user interface objects
US20150123991A1 (en) * 2013-11-04 2015-05-07 At&T Intellectual Property I, Lp System and Method for Enabling Mirror Video Chat Using a Wearable Display Device
US9672649B2 (en) * 2013-11-04 2017-06-06 At&T Intellectual Property I, Lp System and method for enabling mirror video chat using a wearable display device
US9911216B2 (en) 2013-11-04 2018-03-06 At&T Intellectual Property I, L.P. System and method for enabling mirror video chat using a wearable display device
US10593088B2 (en) 2013-11-04 2020-03-17 At&T Intellectual Property I, L.P. System and method for enabling mirror video chat using a wearable display device
US20150185980A1 (en) * 2013-12-30 2015-07-02 Samsung Electronics Co., Ltd. Method and device for switching screens
US11226724B2 (en) 2014-05-30 2022-01-18 Apple Inc. Swiping functions for messaging applications
US9898162B2 (en) 2014-05-30 2018-02-20 Apple Inc. Swiping functions for messaging applications
US10739947B2 (en) 2014-05-30 2020-08-11 Apple Inc. Swiping functions for messaging applications
US11579721B2 (en) 2014-09-02 2023-02-14 Apple Inc. Displaying a representation of a user touch input detected by an external device
US10788927B2 (en) 2014-09-02 2020-09-29 Apple Inc. Electronic communication based on user input and determination of active execution of application for playback
US10061467B2 (en) 2015-04-16 2018-08-28 Microsoft Technology Licensing, Llc Presenting a message in a communication session
US11477139B2 (en) 2016-02-25 2022-10-18 Meta Platforms, Inc. Techniques for messaging bot rich communication
DK201670596A1 (en) * 2016-06-12 2018-02-19 Apple Inc Digital touch on live video
US10264209B2 (en) 2017-02-17 2019-04-16 Lg Electronics Inc. Mobile terminal and controlling method thereof
EP3364281A1 (en) * 2017-02-17 2018-08-22 LG Electronics Inc. Mobile terminal and controlling method thereof
US10778947B2 (en) 2017-03-07 2020-09-15 Filmic Inc. Sympathetic assistive mutation of live camera preview/display image stream
US10721281B2 (en) * 2017-04-06 2020-07-21 Smoothy Inc. Method, system and non-transitory computer-readable recording medium for providing a multilateral communication service
US20190044985A1 (en) * 2017-04-06 2019-02-07 Smoothy Inc. Method, system and non-transitory computer-readable recording medium for providing a multilateral communication service
US10834455B2 (en) 2018-06-27 2020-11-10 At&T Intellectual Property I, L.P. Integrating real-time text with video services
US11595718B2 (en) 2018-06-27 2023-02-28 At&T Intellectual Property I, L.P. Integrating real-time text with video services
US11335121B2 (en) * 2020-03-31 2022-05-17 Snap Inc. Global configuration interface for default self-images
US20230130806A1 (en) * 2020-09-25 2023-04-27 Beijing Zitiao Network Technology Co., Ltd. Method, apparatus, device and medium for generating video in text mode
US11922975B2 (en) * 2020-09-25 2024-03-05 Beijing Zitiao Network Technology Co., Ltd. Method, apparatus, device and medium for generating video in text mode
US11552816B2 (en) 2021-06-02 2023-01-10 Microsoft Technology Licensing, Llc Targeted positioning of message content for interfaces identifying multiple users
US11949923B1 (en) * 2022-12-19 2024-04-02 Adobe Inc. Trigger based digital content caching
US11966952B1 (en) * 2024-01-25 2024-04-23 Weple Ip Holdings Llc Mobile device streaming media application

Similar Documents

Publication Publication Date Title
US8701020B1 (en) Text chat overlay for video chat
US10747418B2 (en) Frictionless interface for virtual collaboration, communication and cloud computing
US10389770B2 (en) Concurrent network based collaboration sessions
EP2715972B1 (en) Muting participants in a communication session
KR101951975B1 (en) communication system
US20150032809A1 (en) Conference Session Handoff Between Devices
CN105159578A (en) Video display mode switching method and apparatus
US20150117513A1 (en) Bandwidth reduction system and method
US10277546B2 (en) Information processing system, information processing apparatus, and storage medium
EP3556121B1 (en) Methods and apparatus for managing control data
US9060033B2 (en) Generation and caching of content in anticipation of presenting content in web conferences
WO2022135005A1 (en) Call-based screen sharing method, apparatus, device, and storage medium
CN114500432A (en) Session message transceiving method and device, electronic equipment and readable storage medium
CN109586929B (en) Conference content transmission method and device, electronic equipment and storage medium
US20230138804A1 (en) Enhanced video call method and system, and electronic device
WO2023284708A1 (en) Video processing method and apparatus, electronic device and storage medium
CN113285866B (en) Information sending method and device and electronic equipment
CN103973542B (en) A kind of voice information processing method and device
EP4113985A1 (en) Multimedia conference data processing method and apparatus, and electronic device
TW202147834A (en) Synchronizing local room and remote sharing
US8705410B2 (en) Global conference roster for distributed bridges
CN113271376B (en) Communication control method, electronic equipment and earphone
TW201352001A (en) Systems and methods for multimedia interactions
WO2024001956A1 (en) Video call method and apparatus, first electronic device, and second electronic device
CN112306595A (en) Interaction method and device and electronic equipment

Legal Events

Date Code Title Description
AS Assignment

Owner name: GOOGLE INC., CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:FULCHER, RICHARD;DODD, MICHAEL D.;MILLAR, EVAN;AND OTHERS;SIGNING DATES FROM 20110318 TO 20110321;REEL/FRAME:027255/0189

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
AS Assignment

Owner name: GOOGLE LLC, CALIFORNIA

Free format text: CHANGE OF NAME;ASSIGNOR:GOOGLE INC.;REEL/FRAME:044277/0001

Effective date: 20170929

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551)

Year of fee payment: 4

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8