1. Field of the Invention
The present invention generally relates to systems and methods for remotely controlling a display device such as a television or a processing device connected thereto. In particular, the present invention relates to systems and methods for remotely controlling an application executing on display device or a processing device connected thereto using a remote control.
2. Background
Many electronic devices that include touch-based user input capabilities have been introduced into the marketplace. For example, a large number of conventional mobile devices such as cellular telephones, tablet computers, and netbooks include touch screens that provide touch-based user input capabilities. Unlike traditional desktop computers, many of these mobile devices do not include a physical keyboard or a mouse for enabling a user to interact with an application running on the device. Consequently, applications that run on these devices must be programmed to rely exclusively on touch-based user input for control.
Recently, there have been efforts to extend the use of operating systems designed for mobile devices to televisions. For example, GOOGLE TV™ is a product/service implemented on a television that will utilize the ANDROID™ operating system, which was developed for mobile devices. It is anticipated that other products/services to be developed for televisions will attempt to exploit operating systems designed for mobile devices. One problem associated with this trend is that many native applications that were developed to execute on a mobile device operating system have not been developed with control capabilities that are useful in a television environment.
When executing an application on a mobile device that includes a touch screen, user control is achieved via a user's touch. This form of user control assumes that the user is currently looking at the screen and can point with his finger at a desired spot on the screen. For example,
A problem arises when trying to run applications developed for touch-based mobile devices on a television. This is because most televisions do not provide touch screen capabilities. Furthermore, even if a television did provide touch screen capabilities, many viewers prefer to view television from a distance, making interaction with the television screen impracticable. Thus, the user cannot tap the television screen.
In addition to the “tap” functionality described above, many touch-based mobile devices also provide “drag” functionality. “Drag” functionality is typically invoked by sliding a finger across the surface of a touch screen. When this occurs, a scroll command is issued to an application running on the mobile device. The scroll command causes the application to scroll the currently-displayed content in the direction of the finger stroke. Furthermore, touch-based mobile devices that support multi-touch allow a user to interact with the touch screen using two fingers at the same time. For example, by touching the touch screen with two fingers and then increasing the distance between the two fingers, a “zoom in” command can be conveyed to an application running on the touch-based mobile device. Conversely, by touching the screen with two fingers and then reducing the distance between the two fingers, a “zoom out” command can be conveyed to the application.
When products such as GOOGLE TV™ are made available, they will be capable of running applications that were developed for a mobile device operating system (such as ANDROID™). The problem, however, is how to control the application. As noted above, most televisions do not have any touch-based user input capabilities and it is also not practical to control a television by touching the television screen. A standard controller such as a keyboard or mouse cannot help as many applications already available have not been built to support keyboard or mouse control.
Thus, there exists a need to provide a control interface for remotely-viewed display devices, such as televisions, that use the same operating system as touch-based mobile devices and that are capable of executing applications that were developed for execution on such touch-based mobile devices.
This Summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This Summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter. Moreover, it is noted that the invention is not limited to the specific embodiments described in the Detailed Description and/or other sections of this document. Such embodiments are presented herein for illustrative purposes only. Additional embodiments will be apparent to persons skilled in the relevant art(s) based on the teachings contained herein.
Embodiments described herein provide a system and method for remotely controlling applications executing on display devices that do not have touch-based user input capabilities, such as televisions, even when such applications were programmed to rely exclusively on touch-based control. In accordance with various embodiments described herein, user input events produced when a user interacts with a touch-based user input component of a remote control device are captured and transmitted to a display device that is executing a target application. On the display device, software components that are not part of the original source code of the target application operate to convert the received user input events into commands (e.g., “tap,” “drag,” or “zoom”) that are recognizable to the target application and inject those commands into the target application. The software components also cause a visually-perceptible hotspot indicator to be overlaid on graphical content rendered to a display of the display device by the target application, thereby allowing the user to determine how his interactions with the touch-based user input component of the remote control device will correspond to graphical elements currently being shown on the display of the display device.
In particular, a method for remotely controlling a target application executing on a display device is described herein, wherein the target application is configured to perform operations in response to a predefined set of commands and wherein at least one of the operations comprises rendering graphical content to a display of the display device. In accordance with the method, user input events generated in response to interaction by a user with a touch-based user input component of a remote control device are received. The user input events are converted into commands from the predefined set of commands. The commands are then injected into the target application executing on the display device, thereby causing the target application to perform operations corresponding to the injected commands. In accordance with the foregoing method, the injecting step is performed by a processing unit of the display device responsive to executing code that is not part of original source code associated with the target application.
Depending upon the implementation of the foregoing method, the converting step may be performed by the remote control device, the display device or by a third device that is not the remote control device or the display device.
In accordance with an embodiment, the foregoing method further includes identifying a location of a hotspot on the display of the display device and providing a visual indication of the hotspot location on the display. In further accordance with such an embodiment, converting the user input events into commands may include converting one or more of the user input events into a tap command at the hotspot location, converting one or more of the user input events into a drag command that is initiated at the hotspot location, or converting the user input events into a zoom command.
A system is also described herein. The system includes a display device and a remote control device. The display device includes a first processing unit and a display. The first processing unit is operable to execute a target application that performs operations in response to a predefined set of commands, wherein at least one of the operations comprises rendering graphical content to the display. The remote control device includes a second processing unit and a touch-based user input component. The second processing unit is operable to execute remote control logic that captures user input events generated when a user interacts with the touch-based user input component and transmits the user input events to the display device via a network. The first processing unit of the display device is further operable to execute controller logic and injection logic that are not part of original source code of the target application. The controller logic generates commands from the predefined set of commands based on the user input events received from the remote control device and the injection logic injects the commands generated by the controller logic into the target application, thereby enabling the user to remotely control the performance of the operations of the target application.
In one implementation of the system, the controller logic identifies a location of a hotspot on the display of the display device and the first processing unit of the display device is further operable to execute overlay logic that provides a visual indication of the hotspot location on the display. In further accordance with such an embodiment, the controller logic generates a tap command at the hotspot location or a drag command that is initiated at the hotspot location based on the user input events received from the remote control device. The drag command that is generated may be one of two drag commands that together comprise a zoom command.
In a further implementation of the system, the display device does not include a touch-based user input component but the target application is configured to perform the operations in response to commands generated based on user interaction with a touch-based user input component.
A computer program product is also described herein. The computer program product comprises a computer-readable storage medium having computer program logic recorded thereon for enabling a processing unit to facilitate remote control of a target application executing on a display device of which the processing unit is a part. The target application is configured to perform operations in response to a predefined set of commands, wherein at least one of the operations comprises rendering graphical content to a display of the display device. The computer program logic includes first computer program logic, second computer program logic and third computer program logic. The first computer program logic, when executed by the processing unit, receives user input events generated in response to interaction by a user with a touch-based user input component of a remote control device. The second computer program logic, when executed by the processing unit, converts the user input events into commands from the predefined set of commands. The third computer program logic, when executed by the processing unit, injects the commands into the target application executing on the display device, thereby causing the target application to perform operations corresponding to the injected commands. The aforementioned first, second and third computer program logic are not part of original source code associated with the target application.
A method for remotely controlling a target application executing on a processing device connected to a display device is also described herein, wherein the target application is configured to perform operations in response to a predefined set of commands and wherein at least one of the operations comprises rendering graphical content that is displayed by the display device. In accordance with the method, user input events generated in response to interaction by a user with a user input component of a remote control device are received. The user input events are converted into commands from the predefined set of commands. The commands are then injected into the target application executing on the processing device, thereby causing the target application to perform operations corresponding to the injected commands. In accordance with the foregoing method, the injecting step is performed by a processing unit of the processing device responsive to executing a software module that is not part of original source code associated with the target application.
A system is also described herein. The system includes a display device and an electronic device that is communicatively connected to the display device. The electronic device includes a touch-screen display and a processing unit. The processing unit is operable to execute a target application that performs operations in response to a predefined set of commands, wherein at least one of the operations comprises generating graphical content for transmission to the display device for display thereon. The processing unit is further operable to execute controller logic and injection logic that are not part of original source code of the target application. The controller logic generates commands from the predefined set of commands based on user input events generated when a user interacts with the touch-screen display. The injection logic injects the commands generated by the controller logic into the target application, thereby enabling the user to control the performance of the operations of the target application in a manner not originally provided for by the target application.
A computer program product is also described herein. The computer program product comprises a computer-readable storage medium having computer program logic recorded thereon for enabling a processing unit of an electronic device to control the performance of a target application executing on the electronic device in a manner not originally provided for by the target application. The target application is configured to perform operations in response to a predefined set of commands, wherein at least one of the operations comprises generating graphical content to be transmitted to a remote display device. The computer program logic includes first computer program logic, second computer program logic, and third computer program logic. The first computer program logic, when executed by the processing unit, receives user input events generated in response to interaction by a user with a touch-screen display of the electronic device. The second computer program logic, when executed by the processing unit, converts the user input events into commands from the predefined set of commands. The third computer program logic, when executed by the processing unit, injects the commands into the target application executing on the electronic device, thereby causing the target application to perform operations corresponding to the injected commands. The aforementioned first, second and third computer program logic are not part of original source code associated with the target application.
Further features and advantages of the invention, as well as the structure and operation of various embodiments of the invention, are described in detail below with reference to the accompanying drawings. It is noted that the invention is not limited to the specific embodiments described herein. Such embodiments are presented herein for illustrative purposes only. Additional embodiments will be apparent to persons skilled in the relevant art(s) based on the teachings contained herein.
The accompanying drawings, which are incorporated herein and form part of the specification, illustrate embodiments of the present invention and, together with the description, further serve to explain the principles of the invention and to enable a person skilled in the relevant art(s) to make and use the invention.
The features and advantages of the present invention will become more apparent from the detailed description set forth below when taken in conjunction with the drawings.
The following detailed description refers to the accompanying drawings that illustrate exemplary embodiments of the present invention. However, the scope of the present invention is not limited to these embodiments, but is instead defined by the appended claims. Thus, embodiments beyond those shown in the accompanying drawings, such as modified versions of the illustrated embodiments, may nevertheless be encompassed by the present invention.
References in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” or the like, indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Furthermore, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the relevant art(s) to implement such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
Embodiments described herein provide a system and method for remotely controlling applications executing on display devices that do not have touch-based user input capabilities, such as televisions, even when such applications were programmed to rely exclusively on touch-based control. In accordance with various embodiments described herein, user input events produced when a user interacts with a user input component of a remote control device are captured and transmitted to a display device or processing device connected thereto that is executing a target application. On the display/processing device, software components that are not part of the original source code of the target application operate to convert the received user input events into commands (e.g., “tap,” “drag,” or “zoom”) that are recognizable to the target application and inject those commands into the target application. In alternate embodiments, the conversion is performed on the remote control device or a third device that is not the display/processing device or the remote control device. The software components on the display/processing device also cause a visually-perceptible hotspot indicator to be overlaid on graphical content rendered to a display of the display device by the target application, thereby allowing the user to determine how his interactions with the user input component of the remote control device will correspond to graphical elements currently being shown on the display of the display device.
In an embodiment, display device 304 comprises a television. However, this example is not intended to be limiting, and display device 304 may comprise any device or system that includes a display and is capable of executing applications that render graphical content thereto. For example display device 304 may also comprise a television and associated set top box, a desktop computer and associated display, a laptop computer, a tablet computer, a video game console and associated display, a portable video game player, a smart telephone, a personal media player or the like. In a particular embodiment, display device 304 does not include a touch-based user interface component and thus cannot itself generate touch-based user input.
Remote control device 302 comprises a device that is configured to interact with display device 304 via communication path 350. As shown in
Communication path 350 is intended to generally represent any path by which remote control device 302 may communicate with display device 304. Communication path 350 may include one or more wired or wireless links. For example, communication path 350 may include a wireless link that is established using infrared (IR) or radio frequency (RF) communication protocols, although this is only an example. In certain implementations, communication path 350 includes one or more network connections. For example, remote control device 302 may be connected to display device 304 via a wide area network (WAN) such as the Internet, a local area network (LAN), or even a personal area network (PAN). Such networks may be implemented using wired communication links (e.g., Ethernet) and/or wireless communication links (e.g., WiFi or BLUETOOTH®) as is known in the art.
As further shown in
Storage media 336 is shown as storing a target application 342. Target application 342 is a computer program that is configured to perform operations on behalf of a user when executed by processing unit 332. By way of example and without limitation, target application 342 may comprise an application that allows a user to play a video game, send and receive e-mails or instant messages, browse the Web, maintain a calendar or contact list, obtain weather information, obtain location information and maps, obtain and play video and/or audio content, create and review documents, or the like. To expose such functionality to a user, target application 342 is configured to render graphical content to display 334 and to accept user input from a touch-based user interface component such as a touch screen. In some implementations, target application 342 may be programmed to exclusively rely on touch-based user input for user control. As noted above, however, display device 304 may not include a touch-based user interface component.
To extend the functionality of display device 304 so that applications executing thereon can be controlled by user input received by remote control device 302, three additional software modules are also stored by storage media 336 and executed by processing unit 332: controller logic 344, injection logic 346 and overlay logic 348. In one embodiment, controller logic 344 is loaded onto display device 304 and then loads injection logic 346 and overlay logic 348 as required. Such software modules may execute as services on display device 304 or can be injected into target application 342 using various methods. However, in either case, such software modules may exist apart from the compiled code of target application 342. The manner in which these software modules operate will be described below.
As also shown in
Storage media 316 is shown as storing remote control logic 322. Remote control logic 322 is configured to capture user input events that are generated in response to user interaction with user input component 314 when executed by processing unit 312. Other functions and features of remote control logic 322 will be described below.
Additionally, in the following, where a software module is described as performing a certain operation, it is to be understood that such operation is performed when the software module is executed by a processing unit (e.g., when remote control logic 322 is executed by processing unit 312, or when any of target application 342, controller logic 344, injection logic 346 or overlay logic 348 is executed by processing unit 332).
As shown in
At step 420, remote control logic 322 causes the captured user input events to be transmitted to controller logic 344 executing on display device 304 via communication path 350. Any suitable communication protocol may be used to enable such transmission. In one embodiment, the communication protocol is initiated by remote control logic 322 when the execution of remote control logic 322 is initiated on remote control device 302.
At step 430, controller logic 344 converts the user input events received from remote control logic 322 into one of a predefined set of commands that will be recognizable to target application 342 and provides the commands to injection logic 346. As will be discussed below, such commands may include tap commands, drag commands, zoom in commands, or zoom out commands. However, these examples are not intended to be limiting and numerous other commands may be utilized in accordance with the various control capabilities of target application 342.
At step 440, injection logic 346 injects the commands generated during step 430 into target application 342, thereby causing target application 342 to perform operations corresponding to the injected commands. For example, injection logic 346 may inject tap, drag, zoom in or zoom out commands generated during step 430 into target application 342 and target application 342 may perform operations in accordance with such commands. As will be discussed below, the injection of the commands into target application 342 may be carried out in one embodiment by hooking functions of target application 342, although this is only one approach.
In accordance with the foregoing method of flowchart 400, the step of converting the user input events captured by remote control logic 322 into commands that will be recognizable to target application 342 is performed by controller logic 344 installed on display device 304. However, in an alternate embodiment, such conversion step may instead be performed by remote control logic 322 itself
As shown in
In a still further embodiment, the step of converting the user input events captured by remote control logic 322 into commands that will be recognizable to target application 342 is performed by a third device that is not remote control device 302 or display device 304. For example, the third device may be an intermediate device that comprises a node along communication path 350. Such third device may receive user input events transmitted by remote control logic 322, convert the user input events into commands recognizable by target application 342, and then transmit the commands to controller logic 344.
In an embodiment, display device 606 comprises a television or other device that includes a display 652 upon which graphical content may be displayed. Processing device 604 is connected to display device 606 via a wired and/or wireless connection and is configured to provide graphical content thereto for display upon display 652. Processing device 604 may comprise, for example and without limitation, a set top box, a digital video recorder, a personal computer, a video gaming console, or other device that can be connected to a display device and provide graphical content thereto.
Remote control device 602 comprises a device that is configured to interact with processing device 604 via communication path 650. As shown in
Communication path 650 is intended to generally represent any path by which remote control device 602 may communicate with processing device 604. Communication path 650 may be implemented in a like manner to communication path 350 as described above in reference to system 300.
As further shown in
Storage media 634 is shown as storing a target application 642. Target application 642 is a computer program that is configured to perform operations on behalf of a user when executed by processing unit 632. Target application 642 may comprise any of the different applications described above in reference to target application 342 of display device 304. To expose functionality to a user, target application 642 is configured to render graphical content for display and to accept user input from a touch-based user interface component such as a touch screen. In some implementations, target application 642 may be programmed to exclusively rely on touch-based user input for user control. The graphical content rendered by target application 642 is delivered to display device 606, where it is displayed on display 652.
To extend the functionality of processing device 604 so that applications executing thereon can be controlled by user input received by remote control device 602, three additional software modules are also stored by storage media 634 and executed by processing unit 632: controller logic 644, injection logic 646 and overlay logic 648. In one embodiment, controller logic 644 is loaded onto processing device 604 and then loads injection logic 646 and overlay logic 648 as required. Such software modules may execute as services on processing device 604 or can be injected into target application 642 using various methods. However, in either case, such software modules may exist apart from the compiled code of target application 642. The manner in which these software modules operate will be described below.
As also shown in
Storage media 616 is shown as storing remote control logic 622. Remote control logic 622 is configured to capture user input events that are generated in response to user interaction with user input component 614 when executed by processing unit 612. Other functions and features of remote control logic 622 will be described below.
Additionally, in the following, where a software module is described as performing a certain operation, it is to be understood that such operation is performed when the software module is executed by a processing unit (e.g., when remote control logic 622 is executed by processing unit 612, or when any of target application 642, controller logic 644, injection logic 646 or overlay logic 648 is executed by processing unit 632).
As shown in
At step 720, remote control logic 622 causes the captured user input events to be transmitted to controller logic 644 executing on processing device 604 via communication path 650. Any suitable communication protocol may be used to enable such transmission. In one embodiment, the communication protocol is initiated by remote control logic 622 when the execution of remote control logic 622 is initiated on remote control device 602.
At step 730, controller logic 644 converts the user input events received from remote control logic 622 into one of a predefined set of commands that will be recognizable to target application 642 and provides the commands to injection logic 646. As will be discussed below, such commands may include tap commands, drag commands, zoom in commands, or zoom out commands. However, these examples are not intended to be limiting and numerous other commands may be utilized in accordance with the various control capabilities of target application 642.
At step 740, injection logic 646 injects the commands generated during step 730 into target application 642, thereby causing target application 642 to perform operations corresponding to the injected commands. For example, injection logic 646 may inject tap, drag, zoom in or zoom out commands generated during step 730 into target application 642 and target application 642 may perform operations in accordance with such commands. The injection of the commands into target application 642 may be carried out in one embodiment by hooking functions of target application 642, although this is only one approach.
In accordance with the foregoing method of flowchart 700, the step of converting the user input events captured by remote control logic 622 into commands that will be recognizable to target application 642 is performed by controller logic 644 installed on processing device 604. However, in an alternate embodiment, such conversion step may instead be performed by remote control logic 622 itself
As shown in
In a still further embodiment, the step of converting the user input events captured by remote control logic 622 into commands that will be recognizable to target application 642 is performed by a third device that is not remote control device 602 or display device 604. For example, the third device may be an intermediate device that comprises a node along communication path 650. Such third device may receive user input events transmitted by remote control logic 622, convert the user input events into commands recognizable by target application 642, and then transmit the commands to controller logic 644.
Referring again to system 300 of
As shown in
At step 930, user input events captured by remote control logic 322 are converted into a command that occurs or is initiated at the hotspot location. For example, as will be discussed below, user input events captured by remote control logic 322 may be converted into a tap command that occurs at the hotspot location or a drag command that is initiated at the hotspot location although these are only a few examples. This conversion step may be performed, for example, by controller logic 344 of display device 304 in accordance with step 430 of flowchart 400 or by remote control logic 322 of remote control device 302 in accordance with step 520 of flowchart 500.
In accordance with an embodiment, the user may interact with user input component 314 to change the location of the hotspot on display 334 and overlay logic 348 may cause the location of the visually-perceptible indicator to be changed in a corresponding manner.
In the following sub-sections II.A, II.B and II.C, various example methods will be described by which a user may interact with user input component 314 of remote control device 302 to manage the location of a hotspot on display 334 and to perform a tap, drag, or zoom in/zoom out in association with such hotspot. The various methods used will depend upon the particular implementation of system 300. Although certain components of system 300 will be referred to in the examples below, it is to be understood that similar techniques may also be used by system 600 to enable a user to interact with user input component 614 of remote control device 602 to manage the location of a hotspot on display 652 and to perform a tap, drag or zoom in/zoom out in association with such hotspot. Furthermore, the examples discussed below will assume that user input component 314 comprises a touch-based user input component. However, this need not be the case. The examples provided in the following sub-sections are not intended to be limiting and persons skilled in the relevant art(s) will appreciate that further methods for performing such operations can be conceived of.
A. Tap Functionality
The following describes example ways by which “tap” functionality can be implemented by system 300 in
Once the hotspot is situated at a desired screen location, the user may initiate a tap command at the hotspot location. The manner in which the user initiates the tap command may vary depending upon the implementation. In one embodiment, the user taps any position on a surface of user input component 314 with a second finger while the first finger (i.e., the finger that was used to select the hotspot location) continues to touch the surface of user input component 314. In accordance with such an embodiment, the user can easily move the hotspot location to a target position on display 334 using a first finger and then initiate a tap command at the target location using his second finger. In further accordance with such an embodiment, the entire surface of user input component 314 may be used as a hotspot control area. This is illustrated in
In an alternate embodiment, the user initiates the tap command at the hotspot location by tapping an area on the surface of user input component 314 dedicated to tap commands. By way of example,
In another embodiment, the user initiates the tap command by simply tapping anywhere on the surface of user input component 314. For example, it is possible to identify such interaction as representing a tap command by measuring an amount of time that passes from when the user's finger first touches the touch pad/touch screen to a time when the user's finger is removed and then comparing the measured time to a predetermined maximum time (e.g., 100 milliseconds). If the amount of time is less than the predetermined maximum time, then the interaction is determined to represent a tap command as opposed to some other command, such as a drag or move command.
In a further embodiment in which the ANDROID™ operating system is used, a tap event may be captured by using the function View.OnClickListener. Such function is documented at the ANDROID™ developer website. (http://developer.android.com/reference/android/view/View.OnClickListener.html).
When the user events that are determined to comprise a tap event are generated, those user events are converted into a tap command that occurs at the current hotspot location and provided to injection logic 346 which inserts such tap command into target application 342.
B. Drag Functionality
The following describes example ways by which “drag” functionality can be implemented by system 300 in
In one embodiment, a user may use a first finger to move the hotspot to a desired location on display 334 in a manner similar to that described above in reference to tap functionality. Once the hotspot is situated at a desired screen location, the user may initiate a drag command at the hotspot location by pressing a second finger on the surface of user input component 314 and not removing it. While the second finger is so situated, any future move of the first finger will trigger drag commands. Such an implementation may be used, for example, in conjunction with touch-based user interface component 1100 of
In an alternate embodiment, a user initiates the drag command at the hotspot location by pressing an area on the surface of user input component 314 dedicated to drag commands. By way of example, continued reference is made to touch-based user interface component 1200 of
In a further embodiment in which the ANDROID™ operating system is used, a drag event may be captured by using the function View.OnDragListener. Such function is documented at the ANDROID™ developer website. (http://developer.android.com/reference/android/viewNiew.OnDragListener.html).
It is noted that alternate embodiments may use different combinations of state machines, finger combinations and areas on user input component 314 in order to move the hotspot and remotely control target application 334.
C. Scale (Zoom) Functionality
Zoom is typically implemented by applications that identify two drag operations being performed by two fingers at the same time. Zoom in is typically triggered by the fingers moving away from each other and zoom out is typically triggered when the two fingers are moved closer to each other.
One example of how a zoom operation may be implemented using touch-based user input component 1100 of
An example of how a zoom operation may be implemented using touch-based user input component 1200 of
Again, it is noted that alternate embodiments may use different combinations of state machines, finger combinations and areas on user input component 314 in order to move the hotspot and remotely control target application 334.
Various technical details relating to specific implementations of system 300 will now be provided. By way of example, the following functionality may be implemented in a system in which display device 304 is executing the ANDROID™ operating system:
1. Remote control logic 322 uses Override Activity::dispatchTouchEvent(MotionEvent ev) to obtain all user input events and send them to display device 304.
2. Injection logic 346 uses the function Instrumentation::sendPointerSync(event) to inject the desired commands into target application 342.
3. In order to present an overlay cursor (or other visually-perceptible indicator of the hotspot) overlay logic 348 may use the following functionality:
4. Hooking functions of target application 342 can be done in advance for example by changing target application 342 without the need to recompile source code associated therewith. In order to change the original application, the example process includes:
5. In order to hook functions of target application 342, the following may be implemented:
The code below demonstrates how Smali code is manipulated.
A sample target application:
The following is sample code that implements ActivityEx. This code is placed in the same folder to be compiled with the original sample application:
This is the modified original application:
As demonstrated, all references to Activity are changed to ActivityEx, which is implemented by the additional code. As a result, activity methods are intercepted and can be manipulated and additional code can be inserted into the original application.
It is important to mention that the same functionality can be achieved in other ways and this is only one example of a way to create an overlay cursor (or other visually-perceptible indicator) and to inject commands into an application in ANDROID™. One additional way to add code into an application, for example, is to provide an application programming interface (API) to the developer that implements the same Activity override and the application developer uses this class when he implements the application.
Furthermore, although the foregoing describes techniques for presenting a visually-perceptible indication of a hotspot location to a display of a display device, persons skilled in the relevant art(s) will readily appreciate that similar techniques may be use to present other content to the display of the display device. For example, in an embodiment, similar techniques may be used to present a visually-perceptible indication of multiple hotspot locations (e.g., to support multi-touch control schemes) to the display device, to present an image of a gamepad or other controller to the display device, or to display any other content that would not normally be rendered by the target application itself.
As discussed above, embodiments of the present invention enable applications designed exclusively for use on a touch-based mobile device (e.g., ANDROID™ applications) to be used on a television as well as on mobile devices such as smart phones.
Accordingly, it may be deemed desirable to allow users to utilize an application on a television and then maintain the state of that application so that the user can seamlessly continue to use the same application on a mobile device. For example, where the application is a video game, it may be desired to allow a user to play the video game on the television and then continue the same video game on a mobile device when he is on the road or otherwise outside his homes. The user's game play would ideally continue from the same place that he left off when playing on the television. Then, when the user returns home, he should be allowed to continue playing from the same point at which he left off on the mobile device.
Since, in this scenario, the same application is running on both devices, it is possible to add code to the application code that performs as follows:
1. When the game starts, check to see if there is save data on a network server for this user.
2. When the game launches, the game uses the save data that is stored locally.
3. When the game ends, allow the user to upload or automatically upload the saved data to the network server.
4. Any time a device executes the application, follow the foregoing steps 1-3.
As demonstrated in the steps above, saved data is maintained and thus the user is allowed to continue game state from one device to the other. An additional advantage of the foregoing method is that it allows the user to backup his application data on a network server so if the user changes to a new device he can restore the save data of those applications that are backed up.
In order to distinguish between users, the first time a user uses this functionality on a device he may be required to authenticate. This way, multiple users can save data on the same server. Each user's data may be maintained, for example, in a designated folder according to the unique user ID. In addition, each application may have a unique ID. Thus, for each user, saved data per application is saved for example under a folder per application ID.
In addition, for each application, the user may opt to save history information on the server. Then, if the user would like to restore application data, he can select from different save points. For example, a folder may be created according to the date and time the save data was uploaded to the server.
In addition, in order to implement the foregoing, it may be required to identify where saved data is located for each application. In order to do that, the application may be executed in a test environment and a test engineer may search for the target folder or folders for the application. The obtained information may be maintained by the code that is added to the application. For example, such information may be stored in a configuration file.
Another option that may be used is to provide API functionality to the application developer such as: an API to upload the data to the server such as UploadData(UserId, AppId, RestorePoint, Data) and an API to restore the data such as DownloadData(UserId, AppId, RestorePoint, Data). Additional APIs can be provided such as EnumDataRestore that will return data about restore points to allow the user to select one.
In recent years, new technologies have been developed that enable an electronic device (such as a personal computer, tablet computer, smart phone, or the like) to wirelessly stream video content that would normally be displayed on a display of the electronic device to a remote display device, such as a television, for viewing thereon. Such technology may also enable the streaming of audio content from the electronic device to the remote display device or an audio system associated therewith. Examples of such technologies include Wi-Fi Display and Apple AirPlay®.
It is possible that the aforementioned technologies may be used to stream video or graphics content generated by a video game application executing on the electronic device to the remote display device. Such video game applications are often programmed to enable a user to play the game by interacting with a touch screen that overlays the display of the electronic device. The touch screen and display, taken together, comprise a touch-screen display. Such interaction often involves targeted interaction with certain elements displayed on the touch-screen display. This creates a problem when the video/graphics content is being streamed to the remote display device, in that the game player will be required to somehow both view the video/graphics content being displayed on the remote display device and also interact with in a targeted manner with the touch screen display of the electronic device. Thus, in order to play the game when the video/graphics content of the game is being streamed to the remote display device, some alternative means for controlling or otherwise interacting with the video game must be provided, wherein such alternative means was not originally provided for by the video game.
As further shown in
Touch-screen display 1314 may be used to provide touch-based user input in a well-known manner.
In accordance with this example implementation, a target application 1322 (such as a video game application or other application) is stored in storage media 1316 and is executed by processing unit 1312. In one embodiment, target application 1322 comprises a video game application, although target application 1322 may comprise other types of applications as well.
As further shown in
The foregoing approach allows a custom “hotspot-based” control scheme to be used to interact with target application 1322 even though target application 1322 may not have been designed to be controlled in such a manner. The “hotspot-based” control scheme may be similar to that described above in reference to other previously-described embodiments in that it allows a user of target application 1322 to carry out targeted interaction with video/graphics content being displayed on remote display device 1304 without having to take his eyes off of remote display device 1304. A primary difference between this embodiment and the embodiments described above is that in this embodiment, target application 1322, controller logic 1328, injection logic 1324, and overlay logic 1326 are all executed on electronic device 1302 and remote display device 1304 is simply used to display video/graphics content generated by target application 1322 (with a hotspot overlaid thereon by overlay logic 1326) and transmitted thereto via communication path 1350.
In another embodiment, target application 1322 can operate in two modes: (1) a “normal” mode in which target application 1322 executes and is controlled by a person that is actually looking at touch-screen display 1314 of electronic device 1302; and (2) a “remote view” mode that may be initiated by the user and in which the video/graphics content generated by target application 1322 is streamed to a remote display device such as remote display device 1304. In the latter mode, injection logic 1324 is used to alter the control mode of target application 1322. In the latter mode, it is also possible to display via touch-screen display 1314 an alternative view that can show a remote control pad while the actual application view is streamed to the remote display device. In order to control the modes, the user may be provided with an option included within an interface of target application 1322 itself to switch execution modes.
The software logic that executes the “hotspot-based” control scheme may be implemented in various ways depending upon the implementation. For example, the required code may be injected into the executable code of target application 1322. As another example, an application programming interface (API) may be provided to the developer of target application 1322, so that the developer can compile the required code into the executable code of target application 1322. As a still further example, the required code may actually be included as part of the operating system of mobile electronic device 1302 and can be initiated by calling the operating system API that will enable the control scheme.
The embodiments described herein, including systems, methods/processes, and/or apparatuses, may be implemented using a processor-based computing system, such as a system 1400 shown in
System 1400 can represent any commercially-available and well-known processor-based computing system or device capable of performing the functions described herein. System 1400 may comprise, for example, and without limitation, a desktop computer system, a laptop computer, a tablet computer, a smart phone or other mobile device with processor-based computing capabilities.
System 1400 includes a processing unit 1404. In one embodiment, processing unit 1404 comprises one or more processors or processor cores. Processing unit 1404 is connected to a communication infrastructure 1402, such as a communication bus. In some embodiments, processing unit 1404 can simultaneously operate multiple computing threads.
System 1400 also includes a primary or main memory 1406, such as random access memory (RAM). Main memory 1406 has stored therein control logic 1428A (computer software), and data.
System 1400 also includes one or more secondary storage devices 1410. Secondary storage devices 1410 include, for example, a hard disk drive 1412 and/or a removable storage device or drive 1414, as well as other types of storage devices, such as memory cards and memory sticks. For instance, system 1400 may include an industry standard interface, such a universal serial bus (USB) interface for interfacing with devices such as a memory stick. Removable storage drive 1414 represents a floppy disk drive, a magnetic tape drive, a compact disk drive, an optical storage device, tape backup, etc.
Removable storage drive 1414 interacts with a removable storage unit 1416. Removable storage unit 1416 includes a computer useable or readable storage medium 1424 having stored therein computer software 1428B (control logic) and/or data. Removable storage unit 1416 represents a floppy disk, magnetic tape, compact disk, DVD, optical storage disk, or any other computer data storage device. Removable storage drive 1414 reads from and/or writes to removable storage unit 1416 in a well known manner.
System 1400 also includes input/output/display devices 1422, such as displays, keyboards, pointing devices, touch screens, etc.
System 1400 further includes a communication or network interface 1418. Communication interface 1418 enables system 1400 to communicate with remote devices. For example, communication interface 1418 allows system 1400 to communicate over communication networks or mediums 1442 (representing a form of a computer useable or readable medium), such as LANs, WANs, the Internet, etc. Communication interface 1418 may interface with remote sites or networks via wired or wireless connections.
Control logic 1428C may be transmitted to and from system 1400 via communication medium 1142.
Any apparatus or manufacture comprising a computer useable or readable medium having control logic (software) stored therein is referred to herein as a computer program product or program storage device. This includes, but is not limited to, system 1400, main memory 1406, secondary storage devices 1410, and removable storage unit 1416. Such computer program products, having control logic stored therein that, when executed by one or more data processing devices, cause such data processing devices to operate as described herein, represent embodiments of the invention.
Devices in which embodiments may be implemented may include storage, such as storage drives, memory devices, and further types of computer-readable media. Examples of such computer-readable storage media include a hard disk, a removable magnetic disk, a removable optical disk, flash memory cards, digital video disks, random access memories (RAMs), read only memories (ROM), and the like. As used herein, the terms “computer program medium” and “computer-readable medium” are used to generally refer to the hard disk associated with a hard disk drive, a removable magnetic disk, a removable optical disk (e.g., CDROMs, DVDs, etc.), zip disks, tapes, magnetic storage devices, MEMS (micro-electromechanical systems) storage, nanotechnology-based storage devices, as well as other media such as flash memory cards, digital video discs, RAM devices, ROM devices, and the like. Such computer-readable storage media may store program modules that include computer program logic for performing, for example, any of the steps described above in the flowcharts of
The invention can work with software, hardware, and/or operating system implementations other than those described herein. Any software, hardware, and operating system implementations suitable for performing the functions described herein can be used.
While various embodiments have been described above, it should be understood that they have been presented by way of example only, and not limitation. It will be apparent to persons skilled in the relevant art(s) that various changes in form and details can be made therein without departing from the spirit and scope of the invention. Thus, the breadth and scope of the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
This application claims priority to U.S. Provisional Patent Application Ser. No. 61/553,622 filed on Oct. 31, 2011. This application is also a continuation-in-part of U.S. patent application Ser. No. 13/220,950, filed Aug. 30, 2011, which claims priority to U.S. Provisional Patent Application No. 61/379,288, filed Sep. 1, 2010. The entirety of each of these applications is incorporated by reference herein.
Number | Date | Country | |
---|---|---|---|
61553622 | Oct 2011 | US | |
61379288 | Sep 2010 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 13220950 | Aug 2011 | US |
Child | 13663084 | US |