EP0597395A1 - Multiple graphical user interface on a single display - Google Patents
Multiple graphical user interface on a single display Download PDFInfo
- Publication number
- EP0597395A1 EP0597395A1 EP93117959A EP93117959A EP0597395A1 EP 0597395 A1 EP0597395 A1 EP 0597395A1 EP 93117959 A EP93117959 A EP 93117959A EP 93117959 A EP93117959 A EP 93117959A EP 0597395 A1 EP0597395 A1 EP 0597395A1
- Authority
- EP
- European Patent Office
- Prior art keywords
- application
- operating system
- window
- function
- gui
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/44—Arrangements for executing specific programs
- G06F9/451—Execution arrangements for user interfaces
- G06F9/452—Remote windowing, e.g. X-Window System, desktop virtualisation
Definitions
- the present invention generally relates to the display of an application on the screen of a remote computer system. More particularly, a program application that runs on a first operating system is capable of being displayed on the screen of a computer system using a second different operating system such that the Graphical User Interface (GUI) of the second operating system is used to present the program application of the first operating system.
- GUI Graphical User Interface
- US 4,961,133 discusses a system for providing portability of program applications across different hardware and operating system environments.
- the transportable code is compiled and linked to create code executable by another operating system.
- US 4,855,936 is an application program interface that handles full screen input/output (I/O) display operations.
- the application program is required to determine display characteristics prior to performing full screen I/O operations and provide a buffer as output is to be performed.
- the application programming interface provides a means for allowing an application programmer to write an application without being concerned with the low level detail of full screen I/O operations. That is, the application is architecture independent with respect to the full screen I/O operations.
- Japanese patent JP 58-31438 is a system that converts messages into specific display format suitable for centralized monitoring and control. A protocol converting portion transforms a message into a specific format, as required.
- the central monitoring system established an interface for transmitting/receiving the protocol.
- each of the described references requires a client Operating System window. Further, if the client operating system supports windowed applications, such application windows are confined to the client OS window. None of the described references can display a client OS application window directly on the host OS window without the need for a client OS window.
- GUI graphical user interface
- an AIX user will appreciate being able to run an application written for OS/2 within a window in conjunction with the AIX graphical user interface. In this manner a distributed system is created wherein applications running on a first system are used remotely.
- the present invention includes at least two interconnected computer systems, each having a different operating system running thereon.
- a first system may be running the OS/2 system and a second computer the AIX system.
- the X Window System (X) is a display environment, or graphical user interface that is available from MIT (X Window System is a trademark of the Massachusetts Institute of Technology) and runs on the operating systems, such as the UNIX system, AIX operating system, and other systems based on the UNIX OS.
- This GUI includes a server (X server) that allocates display screen space for applications running on the AIX system.
- the window manager places GUI borders in the window which allow a user to interact with the application running therein.
- GUI borders include a menu bar, title bar, scroll bar, sizing features, pull down windows, and the like.
- the present invention allows a non-AIX application (such as an OS/2 application), a non X Window application, or the like, to run within the window allocated by the AIX window manager and in conjunction with the AIX (X11) GUI border contained therein.
- the non-AIX application calls are mapped into an X11 form which enables the application commands to be recognized by the X library of functional calls.
- the operating system for which this application was written, e.g. OS/2, must be compatible with the X library (X lib).
- the operating system then sends the translated OS/2 application instructions to, for example, the AIX operating system through the TCP/IP communications protocol.
- the X11 server working in conjunction with the X window manager displays the OS/2 application in the designated window along with the AIX GUI. In this manner the output of an OS/2 application will be displayed in conjunction with the AIX graphical user interface. Further, the process is reversed and input from the user , to the AIX GUI, are mapped into OS/2 application calls such that the OS/2 application can be manipulated by input to the AIX GUI.
- a central processing unit such as one of the Intel X86 processors or an IBM reduced instruction set computing (RISC) processors, is provided and interconnected to the various other components by system bus 12.
- CPU central processing unit
- RISC IBM reduced instruction set computing
- ROM Read only memory
- BIOS basic input/output system
- RAM random access memory
- I/O adapter 18 and communications adapter 34 are also interconnected to system bus 12.
- I/O adapter 18 may be a small computer system interface (SCSI) adapter that communicates with a disk storage device 20.
- Communications adapter 34 interconnects bus 12 with an outside network enabling the data processing system to communicate with other such systems.
- Input/Output devices are also connected to system bus 12 via user interface adapter 22 and display adapter 36.
- Keyboard 24, track ball 32, mouse 26 and speaker 28 are all interconnected to bus 12 via user interface adapter 22.
- Display monitor 38 is connected to system bus 12 by display adapter 36. In this manner, a user is capable of unpitying to the system through the keyboard 24, track ball 32 or mouse 26 and receiving output from the system via speaker 28 and display 38.
- the operating system such as DOS, AIX or the OS/2 system (AIX and OS/2 are Trademarks of IBM Corporation) is used to coordinate the functions of the various components shown in Figure 1.
- the computer system shown in Figure 1 is an example of the type of systems that are capable of utilizing the present invention and can be used as the host or remote system.
- FIG. 2 is a block diagram showing the various components of an interconnected system utilizing the present invention.
- a client system is generally noted by reference numeral 1.
- a client program application 3 is shown, which is a program written specifically for a particular operating system. In this case the client application, is written for the OS/2 operating system.
- the Presentation Manager (PM) 11 is provided which is a programming interface used in conjunction with the OS/2 system. The purpose of PM is to provide a consistent application program interface for application written to OS/2. Specifically, PM provides Gpi and Win API support for the OS/2 applications. That is, PM provides all of the graphics support (Gpi) and window management (WIN API) for the program applications.
- Gpi graphics support
- WIN API window management
- the calls from the PM 11 must be mapped into a form that is recognizable by the operating system running on the interconnected system.
- the X11 graphical user interface is commonly used in conjunction with systems based on the UNIX operating system (UNIX is a registered trademark licensed exclusively by X/Open Company Ltd.), such as the AIX system.
- a mapping mechanism 5 is provided which will transform the application calls into a form that is recognizable by the interconnected operating system. This mapping function will be described in more detail in conjunction with Figures 5A through 5C, described below.
- window systems i.e. GUI
- GUI window systems
- PM and OS/2 the term operating system as used herein will include the windowing system.
- the X Windows System is designed top operate across multiple operating system platforms. As described herein, the operating system on which X Windows is running will be considered as including the X Window System.
- the X Windows interface includes a library of function calls, known as the X library. This library includes commands that will control various display functions, such as input/output control of the display, keyboard, mouse, and the like. This library is essentially a collection of routines that can be used to create an X client program application.
- OS/2 application 3 essentially becomes an X client application.
- Operating system 9 is shown as the OS/2 system from IBM Corp. and provides all of the low level control and data management functions required to implement application programs on specific hardware platforms, such as the PS/2 computer system, commercially available from IBM Corporation (PS/2 is a trademark of IBM Corp.).
- the operating system 9 then communicates with a remote operating system 101 (e.g. AIX) by way of a communications protocol, such as TCP/IP, or the like.
- a communications protocol such as TCP/IP, or the like.
- the X server component 103 is running on the AIX system and provides screen management facilities for display 107. More particularly, the X server is a graphics driver that controls the system. It handles requests from an X client application to created windows, draw lines, circles, text, and the like on the computer system display screen. Further, the X server will handle keyboard and mouse input from the computer system and relays this information back to the X client.
- a window manager 105 is also part of the X Windows interface and is used to allocate screen resources between various program applications, as well as, operating system functions that require information to be displayed. The window manager is a special X client that is run (one for each X server) in order to supervise the control of windows created on the display. The window manager creates the "look and feel" of the user interface.
- the window manager is responsible for placing any border around the window, such as a title bar, control buttons to maximize or minimize the window, scroll buttons, system menu, or the like.
- the window manager also handles user input requiring movement or resizing of the window.
- the Motif window manager from the Open Software Foundation (OSF) is contemplated for use as window manager 105. It should be noted that those of skill in this art will be familiar with the operation of the X Window System components. Therefore, the function of these components will not be further discussed.
- Figure 3 is a screen on display 107 showing a typical X Windows display workplace wherein various AIX system program applications are running.
- a clock program 109 is shown along with an AIX application running in an X Window 113.
- the AIX application may be a word processing/desktop publishing application, such as Interleaf, AIX Interface Composer, or the like.
- a graphical user interface 111 is shown around the periphery of window 113. This is part of the X GUI and includes I/O features such as, software buttons, a scroll bar, pull down menus, a title bar 119, icons 121, and the like.
- GUI 115 is present around the periphery of window 117.
- GUI 115 includes all of the I/O components normally found in an X border, which includes the scroll bar, icons, and the like, previously mentioned.
- a user is capable of running a program application written for a first specific operating system (e.g. OS/2) on a platform having a second different operating system (e.g. AIX) such that the program application written for the first operating system responds to the user inputs to GUI associated with the second operating system.
- a first specific operating system e.g. OS/2
- a second different operating system e.g. AIX
- the program application will provide output to the user in accordance with the GUI from the second operating system.
- the program application may provide different titles to the window manager 105 for display on the title bar, and the scroll bar on the GUI border will change as the user scrolls through a document in a word processing application.
- the program application must provide output to the GUI in order for it to display the proper position of the scroll bar. It can be seen that not only does the present invention provide a system that allows a user to run program applications written for a different operating system, but also allows the user to interact with the application through a graphical user interface, based on the operating system resident on their system. Thus, a user can run applications written for different systems, and still be able to interact with these new applications through a familiar graphical user interface.
- FIG 4 is a screen of display 107 illustrating another embodiment of the present invention. More particularly, the same AIX applications 109, 111, 113 are shown running on the display, along with a Distributed PM application 117 running in a window having DPM border 115. In this case, the DPM GUI is displayed on top of the AIX border, such that the user sees only the DPM GUI. Additionally, it is possible to "shadow" the AIX border with the DPM border such that both are visible. In most cases both sets of functions will work and the user can use the GUI which is most familiar.
- Figures 5A-5C are representative of the operations that the present invention will perform in order to display a client application in a window of a host system. There are innumerable combinations of PM outputs that must be mapped to X lib calls. Thus, Figures 5A-5C show the basic functions of line drawing, curve drawing and text mapping. Those skilled in the art will understand how to apply, these basic mapping operations to other functions output from the client application.
- the remote, or client application is initiated.
- One way is for the host, or server system user to input a startup.cmd and syslogin.cmd commands. This method will resemble remote startup using the RSH daemon on TCP/IP.
- the application calls the WinInitialize command which checks for the Distributed PM environment.
- DPM Dynamic Link Library
- a specific dynamic linked library is called that will build a table of subroutine addresses that will convert the calls to X library recognizable commands.
- This dynamic linked library (DLL) is provided in the PM interface application. Further, the calls from the application to the WIN and Gpi APIs in the PM interface are captured and redirected to the X library.
- Figure 3 shows a system where there is not subclassing. This means that DPM will make no change to the default setting and the local window manager will be in control.
- This is the preferred embodiment and will include an X Window System having a GUI border that includes the title bar, scroll bar, software buttons, window sizing icons, and the like associated with a standard X GUI.
- a subclassed GUI means that the DPM GUI will be displayed either in conjunction with the X GUI or written on top of the X GUI such that only the DPM border is visible.
- the PM to X mapping layer 5 is used to translate the PM calls to X recognizable commands.
- a translate table is used to accomplish this conversion.
- the X window manager normally, initializes a window and then instructs the X client application that it has permission to write to the window.
- the PM interface is used to opening a window and then immediately drawing to it.
- the PM method contemplates local, not networked systems.
- a conversion had to be made that would cause the PM interface to wait for some period of time before drawing to the X window.
- a mapping relationship was created between the PM and X systems so that the X Window handles could be recognized and manipulated by the application 3 running on the remote system.
- the window manager will also recognize input from the DPM (via the X lib and X server) that will allow the titles on the GUI title bar to be changed. For example, if the X GUI title bar includes File, Edit, Help and Options, but the DPM program application also includes the title of Tools, then the DPM command can be translated and sent to the X window manager in order to make the title bar consistent with the program application running on OS/2.
- step 3 the window has been created on the display 107 and it is then determined if the distributed PM application needs to draw lines (step 4). If so, the process continues to step 5 where the line coordinates are translated by the PM to X mapping means 5.
- line drawing is a fairly straight forward process, i.e. beginning and ending points are identified and the intermediate pixels must be painted. In the X system, the initial pixel 0,0 is at the upper right portion of the screen and with PM it is at the lower right corner. There- fore, the y coordinates of the pixels must be translated.
- the call is made (step 6) from the PM interface 11 to the X lib 7, which then outputs the equivalent X commands that will cause the line to be drawn. The line is then drawn into the window at step 7, and the operation jumps to step 17.
- step 8 determines if text is to be written into the window. If so, the DPM text characters are translated by the mapping means 5 and input to X lib 7 (step 9). Both PM and X use ASCII characters so this translation is relatively simple. However, these two systems do not necessarily use interchangeable fonts. Therefore, at step 10, the mapping means compares the PM fonts to the closest predetermined X fonts and outputs the command for these X fonts to the X lib. At step 11, the translated text is presented in the displayed in window 117 of Figure 3. Subsequent to step 11 the method proceeds to step 17.
- step 12 determines if a curve, such as a spline, is to be displayed. If so, the PM interface outputs the beginning and ending points of the curve to the mapping means (step 13).
- the X lib will not include function that corresponds to the function desired by the program application. Curves are one example of this type of function. Therefore, it was determined that support needed to be provided for a spline, which is a type of curve. In this case, the PM interface provides the coordinates for the endpoints to the mapping means. Further, the PM interface will indicate that a spline is to be drawn.
- the mapping means then provides this new functionality by calling a subroutine (step 14) which determines which pixels intermediate the endpoints must be painted in order to create the spline.
- This subroutine effectively uses the existing X lib functions to describe the shape of the curve to be displayed. Once these pixels are determined, calls are made to a standard line draw routine in the X lib 7 for these pixels. The X lib then outputs commands which will cause the appropriate pixels to be painted. It can be seen that a virtually unlimited amount of new function may have to be supported in the mapping means, in order to support the function that is continuously being added to new applications being written.
- the output from the X lib, that represents the curve is provided to the X server so the curve can be drawn in the window (step 16).
- step 12 determines if there are any other application output requests to be processed. If so, step 23 maps the output from PM into an X call. Step 24 then makes the call to the X lib and the display is output on the window at step 25. If there are no other application output requests, then the process moves directly from step 22 to step 17.
- step 17 it is determined if the host system user (AIX) will interact with the remote application (OS/2) by entering input. If not, the process continues to step 26. If the application does allow for user interaction, at step 18, an identifier is returned to the X server 103. This identifier will be in the form of a number that corresponds to keystrokes, or mouse position/click information. At step 19, the mapping means 5 will translate the number corresponding to the X system input into a letter that is recognizable by the DPM system. A translate table is used to make this conversion which takes into account certain predetermined conditions. For example, the X system allows for one finger keyboard operation wherein a user can press shift and subsequently press, e.g.
- step 20 the method proceeds to step 26 which determines if the application program has ended. If so, the window is closed at step 21 and the process ends. However, if the program has not ended, then the method returns to step 4, and the process (subsequent to the creation of the window) is repeated.
- the main function of the mapping means 5 is to redirect calls to the PM interface (specifically, to the PM WIN and Gpi APIs) to the X lib. As described above, some of the translation is fairly straightforward. If an X lib call exists that corresponds to a PM call, then some simple parameter shuffling may be all that is required. However, as noted above, for complex graphical functions the mapping means will have to break down the function and emulate it with multiple calls to the X lib (e.g. spline subroutine). Other PM calls require the establishment of data structures to hold local context or provide a mapping from a PM structure to an X structure, as in the case of a PM window handle being mapped to an X window handle/display combination).
- mapping means allows graphical or windowed program applications run on a first system to be displayed and interacted with through a GUI running on a second different operating system.
- client application functions that must be mapped to the server system. These functions include font support, window management, cursor support (e.g. mouse pointer vs. text cursor), line drawing, curve drawing, text mapping, bitmap conversion, and the like. It has been shown that some of these functions are relatively simple (e.g. line drawing and text mapping) while others are extremely complicated (e.g. curve drawing). As a representative example of how one of the more complex functions can be mapped between the client application and the server window system, the following description is provided.
- cursor support e.g. mouse pointer vs. text cursor
- the Bitmap component of DPM is concerned with all functionality related to displaying, modifying, and querying bitmaps. Only bitmaps that have been created explicitly (i.e. that have a specific HBITMAP handle) are ever eligible to reside on the server. Since bitmaps created in other ways either cannot be monitored or are transient, there is little performance lost in sending these to the server each time.
- the server has a limited capability for storing bitmaps (pixmaps). If the server cannot store a bitmap, then previous bitmaps are removed in a least-recently-used order. Locally, these bitmaps are marked to indicate this fact.
- the fundamental bitmap structure used to track the state of a bitmap and it's server version is SERVERBITMAP.
- One of these is created in a blocked linked list for each bitmap that may be potentially displayed on a remote window.
- the blocked link list consists of bitmap structure entries that are in a standard linked list format, but are allocated in multiple count groups.
Abstract
Description
- The present invention generally relates to the display of an application on the screen of a remote computer system. More particularly, a program application that runs on a first operating system is capable of being displayed on the screen of a computer system using a second different operating system such that the Graphical User Interface (GUI) of the second operating system is used to present the program application of the first operating system.
- Currently it is known for an operating system window manager to allocate a portion of a display screen that can be used by an operating system. In particular, US 4,937,036, 4,937,507 and 4,920,481 describe systems wherein a portion of the display screen is allocated for use by a processor which emulates another processor in this window. This window will include the user interface for the emulated operating system.
- US 4,961,133 discusses a system for providing portability of program applications across different hardware and operating system environments. The transportable code is compiled and linked to create code executable by another operating system. US 4,855,936 is an application program interface that handles full screen input/output (I/O) display operations. The application program is required to determine display characteristics prior to performing full screen I/O operations and provide a buffer as output is to be performed. The application programming interface provides a means for allowing an application programmer to write an application without being concerned with the low level detail of full screen I/O operations. That is, the application is architecture independent with respect to the full screen I/O operations. Japanese patent JP 58-31438 is a system that converts messages into specific display format suitable for centralized monitoring and control. A protocol converting portion transforms a message into a specific format, as required. The central monitoring system established an interface for transmitting/receiving the protocol.
- It can be seen that the related art merely allows for a host system to allocate a specific portion of its display to a client operating system, which is either emulated from the host processor, or remotely connected. However, each of the described references requires a client Operating System window. Further, if the client operating system supports windowed applications, such application windows are confined to the client OS window. None of the described references can display a client OS application window directly on the host OS window without the need for a client OS window. A need exists for a system wherein multiple application windows from multiple client operating systems can be run as peers with hose application windows in a host operating system window. However, none of the described references show a first system, which uses its own window manager to display the first operating system GUI in a window, running a program application written for an entirely different operating system, concurrently in the same window with the first operating system GUI. Thus, it can be seen that a need exists for a system wherein multiple graphical user interfaces can be run concurrently in a single window.
- Is desirable to have the ability to use the GUI that is most familiar to a user, even when running a application program that operates in conjunction with an unfamiliar operating system, or GUI. For example, an AIX user will appreciate being able to run an application written for OS/2 within a window in conjunction with the AIX graphical user interface. In this manner a distributed system is created wherein applications running on a first system are used remotely.
- Broadly, the present invention includes at least two interconnected computer systems, each having a different operating system running thereon. For example, a first system may be running the OS/2 system and a second computer the AIX system. The X Window System (X) is a display environment, or graphical user interface that is available from MIT (X Window System is a trademark of the Massachusetts Institute of Technology) and runs on the operating systems, such as the UNIX system, AIX operating system, and other systems based on the UNIX OS. This GUI includes a server (X server) that allocates display screen space for applications running on the AIX system. Further, the window manager places GUI borders in the window which allow a user to interact with the application running therein. The functions in these GUI borders include a menu bar, title bar, scroll bar, sizing features, pull down windows, and the like. The present invention allows a non-AIX application (such as an OS/2 application), a non X Window application, or the like, to run within the window allocated by the AIX window manager and in conjunction with the AIX (X11) GUI border contained therein.
- First, the non-AIX application calls are mapped into an X11 form which enables the application commands to be recognized by the X library of functional calls. The operating system, for which this application was written, e.g. OS/2, must be compatible with the X library (X lib). The operating system then sends the translated OS/2 application instructions to, for example, the AIX operating system through the TCP/IP communications protocol. The X11 server, working in conjunction with the X window manager displays the OS/2 application in the designated window along with the AIX GUI. In this manner the output of an OS/2 application will be displayed in conjunction with the AIX graphical user interface. Further, the process is reversed and input from the user , to the AIX GUI, are mapped into OS/2 application calls such that the OS/2 application can be manipulated by input to the AIX GUI.
- These and other objects are accomplished by the invention as claimed.
- Figure 1 is a schematic representation of a typical data processing system with which the present invention can be utilized;
- Figure 2 is a block diagram showing the specific components of a system using the present invention and their relationship with one another;
- Figure 3 is a display screen of a computer system illustrating another embodiment of the present invention wherein a remote application is running in the same window with the GUI of a system using a different operating system;
- Figure 4 is a display screen of a computer system illustrating a first embodiment of the present invention wherein a remote application and its GUI are running on a system with a different operating system;
- Figures 5 A-C are flowcharts illustrating the mapping function of the present invention which allows a program application to be interactively running in a window of a display on a computer system with a different operating system wherein multiple GUI's are present.
- Referring to Figure 1, a typical data processing system is shown which may be used in conjunction with the present invention. A central processing unit (CPU) 10, such as one of the Intel X86 processors or an IBM reduced instruction set computing (RISC) processors, is provided and interconnected to the various other components by
system bus 12. Read only memory (ROM) 16 is connected toCPU 10 viabus 12 and includes the basic input/output system (BIOS) that controls the basic computer functions. Random access memory (RAM) 14, I/O adapter 18 andcommunications adapter 34 are also interconnected tosystem bus 12. I/O adapter 18 may be a small computer system interface (SCSI) adapter that communicates with adisk storage device 20. Communications adapter 34interconnects bus 12 with an outside network enabling the data processing system to communicate with other such systems. Input/Output devices are also connected tosystem bus 12 viauser interface adapter 22 anddisplay adapter 36.Keyboard 24,track ball 32,mouse 26 andspeaker 28 are all interconnected tobus 12 viauser interface adapter 22.Display monitor 38 is connected tosystem bus 12 bydisplay adapter 36. In this manner, a user is capable of unpitying to the system through thekeyboard 24,track ball 32 ormouse 26 and receiving output from the system viaspeaker 28 and display 38. Additionally, the operating system such as DOS, AIX or the OS/2 system (AIX and OS/2 are Trademarks of IBM Corporation) is used to coordinate the functions of the various components shown in Figure 1. The computer system shown in Figure 1 is an example of the type of systems that are capable of utilizing the present invention and can be used as the host or remote system. - Figure 2 is a block diagram showing the various components of an interconnected system utilizing the present invention. A client system is generally noted by
reference numeral 1. Aclient program application 3 is shown, which is a program written specifically for a particular operating system. In this case the client application, is written for the OS/2 operating system. Further, the Presentation Manager (PM) 11 is provided which is a programming interface used in conjunction with the OS/2 system. The purpose of PM is to provide a consistent application program interface for application written to OS/2. Specifically, PM provides Gpi and Win API support for the OS/2 applications. That is, PM provides all of the graphics support (Gpi) and window management (WIN API) for the program applications. - In order for the present invention to function, the calls from the
PM 11 must be mapped into a form that is recognizable by the operating system running on the interconnected system. For example, the X11 graphical user interface is commonly used in conjunction with systems based on the UNIX operating system (UNIX is a registered trademark licensed exclusively by X/Open Company Ltd.), such as the AIX system. Thus, amapping mechanism 5 is provided which will transform the application calls into a form that is recognizable by the interconnected operating system. This mapping function will be described in more detail in conjunction with Figures 5A through 5C, described below. - Generally, window systems (i.e. GUI) are tied to a specific operating system, e.g. PM and OS/2. Therefore, the term operating system as used herein will include the windowing system. It should be noted that the X Windows System is designed top operate across multiple operating system platforms. As described herein, the operating system on which X Windows is running will be considered as including the X Window System. The X Windows interface includes a library of function calls, known as the X library. This library includes commands that will control various display functions, such as input/output control of the display, keyboard, mouse, and the like. This library is essentially a collection of routines that can be used to create an X client program application. Thus, due to the mapping of the PM calls into X lib calls, the OS/2
application 3 essentially becomes an X client application.Operating system 9 is shown as the OS/2 system from IBM Corp. and provides all of the low level control and data management functions required to implement application programs on specific hardware platforms, such as the PS/2 computer system, commercially available from IBM Corporation (PS/2 is a trademark of IBM Corp.). Theoperating system 9 then communicates with a remote operating system 101 (e.g. AIX) by way of a communications protocol, such as TCP/IP, or the like. In this manner the two different, incompatible operating systems, e.g. OS/2 and AIX can communicate with one another. - The
X server component 103 is running on the AIX system and provides screen management facilities fordisplay 107. More particularly, the X server is a graphics driver that controls the system. It handles requests from an X client application to created windows, draw lines, circles, text, and the like on the computer system display screen. Further, the X server will handle keyboard and mouse input from the computer system and relays this information back to the X client. Awindow manager 105 is also part of the X Windows interface and is used to allocate screen resources between various program applications, as well as, operating system functions that require information to be displayed. The window manager is a special X client that is run (one for each X server) in order to supervise the control of windows created on the display. The window manager creates the "look and feel" of the user interface. Further, the window manager is responsible for placing any border around the window, such as a title bar, control buttons to maximize or minimize the window, scroll buttons, system menu, or the like. The window manager also handles user input requiring movement or resizing of the window. In a preferred embodiment of the present invention, the Motif window manager from the Open Software Foundation (OSF) is contemplated for use aswindow manager 105. It should be noted that those of skill in this art will be familiar with the operation of the X Window System components. Therefore, the function of these components will not be further discussed. - Figure 3 is a screen on
display 107 showing a typical X Windows display workplace wherein various AIX system program applications are running. For example aclock program 109 is shown along with an AIX application running in anX Window 113. The AIX application may be a word processing/desktop publishing application, such as Interleaf, AIX Interface Composer, or the like. Of course, many other program applications are capable of being run inwindow 113. Agraphical user interface 111 is shown around the periphery ofwindow 113. This is part of the X GUI and includes I/O features such as, software buttons, a scroll bar, pull down menus, atitle bar 119,icons 121, and the like. Anotherwindow 117 is shown ondisplay 107 which is an OS/2 system program application, such as Lotus 1-2-3, Excel, Clock, or the like running therein. Additionally, an Xsystem GUI border 115 is present around the periphery ofwindow 117.GUI 115 includes all of the I/O components normally found in an X border, which includes the scroll bar, icons, and the like, previously mentioned. In this manner, a user is capable of running a program application written for a first specific operating system (e.g. OS/2) on a platform having a second different operating system (e.g. AIX) such that the program application written for the first operating system responds to the user inputs to GUI associated with the second operating system. Further, the program application will provide output to the user in accordance with the GUI from the second operating system. For example, the program application may provide different titles to thewindow manager 105 for display on the title bar, and the scroll bar on the GUI border will change as the user scrolls through a document in a word processing application. Thus, the program application must provide output to the GUI in order for it to display the proper position of the scroll bar. It can be seen that not only does the present invention provide a system that allows a user to run program applications written for a different operating system, but also allows the user to interact with the application through a graphical user interface, based on the operating system resident on their system. Thus, a user can run applications written for different systems, and still be able to interact with these new applications through a familiar graphical user interface. - Figure 4 is a screen of
display 107 illustrating another embodiment of the present invention. More particularly, thesame AIX applications PM application 117 running in a window havingDPM border 115. In this case, the DPM GUI is displayed on top of the AIX border, such that the user sees only the DPM GUI. Additionally, it is possible to "shadow" the AIX border with the DPM border such that both are visible. In most cases both sets of functions will work and the user can use the GUI which is most familiar. - Referring to the flow charts of Figures 5A-5C, the operation of the present invention will now be described. It should be noted that Figures 5A-5C are representative of the operations that the present invention will perform in order to display a client application in a window of a host system. There are innumerable combinations of PM outputs that must be mapped to X lib calls. Thus, Figures 5A-5C show the basic functions of line drawing, curve drawing and text mapping. Those skilled in the art will understand how to apply, these basic mapping operations to other functions output from the client application.
- At
step 1 the remote, or client application is initiated. One way is for the host, or server system user to input a startup.cmd and syslogin.cmd commands. This method will resemble remote startup using the RSH daemon on TCP/IP. For example, the AIX user will issue the command:
rsh $NODE"start/dpmx=$DISPLAY my_app"
This command will cause the DPM daemon on remote node $NODE to prompt for a username and password. If the user name and password are valid the process is then started. Atstep 2, the application calls the WinInitialize command which checks for the Distributed PM environment. If the DPM exists, a specific dynamic linked library is called that will build a table of subroutine addresses that will convert the calls to X library recognizable commands. This dynamic linked library (DLL) is provided in the PM interface application. Further, the calls from the application to the WIN and Gpi APIs in the PM interface are captured and redirected to the X library. - There are two types of window GUI's that can be used, as illustrated by Figures 3 and 4. Figure 3 shows a system where there is not subclassing. This means that DPM will make no change to the default setting and the local window manager will be in control. This is the preferred embodiment and will include an X Window System having a GUI border that includes the title bar, scroll bar, software buttons, window sizing icons, and the like associated with a standard X GUI. A subclassed GUI means that the DPM GUI will be displayed either in conjunction with the X GUI or written on top of the X GUI such that only the DPM border is visible.
- At
step 3, the PM toX mapping layer 5 is used to translate the PM calls to X recognizable commands. A translate table is used to accomplish this conversion. Several problems had to be overcome in order to make this conversion. For example, the X window manager normally, initializes a window and then instructs the X client application that it has permission to write to the window. In contrast, the PM interface is used to opening a window and then immediately drawing to it. The PM method contemplates local, not networked systems. Thus, a conversion had to be made that would cause the PM interface to wait for some period of time before drawing to the X window. Further, a mapping relationship was created between the PM and X systems so that the X Window handles could be recognized and manipulated by theapplication 3 running on the remote system. The window manager will also recognize input from the DPM (via the X lib and X server) that will allow the titles on the GUI title bar to be changed. For example, if the X GUI title bar includes File, Edit, Help and Options, but the DPM program application also includes the title of Tools, then the DPM command can be translated and sent to the X window manager in order to make the title bar consistent with the program application running on OS/2. - Subsequent to step 3, the window has been created on the
display 107 and it is then determined if the distributed PM application needs to draw lines (step 4). If so, the process continues to step 5 where the line coordinates are translated by the PM to X mapping means 5. It should be noted that line drawing is a fairly straight forward process, i.e. beginning and ending points are identified and the intermediate pixels must be painted. In the X system, the initial pixel 0,0 is at the upper right portion of the screen and with PM it is at the lower right corner. There- fore, the y coordinates of the pixels must be translated. Once the translation is complete, the call is made (step 6) from thePM interface 11 to theX lib 7, which then outputs the equivalent X commands that will cause the line to be drawn. The line is then drawn into the window atstep 7, and the operation jumps to step 17. - If it is determined that there is no line to be drawn at
step 4, the operation proceeds to step 8 which determines if text is to be written into the window. If so, the DPM text characters are translated by the mapping means 5 and input to X lib 7 (step 9). Both PM and X use ASCII characters so this translation is relatively simple. However, these two systems do not necessarily use interchangeable fonts. Therefore, atstep 10, the mapping means compares the PM fonts to the closest predetermined X fonts and outputs the command for these X fonts to the X lib. Atstep 11, the translated text is presented in the displayed inwindow 117 of Figure 3. Subsequent to step 11 the method proceeds to step 17. If, atstep 8 there is no text to be drawn, then the method proceeds to step 12 which determines if a curve, such as a spline, is to be displayed. If so, the PM interface outputs the beginning and ending points of the curve to the mapping means (step 13). In many cases, the X lib will not include function that corresponds to the function desired by the program application. Curves are one example of this type of function. Therefore, it was determined that support needed to be provided for a spline, which is a type of curve. In this case, the PM interface provides the coordinates for the endpoints to the mapping means. Further, the PM interface will indicate that a spline is to be drawn. Since, there is no equivalent function in the X lib, the mapping means then provides this new functionality by calling a subroutine (step 14) which determines which pixels intermediate the endpoints must be painted in order to create the spline. This subroutine effectively uses the existing X lib functions to describe the shape of the curve to be displayed. Once these pixels are determined, calls are made to a standard line draw routine in theX lib 7 for these pixels. The X lib then outputs commands which will cause the appropriate pixels to be painted. It can be seen that a virtually unlimited amount of new function may have to be supported in the mapping means, in order to support the function that is continuously being added to new applications being written. Atstep 15, the output from the X lib, that represents the curve is provided to the X server so the curve can be drawn in the window (step 16). - If at
step 12 it was determined that no curves were to be displayed the operation skips to step 22 which determines if there are any other application output requests to be processed. If so, step 23 maps the output from PM into an X call.Step 24 then makes the call to the X lib and the display is output on the window atstep 25. If there are no other application output requests, then the process moves directly fromstep 22 to step 17. - At
step 17 it is determined if the host system user (AIX) will interact with the remote application (OS/2) by entering input. If not, the process continues to step 26. If the application does allow for user interaction, atstep 18, an identifier is returned to theX server 103. This identifier will be in the form of a number that corresponds to keystrokes, or mouse position/click information. Atstep 19, the mapping means 5 will translate the number corresponding to the X system input into a letter that is recognizable by the DPM system. A translate table is used to make this conversion which takes into account certain predetermined conditions. For example, the X system allows for one finger keyboard operation wherein a user can press shift and subsequently press, e.g. "H", and the result will be identical to pressing shift and "H" simultaneously. It can be seen that all of the various combinations of keyboard input must be taken into account when translating user input. Once the translation is completed by the mapping means 5, the corresponding PM commands are sent to thePM interface 11 and provided to theapplication 3 as input (step 20). Subsequent to step 20, the method proceeds to step 26 which determines if the application program has ended. If so, the window is closed atstep 21 and the process ends. However, if the program has not ended, then the method returns to step 4, and the process (subsequent to the creation of the window) is repeated. - The main function of the mapping means 5 is to redirect calls to the PM interface (specifically, to the PM WIN and Gpi APIs) to the X lib. As described above, some of the translation is fairly straightforward. If an X lib call exists that corresponds to a PM call, then some simple parameter shuffling may be all that is required. However, as noted above, for complex graphical functions the mapping means will have to break down the function and emulate it with multiple calls to the X lib (e.g. spline subroutine). Other PM calls require the establishment of data structures to hold local context or provide a mapping from a PM structure to an X structure, as in the case of a PM window handle being mapped to an X window handle/display combination).
- It should be understood that the above description of various translations are provided as examples and should not be considered as all of the types of translations that must be performed by the mapping means. The present invention allows graphical or windowed program applications run on a first system to be displayed and interacted with through a GUI running on a second different operating system.
- As noted above, there are many types of client application functions that must be mapped to the server system. These functions include font support, window management, cursor support (e.g. mouse pointer vs. text cursor), line drawing, curve drawing, text mapping, bitmap conversion, and the like. It has been shown that some of these functions are relatively simple (e.g. line drawing and text mapping) while others are extremely complicated (e.g. curve drawing). As a representative example of how one of the more complex functions can be mapped between the client application and the server window system, the following description is provided.
- The Bitmap component of DPM is concerned with all functionality related to displaying, modifying, and querying bitmaps. Only bitmaps that have been created explicitly (i.e. that have a specific HBITMAP handle) are ever eligible to reside on the server. Since bitmaps created in other ways either cannot be monitored or are transient, there is little performance lost in sending these to the server each time. The server has a limited capability for storing bitmaps (pixmaps). If the server cannot store a bitmap, then previous bitmaps are removed in a least-recently-used order. Locally, these bitmaps are marked to indicate this fact.
-
-
-
-
- The fundamental bitmap structure used to track the state of a bitmap and it's server version, is SERVERBITMAP. One of these is created in a blocked linked list for each bitmap that may be potentially displayed on a remote window. The blocked link list consists of bitmap structure entries that are in a standard linked list format, but are allocated in multiple count groups.
-
-
Claims (10)
- A system for displaying a program application (3), written for a first operating system, comprising:
means for allocating a portion of a computer display screen (38), and for providing a user interface, based on a second operating system;
means for enabling commands to said user inter- face to be processed by said application; and
means for displaying output from said application and said user interface in said portion of said display screen (38). - A system according to claim 1 wherein said means for displaying comprises means for mapping commands from said application (3) to commands which can be interpreted by said second operating system.
- A system according to claim 2 wherein said means for mapping comprises means for creating function in said second operating system to accommodate function present in said application (3)
- A system according to claim any preceding claims wherein said enabling means comprises:
means for interpreting commands directed to said application (3); and
means for translating said commands into a form recognizable by said application (3). - A system according to claims 3 or 4 wherein said means for creating function comprises:
means for comparing the application function with function provided by said second operating system;
means for determining the function within said second operating system related to said application function; and
means for using the function in said second operating system to simulate the application function. - A method of displaying a program application (3), written for a first operating system, comprising the steps of:
allocating a portion of a computer display screen (38), and for providing said user interface based on a second operating system;
enabling commands to said user interface to be processed by said application; and
displaying output from said application (3) and said user interface in said portion of said display screen. - A method according to claim 6 wherein said step of displaying comprises the step of mapping commands from said application (3) to commands which can be interpreted by said second operating system.
- A method according to claim 7 wherein said step of mapping comprises creating function in said second operating to accommodate function present in said application (3).
- A method according to any claim from 6 to 8 wherein said step of enabling comprises the steps of:
interpreting commands directed to said application; and
translating said commands into a form recognizable by said application. - A method according to claim 8 or 9 wherein said step of creating function comprises the steps of:
comparing the application function with function provided by said second operating system;
determining the function within said second operating system related to said application function; and
using the function in said second operating system to simulate the application function.
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US975753 | 1992-11-13 | ||
US07/975,753 US5673403A (en) | 1992-11-13 | 1992-11-13 | Method and system for displaying applications of different operating systems on a single system using the user interface of the different operating systems |
Publications (2)
Publication Number | Publication Date |
---|---|
EP0597395A1 true EP0597395A1 (en) | 1994-05-18 |
EP0597395B1 EP0597395B1 (en) | 2000-01-19 |
Family
ID=25523352
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
EP93117959A Expired - Lifetime EP0597395B1 (en) | 1992-11-13 | 1993-11-05 | Multiple graphical user interface on a single display |
Country Status (4)
Country | Link |
---|---|
US (1) | US5673403A (en) |
EP (1) | EP0597395B1 (en) |
JP (1) | JPH081624B2 (en) |
DE (1) | DE69327632T2 (en) |
Cited By (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2723225A1 (en) * | 1994-07-29 | 1996-02-02 | Sat | Co-operative working between computers with different operating systems |
GB2293470A (en) * | 1994-09-22 | 1996-03-27 | Ibm | Message encapsulation in Object Oriented Programming. |
US5767849A (en) * | 1995-08-18 | 1998-06-16 | International Business Machines Corporation | Personality neutral window management subsystem |
FR2793901A1 (en) * | 1999-05-21 | 2000-11-24 | Bull Sa | METHOD FOR CONTROLLING, FROM A DASHBOARD OF A CLIENT STATION, A PROCESS EXECUTING A SERVER |
DE19654766B4 (en) * | 1995-12-29 | 2004-11-18 | Wyse Technology, Inc., San Jose | Terminal for displaying application information in a window environment |
US7720672B1 (en) | 1995-12-29 | 2010-05-18 | Wyse Technology Inc. | Method and apparatus for display of windowing application programs on a terminal |
Families Citing this family (128)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6195710B1 (en) * | 1995-06-12 | 2001-02-27 | International Business Machines Corporation | Operating system having shared personality neutral resources |
US6204847B1 (en) | 1995-07-17 | 2001-03-20 | Daniel W. Wright | Shared virtual desktop collaborative application system |
AU750333B2 (en) * | 1995-12-29 | 2002-07-18 | Wyse Technology L.L.C. | Method and apparatus for display windowing application programs on a terminal |
US5918039A (en) * | 1995-12-29 | 1999-06-29 | Wyse Technology, Inc. | Method and apparatus for display of windowing application programs on a terminal |
AU766791B2 (en) * | 1995-12-29 | 2003-10-23 | Wyse Technology L.L.C. | A method for updating operating characteristics of a terminal |
US6437805B1 (en) | 1996-09-23 | 2002-08-20 | National Instruments Corporation | System and method for accessing object capabilities in a graphical program |
US6102965A (en) * | 1996-09-23 | 2000-08-15 | National Instruments Corporation | System and method for providing client/server access to graphical programs |
US5914713A (en) * | 1996-09-23 | 1999-06-22 | Fmr Corp. | Accessing data fields from a non-terminal client |
US5793368A (en) * | 1996-11-14 | 1998-08-11 | Triteal Corporation | Method for dynamically switching between visual styles |
US5936624A (en) * | 1997-03-07 | 1999-08-10 | International Business Machines Corporation | Data processing system having a logical containment system and method therefor |
US6144377A (en) * | 1997-03-11 | 2000-11-07 | Microsoft Corporation | Providing access to user interface elements of legacy application programs |
US6073163A (en) * | 1997-06-10 | 2000-06-06 | Oracle Corporation | Method and apparatus for enabling web-based execution of an application |
KR100502400B1 (en) * | 1997-07-31 | 2005-11-03 | 삼성전자주식회사 | Computer and method for selecting controls of peripheral storage devices |
CA2309658C (en) * | 1997-11-12 | 2007-10-30 | Benjamin Slotznick | Automatically switching a user's interface from a program to another program while the first is processing |
US6064382A (en) * | 1997-11-19 | 2000-05-16 | International Business Machines Corporation | Object oriented apparatus and method for providing a graphical user interface for host-based software applications |
US6337717B1 (en) | 1997-11-21 | 2002-01-08 | Xsides Corporation | Alternate display content controller |
US6686936B1 (en) | 1997-11-21 | 2004-02-03 | Xsides Corporation | Alternate display content controller |
US6330010B1 (en) | 1997-11-21 | 2001-12-11 | Xsides Corporation | Secondary user interface |
US6018332A (en) * | 1997-11-21 | 2000-01-25 | Ark Interface Ii, Inc. | Overscan user interface |
US6639613B1 (en) | 1997-11-21 | 2003-10-28 | Xsides Corporation | Alternate display content controller |
US6587121B1 (en) * | 1997-12-19 | 2003-07-01 | Unisys Corporation | Graphical table of contents for a help system |
US6249294B1 (en) * | 1998-07-20 | 2001-06-19 | Hewlett-Packard Company | 3D graphics in a single logical sreen display using multiple computer systems |
US6178503B1 (en) * | 1998-09-11 | 2001-01-23 | Powerquest Corporation | Managing multiple operating systems on a single computer |
US6409602B1 (en) * | 1998-11-06 | 2002-06-25 | New Millenium Gaming Limited | Slim terminal gaming system |
US6346953B1 (en) * | 1999-02-04 | 2002-02-12 | Relativity Technologies | Method and system for recreating a user interface of an existing application text based user interface into a graphical user interface |
US6590592B1 (en) * | 1999-04-23 | 2003-07-08 | Xsides Corporation | Parallel interface |
US6593945B1 (en) * | 1999-05-21 | 2003-07-15 | Xsides Corporation | Parallel graphical user interface |
WO2001020456A1 (en) * | 1999-09-10 | 2001-03-22 | Hitachi, Ltd. | Operating system managing system and method |
US6630943B1 (en) * | 1999-09-21 | 2003-10-07 | Xsides Corporation | Method and system for controlling a complementary user interface on a display surface |
AU7583000A (en) * | 1999-09-21 | 2001-04-24 | Wyse Technology, Inc. | Displaying windowing application programs on a terminal |
US6798413B1 (en) * | 1999-12-03 | 2004-09-28 | Dcs, Inc. | Workflow management system |
US6724402B1 (en) | 2000-01-27 | 2004-04-20 | David R. Baquero | Method of launching computer programs within a graphical user interface |
US6677964B1 (en) * | 2000-02-18 | 2004-01-13 | Xsides Corporation | Method and system for controlling a complementary user interface on a display surface |
US20040226041A1 (en) * | 2000-02-18 | 2004-11-11 | Xsides Corporation | System and method for parallel data display of multiple executing environments |
US20100005396A1 (en) * | 2000-02-18 | 2010-01-07 | Nason D David | Method and system for controlling a comlementary user interface on a display surface |
US7249326B2 (en) * | 2000-04-06 | 2007-07-24 | Microsoft Corporation | Method and system for reducing notification area clutter |
US7506265B1 (en) * | 2000-07-17 | 2009-03-17 | Microsoft Corporation | System and method for displaying images of virtual machine environments |
US7107587B1 (en) | 2000-09-18 | 2006-09-12 | Microsoft Corporation | Access redirector and entry reflector |
US7146602B2 (en) * | 2001-01-16 | 2006-12-05 | Ajile Systems, Inc. | Builder tool and interface for system supporting multiple virtual machines |
TW539951B (en) * | 2001-01-17 | 2003-07-01 | Duan-Huei Wu | A method transferring resources among operating systems |
US8933949B2 (en) * | 2010-10-01 | 2015-01-13 | Z124 | User interaction across cross-environment applications through an extended graphics context |
US8819705B2 (en) | 2010-10-01 | 2014-08-26 | Z124 | User interaction support across cross-environment applications |
US20130024812A1 (en) | 2011-07-13 | 2013-01-24 | Z124 | Foreground/background assortment of hidden windows |
US8726294B2 (en) | 2010-10-01 | 2014-05-13 | Z124 | Cross-environment communication using application space API |
US8966379B2 (en) | 2010-10-01 | 2015-02-24 | Z124 | Dynamic cross-environment application configuration/orientation in an active user environment |
US9047102B2 (en) | 2010-10-01 | 2015-06-02 | Z124 | Instant remote rendering |
US20130024778A1 (en) | 2011-07-13 | 2013-01-24 | Z124 | Dynamic cross-environment application configuration/orientation |
US8181118B2 (en) * | 2001-11-28 | 2012-05-15 | Intel Corporation | Personal information device on a mobile computing platform |
US7081904B2 (en) * | 2002-02-26 | 2006-07-25 | Microsoft Corporation | Methods and apparatuses for identifying remote and local services |
US7406542B2 (en) * | 2002-03-01 | 2008-07-29 | Google Inc. | Method and system for assured denotation of application semantics |
CA2391717A1 (en) * | 2002-06-26 | 2003-12-26 | Ibm Canada Limited-Ibm Canada Limitee | Transferring data and storing metadata across a network |
US20040001101A1 (en) * | 2002-06-27 | 2004-01-01 | Koninklijke Philips Electronics N.V. | Active window switcher |
US7305680B2 (en) * | 2002-08-13 | 2007-12-04 | Sharp Laboratories Of America, Inc. | Listening module for asynchronous messages sent between electronic devices of a distributed network |
US7149752B2 (en) * | 2002-12-03 | 2006-12-12 | Jp Morgan Chase Bank | Method for simplifying databinding in application programs |
US7085759B2 (en) | 2002-12-06 | 2006-08-01 | Jpmorgan Chase Bank | System and method for communicating data to a process |
US8032439B2 (en) | 2003-01-07 | 2011-10-04 | Jpmorgan Chase Bank, N.A. | System and method for process scheduling |
US7401156B2 (en) | 2003-02-03 | 2008-07-15 | Jp Morgan Chase Bank | Method using control interface to suspend software network environment running on network devices for loading and executing another software network environment |
US7379998B2 (en) * | 2003-03-31 | 2008-05-27 | Jp Morgan Chase Bank | System and method for multi-platform queue queries |
US7366722B2 (en) | 2003-05-15 | 2008-04-29 | Jp Morgan Chase Bank | System and method for specifying application services and distributing them across multiple processors using XML |
US7509641B2 (en) * | 2003-05-16 | 2009-03-24 | Jp Morgan Chase Bank | Job processing framework |
US9715678B2 (en) | 2003-06-26 | 2017-07-25 | Microsoft Technology Licensing, Llc | Side-by-side shared calendars |
US8799808B2 (en) | 2003-07-01 | 2014-08-05 | Microsoft Corporation | Adaptive multi-line view user interface |
US7707255B2 (en) | 2003-07-01 | 2010-04-27 | Microsoft Corporation | Automatic grouping of electronic mail |
US20050076110A1 (en) * | 2003-07-11 | 2005-04-07 | Boban Mathew | Generic inbox system and method |
US7266726B1 (en) | 2003-11-24 | 2007-09-04 | Time Warner Cable Inc. | Methods and apparatus for event logging in an information network |
US8302111B2 (en) | 2003-11-24 | 2012-10-30 | Time Warner Cable Inc. | Methods and apparatus for hardware registration in a network device |
US7544209B2 (en) * | 2004-01-12 | 2009-06-09 | Lotke Paul A | Patello-femoral prosthesis |
US9213538B1 (en) | 2004-02-06 | 2015-12-15 | Time Warner Cable Enterprises Llc | Methods and apparatus for display element management in an information network |
KR100586309B1 (en) * | 2004-02-23 | 2006-06-07 | 엔컴퓨팅 주식회사 | network terminal working by downloadable Operating System and method thereof |
US8028247B2 (en) * | 2004-03-05 | 2011-09-27 | International Business Machines Corporation | System and method for window navigation in GUI environment |
US9734222B1 (en) | 2004-04-06 | 2017-08-15 | Jpmorgan Chase Bank, N.A. | Methods and systems for using script files to obtain, format and transport data |
US20050234976A1 (en) * | 2004-04-20 | 2005-10-20 | Relativity Technologies, Inc. | System and method for deriving an object oriented design from the business rules of a legacy application |
US7376830B2 (en) | 2004-04-26 | 2008-05-20 | Jp Morgan Chase Bank | System and method for routing messages |
US7996785B2 (en) * | 2004-06-30 | 2011-08-09 | Microsoft Corporation | Systems and methods for integrating application windows in a virtual machine environment |
US7392471B1 (en) | 2004-07-28 | 2008-06-24 | Jp Morgan Chase Bank | System and method for comparing extensible markup language (XML) documents |
US7484247B2 (en) * | 2004-08-07 | 2009-01-27 | Allen F Rozman | System and method for protecting a computer system from malicious software |
US8146016B2 (en) | 2004-08-16 | 2012-03-27 | Microsoft Corporation | User interface for displaying a gallery of formatting options applicable to a selected object |
US8255828B2 (en) | 2004-08-16 | 2012-08-28 | Microsoft Corporation | Command user interface for displaying selectable software functionality controls |
US9015621B2 (en) | 2004-08-16 | 2015-04-21 | Microsoft Technology Licensing, Llc | Command user interface for displaying multiple sections of software functionality controls |
US7703036B2 (en) | 2004-08-16 | 2010-04-20 | Microsoft Corporation | User interface for displaying selectable software functionality controls that are relevant to a selected object |
US8117542B2 (en) | 2004-08-16 | 2012-02-14 | Microsoft Corporation | User interface for displaying selectable software functionality controls that are contextually relevant to a selected object |
US7895531B2 (en) | 2004-08-16 | 2011-02-22 | Microsoft Corporation | Floating command object |
US7747966B2 (en) | 2004-09-30 | 2010-06-29 | Microsoft Corporation | User interface for providing task management and calendar information |
US7886290B2 (en) * | 2005-06-16 | 2011-02-08 | Microsoft Corporation | Cross version and cross product user interface |
GB2428953A (en) * | 2005-08-04 | 2007-02-07 | Ibm | Identifying remote objects on a client system GUI |
US8239882B2 (en) | 2005-08-30 | 2012-08-07 | Microsoft Corporation | Markup based extensibility for user interfaces |
US8689137B2 (en) | 2005-09-07 | 2014-04-01 | Microsoft Corporation | Command user interface for displaying selectable functionality controls in a database application |
US9542667B2 (en) | 2005-09-09 | 2017-01-10 | Microsoft Technology Licensing, Llc | Navigating messages within a thread |
US8627222B2 (en) | 2005-09-12 | 2014-01-07 | Microsoft Corporation | Expanded search and find user interface |
US7499933B1 (en) | 2005-11-12 | 2009-03-03 | Jpmorgan Chase Bank, N.A. | System and method for managing enterprise application configuration |
US8605090B2 (en) | 2006-06-01 | 2013-12-10 | Microsoft Corporation | Modifying and formatting a chart using pictorially provided chart elements |
US9727989B2 (en) | 2006-06-01 | 2017-08-08 | Microsoft Technology Licensing, Llc | Modifying and formatting a chart using pictorially provided chart elements |
US7610172B2 (en) | 2006-06-16 | 2009-10-27 | Jpmorgan Chase Bank, N.A. | Method and system for monitoring non-occurring events |
KR100831721B1 (en) * | 2006-12-29 | 2008-05-22 | 엘지전자 주식회사 | Apparatus and method for displaying of mobile terminal |
US20080163159A1 (en) * | 2007-01-03 | 2008-07-03 | Relativity Technologies, Inc. | System and method for extracting UML models from legacy applications |
US8201103B2 (en) | 2007-06-29 | 2012-06-12 | Microsoft Corporation | Accessing an out-space user interface for a document editor program |
US8762880B2 (en) | 2007-06-29 | 2014-06-24 | Microsoft Corporation | Exposing non-authoring features through document status information in an out-space user interface |
US8484578B2 (en) | 2007-06-29 | 2013-07-09 | Microsoft Corporation | Communication between a document editor in-space user interface and a document editor out-space user interface |
US20090089453A1 (en) * | 2007-09-27 | 2009-04-02 | International Business Machines Corporation | Remote visualization of a graphics application |
KR101204795B1 (en) * | 2007-10-23 | 2012-11-26 | 삼성전자주식회사 | Method for sharing screen between applications based on a different kind of graphic system and apparatus thereof |
US9588781B2 (en) | 2008-03-31 | 2017-03-07 | Microsoft Technology Licensing, Llc | Associating command surfaces with multiple active components |
US9665850B2 (en) | 2008-06-20 | 2017-05-30 | Microsoft Technology Licensing, Llc | Synchronized conversation-centric message list and message reading pane |
US8402096B2 (en) | 2008-06-24 | 2013-03-19 | Microsoft Corporation | Automatic conversation techniques |
US20090327853A1 (en) * | 2008-06-27 | 2009-12-31 | Microsoft Corporation | Comparing And Selecting Form-Based Functionality |
JP5383234B2 (en) | 2009-02-03 | 2014-01-08 | キヤノン株式会社 | Information processing apparatus and print control method |
WO2010107476A1 (en) * | 2009-03-19 | 2010-09-23 | Duke University | Inhibiting gsnor |
US8799353B2 (en) | 2009-03-30 | 2014-08-05 | Josef Larsson | Scope-based extensibility for control surfaces |
US9046983B2 (en) | 2009-05-12 | 2015-06-02 | Microsoft Technology Licensing, Llc | Hierarchically-organized control galleries |
KR101596505B1 (en) * | 2009-06-19 | 2016-02-23 | 삼성전자주식회사 | Apparatus and method of an user interface in a multimedia system |
KR101651202B1 (en) * | 2009-12-21 | 2016-08-26 | 삼성전자주식회사 | Virtualization apparatus and method of operating thereof |
US10191609B1 (en) | 2010-03-26 | 2019-01-29 | Open Invention Network Llc | Method and apparatus of providing a customized user interface |
US9383887B1 (en) * | 2010-03-26 | 2016-07-05 | Open Invention Network Llc | Method and apparatus of providing a customized user interface |
US9405400B1 (en) | 2010-03-26 | 2016-08-02 | Open Invention Network Llc | Method and apparatus of providing and customizing data input touch screen interface to multiple users |
US8302014B2 (en) | 2010-06-11 | 2012-10-30 | Microsoft Corporation | Merging modifications to user interface components while preserving user customizations |
US8892594B1 (en) | 2010-06-28 | 2014-11-18 | Open Invention Network, Llc | System and method for search with the aid of images associated with product categories |
WO2012044557A2 (en) | 2010-10-01 | 2012-04-05 | Imerj, Llc | Auto-configuration of a docked system in a multi-os environment |
US8898443B2 (en) | 2010-10-01 | 2014-11-25 | Z124 | Multi-operating system |
US8842080B2 (en) | 2010-10-01 | 2014-09-23 | Z124 | User interface with screen spanning icon morphing |
US8761831B2 (en) | 2010-10-15 | 2014-06-24 | Z124 | Mirrored remote peripheral interface |
US20120311457A1 (en) * | 2011-06-06 | 2012-12-06 | Cisco Technology, Inc. | Merging Remote and Local Interfaces for Application Integration |
US9495012B2 (en) | 2011-09-27 | 2016-11-15 | Z124 | Secondary single screen mode activation through user interface activation |
EP3111296B1 (en) | 2014-02-27 | 2022-07-27 | Aptiv Technologies Limited | In-process trapping for service substitution in hosted applications executing on mobile devices with multi operating system environment |
US10893093B2 (en) * | 2018-01-18 | 2021-01-12 | International Business Machines Corporation | Translating a user's working context from one operating system and associated applications to a different operating system and associated applications |
US11716558B2 (en) | 2018-04-16 | 2023-08-01 | Charter Communications Operating, Llc | Apparatus and methods for integrated high-capacity data and wireless network services |
WO2020077346A1 (en) | 2018-10-12 | 2020-04-16 | Charter Communications Operating, Llc | Apparatus and methods for cell identification in wireless networks |
US11129171B2 (en) | 2019-02-27 | 2021-09-21 | Charter Communications Operating, Llc | Methods and apparatus for wireless signal maximization and management in a quasi-licensed wireless system |
US11093264B1 (en) * | 2019-06-14 | 2021-08-17 | Parallels International Gmbh | System and method for drawing optimization with pointer input in a remote session |
US11026205B2 (en) | 2019-10-23 | 2021-06-01 | Charter Communications Operating, Llc | Methods and apparatus for device registration in a quasi-licensed wireless system |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS5831438A (en) * | 1981-08-19 | 1983-02-24 | Fujitsu Ltd | Centralized controlling system between different operating systems |
US4493034A (en) * | 1982-10-14 | 1985-01-08 | Honeywell Information Systems Inc. | Apparatus and method for an operating system supervisor in a data processing system |
US4737906A (en) * | 1985-09-27 | 1988-04-12 | International Business Machines Corporation | Multiple virtual control unit |
US4939507A (en) * | 1986-04-28 | 1990-07-03 | Xerox Corporation | Virtual and emulated objects for use in the user interface of a display screen of a display processor |
US4920481A (en) * | 1986-04-28 | 1990-04-24 | Xerox Corporation | Emulation with display update trapping |
US4937036A (en) * | 1986-04-28 | 1990-06-26 | Xerox Corporation | Concurrent display of data from two different display processors and user interface therefore |
US4855936A (en) * | 1987-09-25 | 1989-08-08 | International Business Machines Corp. | Full-screen input/output application program interface |
US4961133A (en) * | 1987-11-06 | 1990-10-02 | Visystems, Inc. | Method for providing a virtual execution environment on a target computer using a virtual software machine |
US5062037A (en) * | 1988-10-24 | 1991-10-29 | Ibm Corp. | Method to provide concurrent execution of distributed application programs by a host computer and an intelligent work station on an sna network |
US4891709A (en) * | 1989-03-31 | 1990-01-02 | Eastman Kodak Company | Flexible formatting interface for pictorial data transfer |
US5252951A (en) * | 1989-04-28 | 1993-10-12 | International Business Machines Corporation | Graphical user interface with gesture recognition in a multiapplication environment |
US5226117A (en) * | 1990-05-15 | 1993-07-06 | International Business Machines Corporation | Method for simultaneous update and change in parent and child windows |
US5361336A (en) * | 1991-11-21 | 1994-11-01 | Hewlett-Packard Company | Method for controlling an instrument through a common instrument programming interface |
US5377317A (en) * | 1991-12-20 | 1994-12-27 | International Business Machines Corporation | Method and apparatus for distinctively displaying windows on a computer display screen |
-
1992
- 1992-11-13 US US07/975,753 patent/US5673403A/en not_active Expired - Lifetime
-
1993
- 1993-10-13 JP JP5255432A patent/JPH081624B2/en not_active Expired - Fee Related
- 1993-11-05 DE DE69327632T patent/DE69327632T2/en not_active Expired - Fee Related
- 1993-11-05 EP EP93117959A patent/EP0597395B1/en not_active Expired - Lifetime
Non-Patent Citations (3)
Title |
---|
"OS/2 Presentation Manager clipboard support for a windowed 5250 emulator", IBM TECHNICAL DISCLOSURE BULLETIN., vol. 35, no. 2, July 1992 (1992-07-01), NEW YORK US, pages 323 - 332, XP000313316 * |
"Window class library with command table dispatching", IBM TECHNICAL DISCLOSURE BULLETIN., vol. 35, no. 6, November 1992 (1992-11-01), NEW YORK US, pages 357 - 360, XP000314181 * |
WILLIAMS: "Tools help move applications between different GUIs", COMPUTER DESIGN., vol. 31, no. 8, August 1992 (1992-08-01), LITTLETON, MASSACHUSETTS US, pages 50 - 54, XP000307564 * |
Cited By (10)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2723225A1 (en) * | 1994-07-29 | 1996-02-02 | Sat | Co-operative working between computers with different operating systems |
GB2293470A (en) * | 1994-09-22 | 1996-03-27 | Ibm | Message encapsulation in Object Oriented Programming. |
US5767849A (en) * | 1995-08-18 | 1998-06-16 | International Business Machines Corporation | Personality neutral window management subsystem |
DE19654766B4 (en) * | 1995-12-29 | 2004-11-18 | Wyse Technology, Inc., San Jose | Terminal for displaying application information in a window environment |
US7720672B1 (en) | 1995-12-29 | 2010-05-18 | Wyse Technology Inc. | Method and apparatus for display of windowing application programs on a terminal |
DE19655400B4 (en) * | 1995-12-29 | 2011-03-17 | Wyse Technology, Inc., San Jose | Terminal for communicating with a server |
US8079021B2 (en) | 1995-12-29 | 2011-12-13 | Wyse Technology Inc. | Method and apparatus for display of windowing application programs on a terminal |
US8904362B2 (en) | 1995-12-29 | 2014-12-02 | Wyse Technology L.L.C. | Method and apparatus for display of windowing application programs on a terminal |
FR2793901A1 (en) * | 1999-05-21 | 2000-11-24 | Bull Sa | METHOD FOR CONTROLLING, FROM A DASHBOARD OF A CLIENT STATION, A PROCESS EXECUTING A SERVER |
EP1056000A1 (en) * | 1999-05-21 | 2000-11-29 | Bull S.A. | Command procedure, from a dashboard on a client station, of a process running on a server |
Also Published As
Publication number | Publication date |
---|---|
DE69327632D1 (en) | 2000-02-24 |
JPH081624B2 (en) | 1996-01-10 |
JPH07160608A (en) | 1995-06-23 |
EP0597395B1 (en) | 2000-01-19 |
DE69327632T2 (en) | 2000-07-06 |
US5673403A (en) | 1997-09-30 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP0597395B1 (en) | Multiple graphical user interface on a single display | |
Scheifler et al. | The X window system | |
US5831609A (en) | Method and system for dynamic translation between different graphical user interface systems | |
US5767849A (en) | Personality neutral window management subsystem | |
US5774720A (en) | Personality neutral graphics subsystem | |
US7453473B2 (en) | Method and apparatus for high-performance rendering and hit testing of a window tree | |
US5596702A (en) | Method and system for dynamically sharing user interface displays among a plurality of application program | |
US5613090A (en) | Computer system for disparate windowing environments which translates requests and replies between the disparate environments | |
US5621434A (en) | Cursor manipulation system and method | |
US5745112A (en) | Device and method for a window responding to a drag operation | |
JP2544116B2 (en) | Multi processing window display method | |
US5546583A (en) | Method and system for providing a client/server interface in a programming language | |
US6922812B2 (en) | System and method for presenting text upon the display of a server that employs and X window graphical interface | |
JPH0535623A (en) | Display station controller | |
US5724532A (en) | Method and apparatus for exchanging information between application programs according to a drag and drop operation | |
EP0564174A2 (en) | Method and system for visual presentation of data in a data processing system | |
JPH08137646A (en) | Method and system for displaying dialogue box | |
Scheifler et al. | The X window system | |
JPH07271586A (en) | Dynamic designation of call in compiled object | |
US7730500B2 (en) | Application programming interface techniques for accessing operating system resources | |
JP2531856B2 (en) | How to control cursor-dependent scrolling | |
US6414695B1 (en) | System for adding function to an object oriented program through a computer controlled interactive display interface with alternate access to data in the object oriented program normally inaccessible through the interface | |
JP2522893B2 (en) | Window processing display system | |
Nabavi | APL windowing systems-where next? | |
Williams | A comparison of some window managers |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PUAI | Public reference made under article 153(3) epc to a published international application that has entered the european phase |
Free format text: ORIGINAL CODE: 0009012 |
|
AK | Designated contracting states |
Kind code of ref document: A1 Designated state(s): DE FR GB |
|
17P | Request for examination filed |
Effective date: 19940927 |
|
17Q | First examination report despatched |
Effective date: 19971017 |
|
GRAG | Despatch of communication of intention to grant |
Free format text: ORIGINAL CODE: EPIDOS AGRA |
|
GRAG | Despatch of communication of intention to grant |
Free format text: ORIGINAL CODE: EPIDOS AGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAH | Despatch of communication of intention to grant a patent |
Free format text: ORIGINAL CODE: EPIDOS IGRA |
|
GRAA | (expected) grant |
Free format text: ORIGINAL CODE: 0009210 |
|
AK | Designated contracting states |
Kind code of ref document: B1 Designated state(s): DE FR GB |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: FR Free format text: LAPSE BECAUSE OF FAILURE TO SUBMIT A TRANSLATION OF THE DESCRIPTION OR TO PAY THE FEE WITHIN THE PRESCRIBED TIME-LIMIT Effective date: 20000119 |
|
REF | Corresponds to: |
Ref document number: 69327632 Country of ref document: DE Date of ref document: 20000224 |
|
EN | Fr: translation not filed | ||
PLBE | No opposition filed within time limit |
Free format text: ORIGINAL CODE: 0009261 |
|
STAA | Information on the status of an ep patent application or granted ep patent |
Free format text: STATUS: NO OPPOSITION FILED WITHIN TIME LIMIT |
|
26N | No opposition filed | ||
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: DE Payment date: 20011122 Year of fee payment: 9 |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: IF02 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: DE Free format text: LAPSE BECAUSE OF NON-PAYMENT OF DUE FEES Effective date: 20030603 |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: 746 Effective date: 20071007 |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: S47 Free format text: CANCELLATION OF ENTRY; APPLICATION BY FILING PATENTS FORM 15 WITHIN 4 WEEKS FROM THE DATE OF PUBLICATION OF THIS JOURNAL |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: S47 Free format text: ENTRY CANCELLED; NOTICE IS HEREBY GIVEN THAT THE ENTRY ON THE REGISTER 'LICENCES OF RIGHT' UPON THE UNDER MENTIONED PATENT WAS CANCELLED ON 25 MAY 2011MULTIPLE GRAPHICAL USER INTERFACE ON A SINGLE DISPLAY. |
|
PGFP | Annual fee paid to national office [announced via postgrant information from national office to epo] |
Ref country code: GB Payment date: 20121122 Year of fee payment: 20 |
|
REG | Reference to a national code |
Ref country code: GB Ref legal event code: PE20 Expiry date: 20131104 |
|
PG25 | Lapsed in a contracting state [announced via postgrant information from national office to epo] |
Ref country code: GB Free format text: LAPSE BECAUSE OF EXPIRATION OF PROTECTION Effective date: 20131104 |