1. Technical Field
The present disclosure relates to communication devices, and, more particularly, to hand-held mobile communication devices.
2. Discussion of Related Art
Many leading technology companies have provided approaches to remotely control another computer. One example is Virtual Network Computing (VNC®) which provides a graphical desktop sharing system that uses a remote frame buffer (RFB®) protocol to remotely control another computer. (VNC and RFB are registered trademarks of RealVNC Ltd.) Keyboard and mouse events are transmitted from one computer to another, relaying graphical screen updates in the other direction over a network. Another example is Windows® Remote Desktop Service, which is one of the components of Microsoft® Windows® (both server and client versions), that utilizes a proprietary remote desktop protocol (RDP) which allows a user to access applications and data on a remote computer over a network. (Microsoft and Windows are registered trademarks of Microsoft Corporation.)
As hand-held mobile devices become more popular for enterprise and consumer applications, there is an emerging trend to be able to use hand-held mobile phones to remotely access desktop computers, to enable client-server and cloud computing capabilities such that data and applications can be virtually carried on the hand-held mobile devices, all without the necessity of modification to desktop computer applications.
In accordance with exemplary embodiments of the present disclosure, an input system for hand held mobile device that can control a remote desktop service is provided. A whole desktop screen is split into several regions, only showing one part of a region on the screen of the mobile device. A virtual trackball is provided which includes a location button and trackball button. The location button operates as a virtual mouse which can be used to click on hotspots and when the virtual mouse cursor is about to cross the boundary of screen regions the next available screen region will smoothly slide onto the device screen. The trackball button is useable to quickly switch between hotspots which can be identified through local image analysis.
In accordance with an exemplary embodiment, a method for remote control of a desktop computer from a mobile device having a display includes receiving by the mobile device an image representation of a user interface of the desktop computer, scanning the image representation to detect one or more interacting objects of the image representation, generating on the display a display image having one or more of the interacting objects of the image representation, and controlling the desktop computer by interacting with the one or more of the interacting objects of the display image and sending control information back to the desktop computer.
According to an exemplary embodiment a non-transitory computer program storage device embodying instructions executable by a processor to perform remote control of a desktop computer from a hand held mobile device having a display includes instruction code for receiving by the mobile device an image representation of a user interface of the desktop computer, instruction code for scanning the image representation to detect one or more interacting objects of the image representation, instruction code for generating on the display a display image having one or more of the interacting objects of the image representation, and instruction code for controlling the desktop computer by interacting with the one or more of the interacting objects of the display image and sending control information back to the desktop computer.
According to an exemplary embodiment a mobile device for remote control of a desktop computer includes a hand-held mobile computer processing device having a display, and a non-transitory computer program storage device configured to interact with the hand-held mobile computer processing device to provide a user an ability to control a remote desktop computer by the mobile device, the non-transitory computer program storage device including instruction code for receiving by the mobile device an image representation of a user interface of the desktop computer, instruction code for scanning the image representation to detect one or more interacting objects of the image representation, instruction code for generating on the display a display image having one or more of the interacting objects of the image representation, and instruction code for controlling the desktop computer by interacting with the one or more of the interacting objects of the display image and sending control information back to the desktop computer.
According to an exemplary embodiment a method for remote control of a desktop server from a mobile device having a touch screen display screen for displaying an image of the desktop server and for desired entry input by a user is provided. The method includes receiving an image from the remote desktop server, splitting an image display on the touch screen display screen into several regions, only one region being shown on the touch screen display screen at a time, identifying and storing locations in a region of one or more interacting objects using local image analysis, configuring the display on the touch screen display screen such that a region displayed is changeable using identified locations, providing a virtual trackball configured for changing hotpots, the virtual trackball having clickable icons for controlling a cursor on the touch screen display screen, and sending back cursor position and click-action to the desktop computer.
Exemplary embodiments of the present disclosure will be more clearly understood from the following detailed description taken in conjunction with the accompanying drawings in which:
Reference will now be made in detail to the exemplary embodiments, examples of which are illustrated in the accompanying drawings, wherein like reference numerals refer to the like elements throughout.
A significant challenge for hand-held mobile devices is to be “user friendly”. A key aspect of a user friendly device lies in its user interface (UI) and input system. For example, the screen size of hand-held mobile devices is always much smaller than conventional personal computer (PC) desktops. When a whole desktop screen is shown on the screen of the hand-held mobile devices, the buttons, input boxes or icons (i.e., the clickable areas) become too small to be located using a keyboard or a trackball on the mobile devices. It also becomes difficult for a user to control the trackball to click a small button accurately.
Hotspots, are locations on a touchpad that indicate user intentions other than pointing. For example, a finger can be moved along a right edge of a touchpad to control the scroll of the window that has focus vertically or moving the finger on the bottom of the touchpad to control the scroll of the window that has focus horizontally. Some mobile devices, such as the Nokia® E61 mobile phones or Blackberry® mobile phones, have a trackball that can easily capture hotspots (Nokia is a registered trademark of Nokia Corporation. Blackberry is a registered trademark of Research in Motion Limited.) However, such hotspots only exist in the native applications or built-in browsers, and are not available for use in remote desktop services.
As such, a hand held mobile device having a virtual trackball that can control a mouse in a remote desktop computer easily, i.e., without modifying the server side in a client-server network computing relationship, has become a desirable device. This control relationship is depicted in
Referring now to
Basic components of the mobile device 10 are shown in the system block diagram of
ROM 32 stores software programs for controlling the operation of mobile device 10, although software programs may be transferred from ROM 32 to system memory 26 and executed by processor 20 from system memory 26. Touch screen driver 34 receives information from processor 20 and applies appropriate signals to display screen 14 through touch screen driver 34. Touch screen input circuit 36 provides signals indicating that an action has been taken to select a program or function by touching a corresponding icon 16 (
Referring now to
Database 42 includes at least a UI database 42a which stores all existing detected UI components (e.g. image representations), a mobile UI database 42b which stores mobile UI data, and a function database 42c which stores function data.
Image analysis module 44 receives a set of UI components, such as icons, menus, and the like, from the display of desktop server 40, for display on display screen 14 of mobile device 10. In an exemplary embodiment a VNC® system that uses the RFB® protocol may be used to provide a graphical desktop sharing system between mobile device 10 and desktop server 40.
UI component parser 46 performs a scanning function that scans the display to detect one or more interacting objects of the image representation for the display screen 14. The interacting objects may include one or more of the following types: a URL, a menu of functions, a system icon, an application icon, a system button and an application button. The interacting objects may also include metadata and a bitmap.
Mobile UI mapping module 48 performs mapping to a pre-defined mobile UI.
Control function attaching module 50 invokes one or more functions contained in one or more activated icons. The control function can be implemented by one or more of the following approaches: an icon, a glyph, a trackball glyph, a pop up message and a pop up menu. The pop up message may include an instruction set. The control function permits navigation from a first interacting object to a second interacting object. The control function may be configured to select a subgroup of interacting objects.
Mobile UI components assembler 52 re-assembles detected UI components on top of the original remote desktop image on display screen 14 to provide the desired display.
Referring now to
In an exemplary embodiment an image is received from the remote desktop server (60). The image may be received image via standard VNC or RDP.
In an exemplary embodiment the image display on display screen 14 may be split into several regions, only one region being shown on the mobile screen at a time (62). The splitting may be implemented in various ways as needed. In an exemplary embodiment, referring briefly to
Referring back to
In an exemplary embodiment static locations (e.g., for system buttons) and relative locations (e.g., for application buttons) of hotspots may be stored (66).
In an exemplary embodiment the region displayed on the desktop screen may be changeable using the identified locations (68). Detected interacting UIs (buttons, icons, etc.) are distributed in every region (for example, in
In an exemplary embodiment a virtual trackball may be provided and may be used to change hotspots (70). The virtual trackball is a virtual input system designed for a touch screen mobile device. The virtual trackball has five clickable icons, i.e., 4 arrows and a ball icon in the middle. Each arrow points to one direction. The clickable icons operate as a virtual mouse which can be used to click on hotspots. By default, the arrows control the virtual mouse (i.e., the cursor) on the display screen, which is like any physical mouse input system. When the cursor is moved to the UI component, tapping the ball icon once acts the same way as clicking a left button of a physical mouse, tapping twice quickly acts as clicking the right button of a physical mouse, and then the associated menu or popup message will be displayed (mobile device menus, and the like). The virtual trackball input can switch to hotspot mode. The four arrow icons associate with the visual cue's (e.g., focus) movement, left, right, up and down. Thus, the user can quickly jump from one UI component to another (like the Blackberry® physical trackball system). After all UI components are detected, and associated with rich metadata, the virtual trackball can leverage these metadata, and navigate among those UI components (for example, jump from one clickable icon to another one without touching everywhere on screen, or zoom-in/out of the remote desktop image).
Referring to
In an exemplary embodiment the mouse position and click-action may be sent back to the remote desktop computer via standard operations of the VNC or RDP protocols.
Referring now to
Referring first to
Referring now to
Referring now to
Those skilled in the art will appreciate that the mobile virtual desktop device in accordance with the present disclosure can cover all kinds of mobile devices that want to have remote desktop access capability (i.e., touch screen based, non-touch screen based devices like Blackberry® devices, and the like), and it provides a systematic method to re-interpret and represent the UI components embedded in a pure bitmap image received via VNC®/RDP protocol. By associating rich metadata with detected UI components, the mobile virtual desktop device in accordance with the present disclosure can increase the quality and satisfaction of the user interaction with remote desktop service in a purely mobile fashion.
The methodologies of embodiments of the present disclosure may be particularly well-suited for use in an electronic device or alternative system. Accordingly, exemplary implementations of the present disclosure may take the form of an entirely hardware embodiment or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “processor”, “circuit,” “module” or “system.” Furthermore, exemplary implementations of the present disclosure may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code stored thereon.
Any combination of one or more computer usable or computer readable medium(s) may be utilized. The computer-usable or computer-readable medium may be a computer readable storage medium. A computer readable storage medium may be, for example but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer-readable storage medium would include the following: a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain or store a program for use by or in connection with an instruction execution system, apparatus or device.
Computer program code for carrying out operations of the present disclosure may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the “C” programming language or similar programming languages. The program code may execute entirely on the user's computer, partly on the user's computer, as a stand-alone software package, partly on the user's computer and partly on a remote computer or entirely on the remote computer or server. In the latter scenario, the remote computer may be connected to the user's computer through any type of network, including a local area network (LAN) or a wide area network (WAN), or the connection may be made to an external computer (for example, through the Internet using an Internet Service Provider).
Exemplary embodiments of the present disclosure are described herein with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions.
These computer program instructions may be stored in a computer-readable medium that can direct a computer or other programmable data processing apparatus to function in a particular manner, such that the instructions stored in the computer-readable medium produce an article of manufacture including instruction means which implement the function/act specified in the flowchart and/or block diagram block or blocks.
The computer program instructions may be stored in a computer readable medium that can direct a computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.
For example,
It is to be appreciated that the term “processor” as used herein is intended to include any processing device, such as, for example, one that includes a central processing unit (CPU) and/or other processing circuitry (e.g., digital signal processor (DSP), microprocessor, etc.). Additionally, it is to be understood that the term “processor” may refer to more than one processing device, and that various elements associated with a processing device may be shared by other processing devices. The term “memory” as used herein is intended to include memory and other computer-readable media associated with a processor or CPU, such as, for example, random access memory (RAM), read only memory (ROM), fixed storage media (e.g., a hard drive), removable storage media (e.g., a diskette), flash memory, etc. Furthermore, the term “I/O circuitry” as used herein is intended to include, for example, one or more input devices (e.g., keyboard, mouse, etc.) for entering data to the processor, and/or one or more output devices (e.g., printer, monitor, etc.) for presenting the results associated with the processor.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
Although illustrative embodiments of the present disclosure have been described herein with reference to the accompanying drawings, it is to be understood that the present disclosure is not limited to those precise embodiments, and that various other changes and modifications may be made therein by one skilled in the art without departing from the scope of the appended claims.