|Publication number||US6307570 B1|
|Application number||US 08/993,746|
|Publication date||Oct 23, 2001|
|Filing date||Dec 19, 1997|
|Priority date||Mar 31, 1997|
|Publication number||08993746, 993746, US 6307570 B1, US 6307570B1, US-B1-6307570, US6307570 B1, US6307570B1|
|Inventors||Andrew L. Stergiades|
|Original Assignee||Citrix Systems, Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (19), Non-Patent Citations (3), Referenced by (20), Classifications (6), Legal Events (5)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This application claims priority to co-pending provisional patent application Ser. No. 60/042,199, filed on Mar. 31, 1997, the contents of which are incorporated herein by reference.
The present invention relates to a method and object for controlling the execution of an application program on a server from an associated client and, in particular, to controlling the operation and display of an input device application on a server from an associated client node.
Electronic computing devices exist that do not have traditional text input capabilities, i.e. keyboards or key number pads. Such devices may not have keyboards or number pads because of their physical size, e.g. hand-held personal digital assistants, or because it is not convenient to use the device with a keyboard, e.g. an Internet appliance which is designed to connect to a common television set and is operable only by a television remote control.
Although such devices do not have keyboards or key number pads, it is often necessary for the devices to possess traditional text input capabilities. For example, a user of an Internet appliance may need to type in a Uniform Resource Locator (URL) address in order to direct the Internet appliance to display a particular page of interest. This URL address requires alphanumeric data entry, which traditionally has been done by a keyboard.
Some information appliances attempt to solve this problem by providing a software “pop-up” keyboard. Software “pop-up” keyboards are screen displays that are local to the device and allow the user to enter alphanumeric information by navigating the screen display on the local device.
Although these software devices enable traditional text input capabilities in electronic devices lacking keyboards and key pads, because they are local to the device they: occupy the memory space of the local device, which may be limited; require complex or unwieldy screen management techniques in order to distinguish keyboard events and other program events; and are not client-node independent, which limits the number of server applications that may be able to accept input from them.
The present invention relates to a remote system level soft input object and a method for creating and managing a remote system level soft input object on a server from a client node. This allows a client node, which requires traditional text input capabilities to provide keyboard or key pad functionality to a user. In addition, because the object is created and managed on the server, local memory space is preserved for local applications, local screen management is kept simple because the local application which the user is running is never displaced by the soft input object, and the input object format may be adjusted to allow the user to communicate with the server application in a way that is familiar to the user, e.g. a QWERTY keyboard, a Dvorak-style keyboard, or a traditional keypad.
In one aspect, the invention relates to a method for controlling the display of an input device application, which is hosted by and executes on a server. The method includes the steps of receiving a change-of-state protocol packet from a client node and, in response to the protocol packet, changing the state of the input device application. The protocol packet may be a “raise display” protocol packet which causes the server to display the input device or it may be a “lower display” protocol packet which causes the server to stop displaying the input device.
In another aspect the invention relates to a method for providing input to an application which is executing on a server. The method includes the steps of receiving a change-of-state protocol packet from a client node and, in response to receiving the packet, changing the state of an input device application which is hosted by, and executes on, the server. Input is received from the client node and is interpreted as input to the input device application. The input to the input device application generates an input to the application which is running on the server.
The invention is pointed out with particularity in the appended claims. The advantages of this invention described above, as well as other advantages, may be better understood by referring to the following description taken in conjunction with the accompanying drawings.
FIG. 1 is a flowchart of the steps to be taken by a server to allow a client node to control execution of an input application device.
In brief overview, a method for controlling the display of an input device application comprises the steps of receiving a change-of-state protocol packet from a client node and changing the state of an input device application running on * 5 the server in response to the change-of-state protocol packet. When reference is made to a change-of-state protocol packet throughout the specification, it is meant to be understood that such change-of-state protocol packet may be an “on” packet or an “off” packet.
The server receives a change-of-state protocol packet which is transmitted over a network. The network may be any network which can transmit data, such as an electrical, fiber optic, or a wireless network. The client node which sends the change-of-state protocol packet may also be a client application running on a server node.
The client node may transmit a change-of-state protocol packet in response to any one of a number of inputs. For example, a “hot key” may be defined on an input device associated with the node running the client application that, when activated, sends a change-of-state protocol packet. Alternatively, a pattern of inputs, e.g. a series of mouse clicks, may be interpreted as a command to send a change-of-state protocol packet. In another embodiment, the client node may provide a user with a screen cursor that, when moved into a predefined “hot zone” of a display screen, indicates that a change-of-state protocol packet is to be sent.
Once the change-of-state protocol packet is received by the server, the server changes the state of the input device application. For cases in which an “on” change-of-state protocol packet is received, the server initiates execution of the input device application. Similarly, for cases in which an “off” change-of-state protocol packet is received, the server terminates execution of the input device application. In other embodiments, the change-of-state protocol packet may toggle the state of the input device application.
The input application device is hosted by, and executes on, the server and can be any kind of program which provides an input/output device with which the user interacts. For example, the program may be an object which responds to input and produces output, or it may be a subroutine or other traditional software implementation. The input device application may provide the user with a keyboard that is a traditional QWERTY style keyboard or it may provide the user with a keyboard in any one of a number of different standard formats, such as a Dvorak keyboard. Alternatively, the input device application may provide the user with a different form of input, such as a key pad, a series of buttons having a predefined function associated with them, or a drum-styled input display.
FIG. 1 is a flowchart of the steps to be taken by a server which allows an input device application to be controlled from a client node. A client lacking traditional text input capabilities is in communication with a server. The server executes an application for the client with which the client node interacts. When the client node needs to input text in order to interact with the application running on the server, the client node sends a change-of-state protocol packet to the server instructing the server to begin execution of an input/output application device.
The server receives the transmitted change-of-state protocol packet (step 202) and determines if it is running the appropriate input device application (step 204). The server may provide only one input device application which can be requested by the client node or the change-of-state protocol packet may include information which indicates to the server which input device application the client node requests.
If the requested input device application is not already executing on the server, the server “raises” the input device application, e.g. a keyboard, which allows the user to input alphanumeric text (step 206). “Raising” an input device application means that the server executes the input device application. When the input device application starts, it displays a graphical representation of an input device. The graphical display of the input device is transmitted to the client node. Although the server displays the input application device to the client node, the window currently accepting input, termed “having focus”, is not shifted to the input application device window but remains with the application the client is running.
The input application device accepts input from the client node based on whatever input device is available to the client node. For example, if the client node has only a mouse, then the input application device can respond to the position of the cursor on the client node screen, as well as mouse clicks to indicate depressing a button of the keyboard. The server interprets the client node input as input to the input application device (step 208). This is accomplished by providing the input device application window with an attribute indicating that the input device application window is to always stay on top of z-order, i.e., it is always the top window displayed. However, the input device application window does not get the “focus” unless it receives a mouse click on its title bar. Therefore, the input device application will remain displayed over other windows even when it does not have the focus.
In other embodiments, the server may display the application to a client node having an electronic touch screen which receives client node may be provided with a graphic tablet, trackball, or light pen which may be used to interact with the input device application.
Once the client node is finished inputting text, it sends another change-of-state protocol packet to the server instructing the server to terminate execution of the input application device. When the server receives the change-of-state protocol packet (step 210), it “lowers” the input application device, which means that it stops displaying the keyboard on its screen and it terminates execution of the software program (step 212).
Having described certain embodiments of the invention, it will now become apparent to one of ordinary skill in the art that other embodiments incorporating the concepts of the invention may be used. Therefore, the invention should not be limited to certain embodiments, but rather should be limited only by the spirit and scope of the following claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5289574 *||Sep 17, 1990||Feb 22, 1994||Hewlett-Packard Company||Multiple virtual screens on an "X windows" terminal|
|US5483466 *||Nov 15, 1993||Jan 9, 1996||Hitachi, Ltd.||Client/server system and mail reception/display control method|
|US5548723 *||Dec 17, 1993||Aug 20, 1996||Taligent, Inc.||Object-oriented network protocol configuration system utilizing a dynamically configurable protocol stack|
|US5583563 *||Jan 12, 1995||Dec 10, 1996||Us West Marketing Resources Group, Inc.||Method and system for delivering an application in an interactive television network|
|US5625683||Mar 25, 1996||Apr 29, 1997||Motorola, Inc.||Method of and telephone with call-reminding and auto-dialing|
|US5640540 *||Feb 13, 1995||Jun 17, 1997||International Business Machines Corporation||Method and apparatus for translating key codes between servers over a conference networking system|
|US5655218||Feb 16, 1996||Aug 5, 1997||Motorola, Inc.||Radiotelephone communication unit displaying chronological information|
|US5684861||Dec 4, 1995||Nov 4, 1997||Lewis; Walter F.||Apparatus and method for monitoring cellular telephone usage|
|US5918020 *||Feb 28, 1997||Jun 29, 1999||International Business Machines Corporation||Data processing system and method for pacing information transfers in a communications network|
|US5928324 *||Aug 20, 1997||Jul 27, 1999||International Business Machines Corporation||Data processing system, and method having a server handling output request from a display terminal and forwarding access request to client system|
|US5983273 *||Sep 16, 1997||Nov 9, 1999||Webtv Networks, Inc.||Method and apparatus for providing physical security for a user account and providing access to the user's environment and preferences|
|US5999180 *||Sep 4, 1996||Dec 7, 1999||Ncr Corporation||Method and system for generating a configuration file using an X-windows server configuration tool|
|US5999950 *||Aug 11, 1997||Dec 7, 1999||Webtv Networks, Inc.||Japanese text input method using a keyboard with only base kana characters|
|US6018806 *||Oct 16, 1995||Jan 25, 2000||Packard Bell Nec||Method and system for rebooting a computer having corrupted memory using an external jumper|
|US6034689 *||Jun 3, 1996||Mar 7, 2000||Webtv Networks, Inc.||Web browser allowing navigation between hypertext objects using remote control|
|DE19602718A1||Jan 26, 1996||Jul 31, 1997||Loewe Opta Gmbh||Telephone call set=up influencing method by notifying user of incurred charges|
|EP0734144A2||Mar 4, 1996||Sep 25, 1996||Siemens Aktiengesellschaft||Method and apparatus for determination of user charges in a subscriber apparatus|
|WO1994028670A1||May 30, 1994||Dec 8, 1994||Juho Laatu||A method for indicating the charge of a call, and a subscriber station|
|WO1998052344A1||May 12, 1998||Nov 19, 1998||Ericsson Telefon Ab L M||Communication method, system, and device for reducing processor load at tariff switch|
|1||"WebTV System Guide", http//developer.webtv.net/authoring/sysgde/sysgde.html, printed Sep. 13, 2000, 12 pages.|
|2||Screenshot of calculator application that is part of Microsoft(R) Windows(R) Operating System, 1 page.|
|3||Screenshot of calculator application that is part of Microsoft® Windows® Operating System, 1 page.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7450128||Nov 15, 2004||Nov 11, 2008||Hewlett-Packard Development Company, L.P.||Systems and methods of providing image copy and modify commands to a receiver with an associated display|
|US7574662 *||Jun 21, 2004||Aug 11, 2009||Cisco Technology, Inc.||Remote document sharing|
|US7817849||Aug 18, 2005||Oct 19, 2010||Hewlett-Packard Development Company, L.P.||Method and apparatus for graphical data compression|
|US7937370||Feb 21, 2007||May 3, 2011||Axeda Corporation||Retrieving data from a server|
|US7966418||Feb 20, 2004||Jun 21, 2011||Axeda Corporation||Establishing a virtual tunnel between two computer programs|
|US8055758||Aug 14, 2006||Nov 8, 2011||Axeda Corporation||Reporting the state of an apparatus to a remote computer|
|US8060886||Feb 12, 2007||Nov 15, 2011||Axeda Corporation||XML scripting of SOAP commands|
|US8065397||Dec 26, 2006||Nov 22, 2011||Axeda Acquisition Corporation||Managing configurations of distributed devices|
|US8108543||Apr 17, 2002||Jan 31, 2012||Axeda Corporation||Retrieving data from a server|
|US8291039||May 11, 2011||Oct 16, 2012||Axeda Corporation||Establishing a virtual tunnel between two computer programs|
|US8370479||Oct 3, 2006||Feb 5, 2013||Axeda Acquisition Corporation||System and method for dynamically grouping devices based on present device conditions|
|US8406119||Sep 29, 2006||Mar 26, 2013||Axeda Acquisition Corporation||Adaptive device-initiated polling|
|US8752074||Oct 4, 2011||Jun 10, 2014||Axeda Corporation||Scripting of soap commands|
|US8762497||Dec 19, 2011||Jun 24, 2014||Axeda Corporation||Retrieving data from a server|
|US8769095||Dec 26, 2012||Jul 1, 2014||Axeda Acquisition Corp.||System and method for dynamically grouping devices based on present device conditions|
|US8788632||Oct 4, 2011||Jul 22, 2014||Axeda Acquisition Corp.||Managing configurations of distributed devices|
|US8898294||Oct 3, 2011||Nov 25, 2014||Axeda Corporation||Reporting the state of an apparatus to a remote computer|
|US9002980||Sep 13, 2012||Apr 7, 2015||Axeda Corporation||Establishing a virtual tunnel between two computer programs|
|US20050257196 *||May 17, 2004||Nov 17, 2005||Gideon Hollander||System and method for developing new services from legacy computer applications|
|US20060103657 *||Nov 15, 2004||May 18, 2006||John Marks||Systems and methods of providing image copy and modify commands to a receiver with an associated display|
|U.S. Classification||715/744, 709/203, 345/156|
|Dec 19, 1997||AS||Assignment|
Owner name: CITRIX SYSTEMS, INC., FLORIDA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:STERGIADES, ANDREW L.;REEL/FRAME:008941/0875
Effective date: 19971215
|Jun 2, 2000||AS||Assignment|
|Apr 4, 2005||FPAY||Fee payment|
Year of fee payment: 4
|Apr 23, 2009||FPAY||Fee payment|
Year of fee payment: 8
|Mar 6, 2013||FPAY||Fee payment|
Year of fee payment: 12