This disclosure relates generally to accessibility applications for assisting visually impaired users to navigate graphical user interfaces.
A digital media receiver (DMR) is a home entertainment device that can connect to a home network to retrieve digital media files (e.g., music, pictures, video) from a personal computer or other networked media server and play them back on a home theater system or television. Users can access the content stores directly through the DMR to rent movies and TV shows and stream audio and video podcasts. A DMV also allows a user to sync or stream photos, music and videos from their personal computer and to maintain a central home media library.
Despite the availability of large high definition television screens and computer monitors, visually impaired users may find it difficult to track a cursor on the screen while navigating with a remote control device. Visual enhancement of on screen information may not be helpful for screens with high density content or where some content is not navigable by the remote control device.
A system and method is disclosed that uses screen reader like functionality to speak information presented on a graphical user interface displayed by a media presentation system, including information that is not navigable by a remote control device. Information can be spoken in an order that follows the relative importance of the information based on a characteristic of the information or the location of the information within the graphical user interface. A history of previously spoken information is monitored to avoid speaking information more than once for a given graphical user interface. A different pitch can be used to speak information based on a characteristic of the information. In one aspect, information that is not navigable by the remote control device is spoken after a time delay. Voice prompts can be provided for a remote-driven virtual keyboard displayed by the media presentation system. The voice prompts can be spoken with different voice pitches.
In some implementations, a graphical user interface is caused to be displayed by a media presentation system. Navigable and non-navigable information are identified on the graphical user interface. The navigable and non-navigable information are converted into speech. The speech is output in an order that follows the relative importance of the converted information based on a characteristic of the information or a location of the information within the graphical user interface.
In some implementations, a virtual keyboard is caused to be displayed by a media presentation system. An input is received from a remote control device selecting a key of the virtual keyboard. Speech corresponding to the selected key is outputted. The media presentation system can also cause to be displayed an input field. The current content of the input field can be spoken each time a new key is selected entering a character, number, symbol or command in the input field, allowing a user to detect errors in the input field
Particular implementations disclosed herein can be implemented to realize one or more of the following advantages. Information within a graphical user interface displayed on a media presentation system is spoken according to its relative importance to other information within the graphical user interface, thereby orientating a vision impaired user navigating the graphical user interface. Non-navigable information is spoken after a delay to allow the user to hear the information without having to focus a cursor or other pointing device on each portion of the graphical user interface where there is information. A remote-driven virtual keyboard provides voice prompts to allow a vision impaired user to interact with the keyboard and to manage contents of an input field displayed with the virtual keyboard.
The details of one or more implementations of assisted media presentation are set forth in the accompanying drawings and the description below. Other features, aspects, and advantages will become apparent from the description, the drawings, and the claims.
Like reference symbols in the various drawings indicate like elements.
An example of system 100 can be a home network that includes a wireless router for allowing communication between data processing apparatus 108 and DMR 102. Other example configurations are also possible. For example, DMR 102 can be integrated in media presentation system 104 or within a television set-top box. In the example shown, DMR 102 is a home entertainment device that can connect to home network to retrieve digital media files (e.g., music, pictures, or video) from a personal computer or other networked media server and play the media files back on a home theater system or TV. DMR 102 can connect to the home network using either a wireless (IEEE 802.11x) or wired (e.g., Ethernet) connection. DMR 102 can cause display of graphical user interfaces that allow users to navigate through a digital media library, search for, and play media files (e.g., movies, TV shows, music, podcasts).
Remote control device 112 can communicate with DMR 102 through a radio frequency or infrared communication link. As described in reference to
In some implementations, a TTS engine in the screen reader can convert raw text displayed on the screen containing symbols like numbers and abbreviations into an equivalent of written-out words using text normalization, pre-processing or tokenization. Phonetic transcriptions can be assigned to each word of the text. The text can then be divided and marked into prosodic units (e.g., phrases, clauses, sentences) using text-to-phoneme or grapheme-to-phoneme conversion to generate a symbolic linguistic representation of the text. A synthesizer can then convert the symbolic linguistic representation into sound, including computing target prosody (e.g., pitch contour, phoneme durations), which can be applied to the output speech. Some examples of synthesizers are concatenative synthesis, unit selection synthesis, diphone synthesis or any other known synthesis technology.
Referring to
The scenario described above works fine for a user with good vision. However, such a sequence may be difficult for vision impaired user who may be sitting a distance away from media presentation system 104. For such users, a screen reader mode can be activated.
In some implementations, a screen reader mode is activated when DMR 102 is initially installed and setup. A setup screen can be presented with various set up options, such as a language option. After a specified number of seconds of delay (e.g., 2.5 seconds), a voice prompt can request the user to operate remote control device 112 to activate the screen reader. For example, the voice prompt can request the user to press a Play or other button on remote control device 112 a specified number of times (e.g., 3 times). Upon receiving this input, DMR 102 can activate the screen reader. The screen reader mode can remain set until the user deactivates the mode in a settings menu.
When the user first enters GUI 202, a pointer (e.g., a cursor) can be focused on the first screen element in the menu bar (Movies) as a default entry point into GUI 202. Once in GUI 202, the screen reader can read through information displayed on GUI 202 in an order that follows a relative importance of the information based on a characteristic of the information or the location of the information within GUI 202.
The screen labels in the menu bar can be spoken from left to right. If the user selects category screen label 206, screen label 206 will be spoken as well as each screen label underneath screen label 206 from top to bottom. When the user focuses on a particular screen label, such as screen label 208 (Favorites subcategory), screen label 208 will be spoken after a few time period expires without a change in focus (e.g., 2.5 seconds).
Referring now to
Since screen label 209 was already spoken when the user entered GUI 208, screen label 209 will not be spoken again, unless the user requests a reread. In some implementations, remote control device 112 can include a key, key sequence or button that causes information to be reread by the screen reader.
In some implementations, a history of spoken information is monitored in screen reader mode. When the user changes focus, the history can be reviewed to determine whether screen label 209 has been spoken. If screen label 209 has been spoken, screen label 209 will not be spoken again, unless the user requests that screen label 209 be read again. Alternatively, the user can back out of GUI 208, then re-enter GUI 208 again to cause the label to be read again. In this example, screen label 209 is said to be an “ancestor” of Label A. Information that is the current focus of the user can be read and re-read. For example, if the user navigates left and right in row 1, each time an item becomes a focus the corresponding Label is read by the screen reader.
Referring now to
For GUIs that display non-navigable information, the screen reader can wait a predetermined period of time before speaking the non-navigable information. In the example shown, when the user first navigates to GUI 212, screen label 214 is spoken. If the user takes no further action in GUI 212, and after expiration of a predetermined period of time (e.g., 2.5 seconds), the non-navigable information (e.g., basic info 216, summary 218) can be spoken.
In some implementations, a different voice pitch can be used to speak different types of information. For example, context information (e.g., screen labels that categorizes content) can be spoken in a first voice pitch and content information (e.g., information that describes the content) can be spoken in a second voice pitch, where the first voice pitch is higher or lower than the second voice pitch. Also, the speed of the spoken speech and the gender of the voice can be selected by a user through a settings screen accessible through the menu bar of GUI 202.
In the example shown, the user has entered GUI 300 causing screen label 302 to be spoken, which comprises User Account and instructions for entering a User ID. The user has partially typed in a User ID (johndoe@me.co_) in input field 308 and is about to select the “m” key 306 on virtual keyboard 304 (indicated by an underscore) to complete the User ID entry in input field 308. When the user selects the “m” key 306, or any key on virtual keyboard 304, the screen reader speaks the character, number, symbol or command corresponding to the key. In some implementations, before speaking the character “m,” the contents in input field 308 (johndoe@me.co_) are spoken first. This informs the vision impaired user of the current contents of input field 308 so the user can correct any errors. If a character is capitalized, the screen reader can speak the word “capital” before the character to be capitalized is spoken, such as “capital M.” If a command is selected, such as Clear or Delete, the item to be deleted can be spoken first, followed by the command. For example, if the user deletes the character “m” from input field 308, then the TTS engine can speak “m deleted.” In some implementations, when the user inserts a letter in input field 308, the phonetic representation (e.g., alpha, bravo, charlie) can be outputted to aid the user in distinguishing characters when speech is at high speed. If the user requests to clear input field 308 using remote control device 112 (e.g., by pressing a clear button), the entire contents of input field 308 will be spoken again to inform the user of what was deleted. In the above example, the phrase “johndoe@me.com deleted” would be spoken.
In some implementations, process 400 can begin by causing a GUI to be displayed on a media presentation system (402). Some example GUIs are GUIs 202, 208 and 212. An example media presentation system is a television system or computer system with display capability. Process 400 identifies navigable and non-navigable information displayed on the graphical user interface (404). Process 400 converts navigable and non-navigable information into speech (406). For example, a screen reader with a TTS engine can be used to convert context information and content information in the GUI to speech. Process 400 outputs speech in an order that follows a relative importance of the converted information based on a characteristic of the information or the location of information on the graphical user interface (408). Examples of characteristics can include the type of information (e.g., context related or content related), whether the information is navigable or not navigable, whether the information is a sentence, word or phoneme, etc. For example, a navigable screen label may be spoken before a non-navigable content summary for a given GUI of information. In some implementations, a history of spoken information can be monitored to ensure that information previously spoken for a given GUI is not spoken again, unless requested by the user. In some implementations, a time delay (e.g., 2.5 seconds) can be introduced prior to speaking non-navigable information. In some implementations, information can be spoken with different voice pitches based on characteristics of the information. For example, a navigable screen label can be spoken with a first voice pitch and a non-navigable text summary can be spoken with a second pitch higher or lower than the first pitch.
Process 500 can begin by causing a virtual keyboard to be displayed on a media presentation system (502). An example GUI is GUI 300. An example media presentation system is a television system or computer system with display capability. Process 500 can then receive input from a remote control device (e.g., remote control device 112) selecting a key on the virtual keyboard (504). Process 500 can then use a TTS engine to output speech corresponding to the selected key (506).
In some implementations, the TTS engine can speak using a voice pitch based on the selected key or phonetics. In some implementations, process 500 can cause an input field to be displayed by the media presentation system and content of the input field to be output as speech in a continuous manner. After the contents are spoken, process 500 can cause each character, number, symbol or command in the content to be spoken one at a time. In some implementations, prior to receiving the input, process 500 can output speech describing the virtual keyboard type (e.g., alphanumeric, numeric, foreign language). In some implementations, outputting speech corresponding to a key of the virtual keyboard can include outputting speech corresponding to a first key with a first voice pitch and outputting speech corresponding to a second key with a second voice pitch, where the first voice pitch is higher or lower than the second voice pitch.
In some implementations, processor(s) 602 can be configured to control the operation of receiver 600 by executing one or more instructions stored in computer-readable mediums 604, 606. For example, storage device 604 can be configured to store media content (e.g., movies, music), meta data (e.g., context information, content information), configuration data, user preferences, and operating system instructions. Storage device 604 can be any type of non-volatile storage, including a hard disk device or a solid-state drive. Storage device 610 can also store program code for one or more applications configured to present media content on a media presentation device (e.g., a television). Examples of programs include, a video player, a presentation application for presenting a slide show (e.g. music and photographs), etc. Storage device 604 can also store program code for one or more accessibility applications, such as a voice over framework or service and a speech synthesis engine for providing spoken interfaces using the voice over framework, as described in reference to
Wired network interface 608 (e.g., Ethernet port) and wireless network interface 610 (e.g., IEEE 802.11x compatible wireless transceiver) each can be configured to permit receiver 600 to transmit and receive information over a network, such as a local area network (LAN), wireless local area network (WLAN) or the Internet. Wireless network interface 610 can also be configured to permit direct peer-to-peer communication with other devices, such as an electronic tablet or other mobile device (e.g., a smart phone).
Input interface 612 can be configured to receive input from another device (e.g., a keyboard, game controller) through a direct wired connection, such as a USB, eSATA or an IEEE 1394 connection.
Output interface 614 can be configured to couple receiver 600 to one or more external devices, including a television, a monitor, an audio receiver, and one or more speakers. For example, output interface 614 can include one or more of an optical audio interface, an RCA connector interface, a component video interface, and a High-Definition Multimedia Interface (HDMI). Output interface 614 also can be configured to provide one signal, such as an audio stream, to a first device and another signal, such as a video stream, to a second device. Memory 606 can include non-volatile memory (e.g., ROM, flash) for storing configuration or settings data, operating system instructions, flags, counters, etc. In some implementations, memory 606 can include random access memory (RAM), which can be used to store media content received in receiver 600, such as during playback or pause. RAM can also store content information (e.g., metadata) and context information.
Receiver 600 can include remote control interface 620 that can be configured to receive commands from one or more remote control devices (e.g., device 112). Remote control interface 620 can receive the commands through a wireless connection, such as infrared or radio frequency signals. The received commands can be utilized, such as by processor(s) 602, to control media playback or to configure receiver 600. In some implementations, receiver 600 can be configured to receive commands from a user through a touch screen interface. Receiver 600 also can be configured to receive commands through one or more other input devices, including a keyboard, a keypad, a touch pad, a voice command system, and a mouse coupled to one or more ports of input interface 612.
The features described can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. The features can be implemented in a computer program product tangibly embodied in an information carrier, e.g., in a machine-readable storage device, for execution by a programmable processor; and method steps can be performed by a programmable processor executing a program of instructions to perform functions of the described implementations by operating on input data and generating output. Alternatively or in addition, the program instructions can be encoded on a propagated signal that is an artificially generated signal, e.g., a machine-generated electrical, optical, or electromagnetic signal that is generated to encode information for transmission to suitable receiver apparatus for execution by a programmable processor.
The described features can be implemented advantageously in one or more computer programs that are executable on a programmable system including at least one programmable processor coupled to receive data and instructions from, and to transmit data and instructions to, a data storage system, at least one input device, and at least one output device. A computer program is a set of instructions that can be used, directly or indirectly, in a computer to perform a certain activity or bring about a certain result. A computer program can be written in any form of programming language (e.g., Objective-C, Java), including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
Suitable processors for the execution of a program of instructions include, by way of example, both general and special purpose microprocessors, and the sole processor or one of multiple processors or cores, of any kind of computer. Generally, a processor will receive instructions and data from a read-only memory or a random access memory or both. The essential elements of a computer are a processor for executing instructions and one or more memories for storing instructions and data. Generally, a computer will also include, or be operatively coupled to communicate with, one or more mass storage devices for storing data files; such devices include magnetic disks, such as internal hard disks and removable disks; magneto-optical disks; and optical disks. Storage devices suitable for tangibly embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, such as EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, ASICs (application-specific integrated circuits).
To provide for interaction with a user, the features can be implemented on a computer having a display device such as a CRT (cathode ray tube) or LCD (liquid crystal display) monitor for displaying information to the user and a keyboard and a pointing device such as a mouse or a trackball by which the user can provide input to the computer.
The features can be implemented in a computer system that includes a back-end component, such as a data server, or that includes a middleware component, such as an application server or an Internet server, or that includes a front-end component, such as a client computer having a graphical user interface or an Internet browser, or any combination of them. The components of the system can be connected by any form or medium of digital data communication such as a communication network. Examples of communication networks include, e.g., a LAN, a WAN, and the computers and networks forming the Internet.
The computer system can include clients and servers. A client and server are generally remote from each other and typically interact through a network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
One or more features or steps of the disclosed embodiments can be implemented using an Application Programming Interface (API). An API can define on or more parameters that are passed between a calling application and other software code (e.g., an operating system, library routine, function) that provides a service, that provides data, or that performs an operation or a computation.
The API can be implemented as one or more calls in program code that send or receive one or more parameters through a parameter list or other structure based on a call convention defined in an API specification document. A parameter can be a constant, a key, a data structure, an object, an object class, a variable, a data type, a pointer, an array, a list, or another call. API calls and parameters can be implemented in any programming language. The programming language can define the vocabulary and calling convention that a programmer will employ to access functions supporting the API.
In some implementations, an API call can report to an application the capabilities of a device running the application, such as input capability, output capability, processing capability, power capability, communications capability, etc.
A number of implementations have been described. Nevertheless, it will be understood that various modifications may be made. In addition, other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Accordingly, other implementations are within the scope of the following claims.
This application claims priority to U.S. patent application Ser. No. 12/939,940, filed on Nov. 4, 2010, which is hereby incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 12939940 | Nov 2010 | US |
Child | 16363233 | US |