The present invention relates to the display of information in a communications network and more specifically to displaying the output of executing application programs in a web page.
Businesses in today's fast-paced global marketplace strive to improve their productivity and profitability by providing their employees with access to business-critical applications and data at fixed locations within the workplace as well as at mobile locations. The popularity of web-based computing, combined with the need to expedite information access for mobile users, has spurred adoption of enterprise portals. Enterprise portals are company web sites that aggregate, personalize and serve applications, data and content to users, while offering management tools for organizing and using information more efficiently. In some companies, portals have replaced traditional desktop software with browser-based access to a virtual workplace that is easy to use, convenient and ubiquitous. Companies that implement portals also benefit from a fast return on investment due to increased worker productivity and greater efficiency in their information technology infrastructure.
True desktop software replacement requires that a portal offer a full complement of information resources. Business applications are, arguably, the most vital information resource that workers need to access. Business applications also typically represent a major investment, and often a competitive advantage, which must not be lost when moving to web-based systems. From the standpoint of productivity, application access via the portal is needed so that users are not forced to switch back and forth between the browser and the desktop to do their work. With a split browser/desktop system, it is more difficult to locate and coordinate material from various sources. Users are also typically tied to the desktop device because it provides key applications that may not be accessible via the browser.
These business drivers provide compelling motivation to include existing and upcoming applications in portal implementations. However, few applications have been developed specifically for web-based delivery and those that have often provide reduced functionality as compared to their equivalent desktop applications. Although it is possible to use existing applications in a portal by re-engineering them for web publication using HTML, scripting, Java™ and other proprietary means, this approach is time-consuming and expensive and may delay portal implementation. Likewise, such implementations may experience reduced functionality and/or may not be feasible because the “download and run” model of application execution is too resource-intensive.
Accordingly, methods and systems are desired that enable efficient deployment of legacy applications in enterprise portals without undertaking expensive development efforts that may be marginally effective and which dilute the return on investment of the portal.
The present invention overcomes these shortcomings by applying web-enablement technology to legacy applications so that these applications remain in their original form, with the same user interface and full functionality to which their users are already accustomed, while allowing such viewers to interact with the applications via application-output windows displayed within a web page.
In one embodiment, the invention provides a method of displaying application-output data within one or more application-output windows positioned within a web browser window. The application-output data can be generated by a web enabled application program and/or a non-web enabled application program that is unmodified (e.g., so called “legacy applications”). The application programs that provide the source of the application-output data can reside on different application servers and the application-output data from these different application servers is displayed within one or more application-output windows in the same web browser window. In one aspect, the application-output windows are child windows of the web browser window. In one embodiment, the application-output windows are relocatable beyond the boundaries of the web browser window. In another aspect, window attribute information associated with the application-output windows is received via a first virtual channel and application-output data (e.g., graphical data) is received via a second virtual channel. In yet another aspect, the window attribute information of the application-output windows displayed within the web browser window is modifiable independently of the web browser that formed the web browser window. The invention displays the application-output data in the application-output window in accordance with the window attribute information.
In one embodiment, the invention provides a client agent that monitors and responds to events associated with the application-output windows, such as detecting a resize event input by a viewer of the web browser window and in response resizing an affected application-output window. The client agent performs these functions independently of the web browser. In one embodiment, the client agent is executed/instantiated in response to an application object (e.g., an ActiveX control) embedded in the web page displayed in the web browser window. In this embodiment, the client agent uses the window attribute information of the application-output windows received via the second virtual channel to modify at least one property of the application object, where the modified property triggers a corresponding change in the associated application-output windows. In a further aspect, the client agent establishes the first and second virtual channels independently of the web browser.
In this manner, the invention avoids expensive development and user training costs, and provides access to the full functionality of the original legacy application at mobile locations that have web access.
The invention is pointed out with particularity in the appended claims. The advantages of this invention described above, and further advantages, may be better understood by reference to the following description taken in conjunction with the accompanying drawings, in which:
Portals and other web-based implementations capable of displaying application-output data to remote users are, preferably, implemented using a server-based computing model. Server-based computing is analogous to enterprise portals, which improve user productivity through single-point access to information resources (e.g., application programs), in that server-based computing enhances the overall efficiency of the portal via single-point application administration.
In server-based computing models, application processing, administration, support and deployment are typically based on one or more central servers, which may be geographically distant from a user's display device. Remote users interact with particular applications hosted on these application servers by sending keystrokes, mouse movements, and other input/output actions to the application servers via data communication networks (e.g., LAN, MAN, WAN, Internet, Intranet, etc.) and receive screen/window updates, files and other data therefrom. Because much, if not all, of the application processing takes place on the server, the user's display device operates essentially as a thin client and thus requires few resources (e.g., processing power, nonvolatile memory, volatile memory, etc.) to display the application-output data of what may be a compute-intensive application. Further, by reducing the overall quantity of data that travels across the network, significant improvements can be realized in application performance and security.
Coupling this server-based computing model with web-based implementations of application programs (e.g., portals) enables users to access business critical applications on virtually any device connected to the web, including home computers, laptop computers, computer workstations, wireless and handheld communication devices, and information appliances running on a wide array of platforms. Device and platform flexibility allows mobile workers to move seamlessly from one device to another and receive a consistent, personalized information set, which includes access to the full functionality of business-critical, legacy applications.
In brief overview, a user of a device connected to the web requests access to one or more application programs from a web server. After authenticating the user's credentials, the web server accesses user-specific and application-specific parameters from a memory coupled to the web server. The web server subsequently communicates these parameters to one or more application execution servers hosting the requested application programs, and software processes operating on the application execution servers execute and initialize the requested application programs using the communicated parameters. In this manner, each instance of the application programs is personalized for a particular requesting user. The particular network addresses of the application execution servers hosting these personalized application programs are then forwarded to the user's device, which establishes a communications link and client-server session therewith.
Commands, events, graphical data, and window attribute information associated with the executing application programs are communicated between the user device and the application execution servers during the client-server session to ensure that the application-output data is displayed seamlessly on the desktop of the user device. Seamless display of the application-output data refers to the presentation of the data on the user desktop in a manner that is consistent with how locally-executing applications are presented and manipulated in the local desktop of the user device. In other words, a user views and interacts with the application-output data generated by the remote application programs as if the application programs were being executed locally.
In one embodiment, the output of the application programs is displayed in one or more application-output windows positioned within a web page displayed by a web browser of the user's device. In a further embodiment, the attributes of the application-output windows can be modified so that the application-output windows are moveable and resizeable within the boundaries of the web page. In another embodiment, the application-output windows initially appear within the boundaries of the web page and are subsequently moveable so that they are positioned outside the boundaries of the web page and thus give the appearance that the application-output windows correspond to locally-executing applications rather than to remotely-executing applications. In yet another embodiment, the application-output windows initially appear outside the boundaries of the web page and thus also appear to correspond to locally-executing applications. In one embodiment, the application output displayed in the application-output windows and the attributes of the application-output windows themselves are communicated and manipulated by software processes on the user's device and on the application execution servers, without involvement of the web server or web browser that initially provided access to the application programs.
In more detail and with reference to
In operation and also with reference to
The web server 112 authenticates the user by accessing an authentication process that compares the credentials entered by the user with previously-assigned credentials. In one embodiment, the authentication process and database of previously-assigned credentials are stored and maintained on the web server 112. In other embodiments, the previously-assigned credentials can be stored in the server farm 116, on individual application execution servers 114, and/or on an administrative server (not shown) that is coupled to the web server 112 via the Internet or other data communication network.
In the scenario where the web page content 124 corresponds to an enterprise portal, which provides access to an application set 126 (e.g., the set of application programs that have been personalized for the user by a portal administrator), the web server 112 accesses one or more application objects 128 (e.g., COM-compliant Java objects, ActiveX objects, HTML tags, etc.) that call web server-side scripts to authenticate the user (step 212) and/or to obtain the application set 126 information associated with the portal and user from the server farm 116 (step 214). The application objects 128 also include properties that are associated with the user and/or the particular applications 130 in the application set 126 that are provided via the portal. The user properties include, for example, group/project information that identifies the particular applications 130 and data that the user needs to access in order to allow the user to collaborate with other members of the group/project. The application properties include, for example, the user's preferences for each of the applications 130 in the application set 126.
The scripts called by the application objects 128 establish a network session between the web server 112 and the server farm 116 via, for example, a central administrative process (not shown), which monitors and controls each server 114 in the server farm 116. The administrative process selects one or more servers, which host the application programs 130 in the application set 126 specified by the application objects 128, based, for example, on a server and/or network performance basis. The desired application set 126 can be provided entirely by a single server 114 by selecting/allocating each application 130 in the application set 126 from a plurality of applications 130,132 hosted on the server 114. Alternatively, the application set 126′ can be provided by a plurality of servers 114 with each of the plurality of servers 114 hosting at least one of the application programs in the application set 126′. A more detailed description of server farms and their administration/operation can be found in International Patent Application No. PCT/US01/14314, which is incorporated herein by reference in its entirety.
The administrative process launches one or more server agents 134 on the selected/allocated servers 114 in response to the scripts called by the application objects 128. Server agents 134 are software processes that execute, initialize, and interact with each of the application programs 130 in the application set 126 in accordance with the properties specified by the application objects 128. In one embodiment, there is a server agent 134 for each application program 130 in the application set 126. In other embodiments, there is a single server agent 134 for the application set 130, to the extent that all of the application programs 130 are hosted on the same server 114. In yet another embodiment, there is a single server agent 134 for each server 114. The server agents 134 then provide the output of the application programs 130 in the application set 126 as well as any other information relating to the application set 126 to the web server 112, which subsequently formats the application set information into the web page content 124 (step 216). The web page content 124 can include application icons corresponding to one or more of the application programs 130 in the application set 126 as well as application-output data from one or more of the application programs 130. In one embodiment, the application-output data provided by the application programs 130 corresponds to graphical data that is formatted to fit into a window, which exhibits attributes (e.g., window position on the web page, size, style, z-order, etc.) as initially specified by the properties of the application objects 128.
In one illustrative embodiment and with reference to
The application objects 128 can be any data constructs which indicate to the browser 122 displaying the web page content 124 that an application-output window 326 should be displayed at a particular location in the web page 322. The application objects 128 may include additional information, such as the height, width, border style, background color or pattern in the application-output window 326, along with indicia of which applications 130 may be displayed in the window 326, how often the output display should be updated, or any other additional information that is useful to enhance the display of the application output.
In one illustrative embodiment, the application objects 128 are window tags that are embedded in an HTML file, examples of such tags are delineated below.
In each case above, the tag indicates that an application-output window 326 having a height of 295 pixels and a width of 436 pixels should be drawn to receive output data from the application program 130. Each tag also specifies that the application program 130 should automatically start execution and that the application-output window 326 in which the application output is displayed should be drawn with a border. The ActiveX and Netscape Plugin tags have the properties of the remote application 130 specified in the file “direct.ica” located in the directory “/ica.” The JAVA tag specifies the properties of the remote application 130 directly. In the example above, the address of the server 114 hosting the application program 130 is specified as well as the name of the application program 130 to be executed.
In one embodiment, the application program 130 executes substantially at the same time as the display of the web page 322. In another embodiment, the application program 130 executes when instructed to do so by the server agent 114, as part of providing web page content 124 to the web server 112. In yet another embodiment, the application program executes in response to a signal, such as a user-specified input (e.g., selecting an application icon 324 on the web page 322. Once execution of the application program 130 is commenced, the browser 122 instantiates a client agent 136 on the client device 110 (step 220). Alternatively, the client agent 136 is instantiated substantially at the same time as the display of the web page 322 or in response to user-specified inputs.
The client agent 136 comprises one or more software processes, which execute on the client device 110 and which are configured to interact with the server agent 134, browser 122, application-output window 326, and/or web server 112. In one embodiment, the client agent 136 is spawned as a child process of the browser 122. In other embodiments, the client agent 136 is a peer process of the browser 122 or a dynamically linked library associated with the browser 122. In one embodiment, a client agent 136 is instantiated for each application-output window 326 displayed in the web page 322. In another embodiment, a single client agent 136 is instantiated for one or more application-output windows 326 associated with a particular one of the application programs 130 in the application set 126. In yet another embodiment, a single client agent 136 is instantiated for each server agent 134, which contributed to the web page content 124. In yet another embodiment, a single client agent 136 is instantiated for the entire application set 126.
The browser 122 passes the properties of the application objects 128 relating to particular application programs 130 in the application set 126 to the client agent 136 associated with those same application programs 126. Additionally, the browser 122 may pass a handle for an application-output window 326 to the client agent 136 or the client agent 136 may query the browser 122 to retrieve the handle for the application-output window 326. Application properties, which are not specified by either the browser 122 or the application objects 128, may be set to default values. The client agent 136 may also have certain property defaults hard-coded, or the client agent 136 may access a file which contains property defaults.
The client agent 136 uses the name of the application program 130 and the address of the application execution server 114, which are both provided as part of the properties of the application objects 128, to establish a communications link and initiate a client-server session with the server agent 134 associated with the server 114 and application program 130 (step 222). The client agent 136 passes some or all of the properties of the application objects 128 to the server agent 134 along with any necessary default values. Alternatively, the server agent 134 may have already received some or all of the properties of the application objects 128 from the web server 112 prior to contributing to the web page content 124, which was subsequently displayed in the web page 322. If a particular property is not passed to the server agent 134, the server agent 134 may request it from the client agent 136 if it is a necessary property to which it has no default value (e.g., user ID) or the server agent 134 may provide its own default value for the property (e.g., execution priority).
The server agent 134 uses the properties received from the client agent 136 to authenticate the client agent 136 and to execute the desired application program 130 if it has not previously been started. Once the application program 130 is executing and the client agent 136 has been authenticated, the application program 130 communicates through the server agent 130 directly with the client agent 136, without intervention of the browser 122 or web server 112. The client agent 136 receives output data from the application program 130 and displays the output data in the appropriate application-output window 326 in the web page 322. The client agent 136 also detects input events, such as mouse clicks and keyboard inputs, associated with the application-output window 130 and forwards any such input events to the application program 130 via the server agent 134. This type of client-server session is repeated for each application program 130 in the application set 126 that is selected by the user and thus enables the user to interact with all of the resources in the application set 126 (step 224).
The data exchanged between the client agent 136 and server agent 134 during the client-server session includes not only input events and the graphical output data of the application program 130, but also window attribute information (e.g., window position, z-order, size, style, color, etc.). The window attribute information of the application-output windows 326 is initially specified by the application objects 128 embedded in the web page 322. For example, the application objects 128 can include an ActiveX control, which specifies and controls the window attributes of the application-output windows 326 during the client-server session. In one embodiment, the application-output windows 326 exhibit the same dimensions as the corresponding ActiveX controls.
The client agent 136 communicates the initial window attributes of the local application-output windows 130 to the server agent 134 along with information relating to the client desktop 310 (e.g., size, resolution, etc.). The server agent 134 responds by conforming the size of its server desktop to that of the client desktop 310 and by conforming the window attributes of local server windows to those of the application-output windows 326 on the client desktop 310. The application-output windows 326 on the client desktop 310 and the server windows on the server desktop thus exhibit the same window attributes and display the same graphical output data that is generated by the application 130. Note that the server desktop can correspond to either an offscreen surface contained within the server's video memory or to an onscreen surface displayed on a display device coupled to the server 114.
The user of the client device 110 can move, resize, and/or alter the z-order or other initial window attributes of the application-output windows 326 during the client-server session, by entering an input event that is detected by the client agent 136 and then communicated to the server agent 134. The server agent 134 conforms its desktop and/or windows to be consistent with the input event and then transmits updated graphical output data and window attribute information, corresponding to the input event, to the client agent 136 with instructions to update the application-output windows 326 so that they match the windows on the server 114.
For example, if the user of the client device 110 resizes one of the application-output windows 326 from that originally specified by the application objects 128 (such as by clicking with the mouse and dragging the border of the application-output window 326 to the desired location/size), the client agent 136 detects the input event generated by the mouse action and communicates it to the server agent 134, which effects the same resize event in the on or offscreen surfaces of the server 114. The server agent 134 then sends repaint and resize command messages to the client agent 136 along with updated graphical output data and window attribute information. In response, the client agent 136 modifies the appropriate application object 128 affected by the resize event (e.g., the ActiveX control discussed above) so that the corresponding application-output window 326 is resized and the updated graphical output data is painted within the borders of the application-output window 326.
The invention thus enables the window attributes of the application-output window 326 to be modified so that the application-output window 326 can be moved, resized, etc., within the boundaries of the browser window 320. With reference to FIG. 4 and by way of nonlimiting example, application-output window B′ 410 can be resized using the methodology described above to form application-output window B″ 420, which overlaps (thus exhibiting a different z-order from) application-output window F 430. Alternatively, the application-output window 326 can be moved or resized to extend beyond or be entirely outside of the browser window 320. By way of nonlimiting example and with reference to
In one embodiment, each input event affecting the application-output window 326 is transferred to and processed by the server agent 114, which then instructs the client agent 136 to effect corresponding changes in the application-output window 326. In another embodiment, one or more input event types (e.g., click and drag mouse actions directed at moving the application-output window 326 to another grid location on the web page 322) are processed entirely by the client agent 136 and not reported to the server agent 134, where the graphical output data displayed within the application-output window 326 remains unchanged.
In more detail and with reference to
The message receiving process 630 receives graphical data, window attribute information, and commands from the server agent 134 via the communications link that provides the connectivity between the client agent 136 and server agent 134 during the client-server session. The communications link preferably includes a first virtual channel 660 and a second virtual channel 670. Command, event, and window attribute information is passed between the client agent 136 and the server agent 134 via the first virtual channel 660, while graphical data corresponding to the graphical contents of the application-output windows 326 is passed via the second virtual channel 670. The message receiving process 630 informs the command process 620 of the commands, window attributes, and graphical data received from the server agent 134 and the command process 620 further processes this data.
In one embodiment, the command process 620 processes the commands received from the server agent 134 by instructing the client operating system 650 to form and/or modify affected application-output windows 326 in accordance with the window attributes specified by the server agent 134. The command process 620 also instructs the client operating system 650 to display the graphical data provided by the server agent 134 in the appropriate application-output windows 326. In one embodiment, the command process 620 implements changes to the application-output windows 326 in the client desktop 310 by issuing GDI commands. In other embodiments, the command process 620 issues commands directly to an associated graphics subsystem or via graphics API commands.
The command process 620 also instructs the monitor process 610 to periodically monitor the client desktop 310 in order to detect changes affecting the application-output windows 326. In one embodiment, the monitor process 610 instructs the client operating system 650 to return information relating to the client desktop 310 at predetermined polling intervals. In other embodiments, the monitor process 610 monitors the message queue maintained by the client operating system 650 in order to detect changes affecting the application-output windows. The monitor process 610 communicates some or all of the detected desktop changes to the command process 620 for further processing.
In one embodiment, the command process 620 instructs the message transmission process 640 to transmit all of the changes detected by the monitor process 610 to the server agent 134 via the first virtual channel. In another embodiment, the command process 620 instructs the message transmission process 640 to transmit a subset of the detected changes, such as changes which only affect the graphical data and/or window attributes of the application-output windows 326. The server agent 134 receives the detected changes along with any commands from the command process 620 and any input events made by the user of the client device 110 that triggered the detected changes. The server agent 134 then modifies its local desktop to accommodate the detected changes and transmits associated commands, window attributes, and graphical data back to the client's message receiving process 630. In this manner, the present invention ensures that desktop elements, such as the application-output windows 326, that are common in the client and server desktops remain in lock step.
The command process 620 of the client agent 136 ensures that analogous/common elements in the client and server desktops remain in lock step by maintaining a common window list. The common window list includes the window attribute information for each window in the client desktop 310 and for each corresponding window in the server desktop. In embodiments, in which a plurality of client agents are executing on the client device 110, the command process 620 of a single client agent 136 has primary responsibility for maintaining the common window list. If the single client agent 136 terminates, while other client agents remain in operation, the remaining client agents will elect another primary client agent to maintain the common window list.
The present invention also enhances the performance of the client-server session by preferably using the techniques described in co-owned, International Patent Publication No. WO 01/92973, which is incorporated herein by reference, to reduce the amount of graphical data transmitted between the client and server agents. In one embodiment, the invention encodes the data into relatively small representations that repeat within the protocol stream transmitted between the client agent 136 and the server agent 134. In this manner, the invention minimizes the size of each discrete data element that must be transmitted and increases the repeatability of the data within the protocol stream so that compression algorithms that operate more efficiently on repetitive encoded data can realize a greater degree of compression efficiency. The invention uses a number of techniques to realize this enhanced compression, including the following: scanning a command queue for later-issued commands which supercede earlier-issued commands; disk-caching techniques that improve compression of data that has been previously encountered during a client-server session; transmission of relative coordinates using quantized regions to avoid sending both endpoints and/or the angle of an associated strip (i.e., series of consecutive pixels exhibiting a common angle); and manipulation of off-screen surfaces to enhance performance during the client-server session. The invention also reduces the frequency of overscroll problems encountered when there is a performance mismatch between a fast server and a relatively slow network or client device.
Having described certain embodiments of the invention, it will now become apparent to one of 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.
This claims priority to co-pending U.S. patent application Ser. No. 09/086,898, filed May 29, 1998; co-pending U.S. patent application Ser. No. 08/855,977, filed May 14, 1997; and co-pending U.S. patent application Ser. No. 09/247,220, filed Feb. 10, 1999, the entirety of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4387425 | El-Gohary | Jun 1983 | A |
4499499 | Brickman et al. | Feb 1985 | A |
RE32632 | Atkinson | Mar 1988 | E |
4779189 | Legvold et al. | Oct 1988 | A |
4860247 | Uchida et al. | Aug 1989 | A |
4887204 | Johnson et al. | Dec 1989 | A |
4903218 | Longo et al. | Feb 1990 | A |
4937036 | Beard et al. | Jun 1990 | A |
4937784 | Masai et al. | Jun 1990 | A |
4949281 | Hillenbrand et al. | Aug 1990 | A |
4958303 | Assarpour et al. | Sep 1990 | A |
4974173 | Stefik et al. | Nov 1990 | A |
5014221 | Mogul | May 1991 | A |
5031089 | Liu et al. | Jul 1991 | A |
5062060 | Kolnick | Oct 1991 | A |
5072412 | Henderson, Jr. et al. | Dec 1991 | A |
5103303 | Shoji et al. | Apr 1992 | A |
5119319 | Tanenbaum | Jun 1992 | A |
5155847 | Kirouac et al. | Oct 1992 | A |
5175852 | Johnson et al. | Dec 1992 | A |
5187790 | East et al. | Feb 1993 | A |
5202971 | Henson et al. | Apr 1993 | A |
5204897 | Wyman | Apr 1993 | A |
5231697 | Yamada | Jul 1993 | A |
5233701 | Nakata | Aug 1993 | A |
5241625 | Epard et al. | Aug 1993 | A |
5247683 | Holmes et al. | Sep 1993 | A |
5249290 | Heizer | Sep 1993 | A |
5255361 | Callaway et al. | Oct 1993 | A |
5301270 | Steinberg et al. | Apr 1994 | A |
5305440 | Morgan et al. | Apr 1994 | A |
5309555 | Akins et al. | May 1994 | A |
5325527 | Cwikowski et al. | Jun 1994 | A |
5329619 | Page et al. | Jul 1994 | A |
5341477 | Pitkin et al. | Aug 1994 | A |
5341478 | Travis, Jr. et al. | Aug 1994 | A |
5351129 | Lai | Sep 1994 | A |
5367688 | Croll | Nov 1994 | A |
5414457 | Kadowaki et al. | May 1995 | A |
5440719 | Hanes et al. | Aug 1995 | A |
5457797 | Butterworth et al. | Oct 1995 | A |
5461608 | Yoshiyama | Oct 1995 | A |
5469540 | Powers, III et al. | Nov 1995 | A |
5473599 | Li et al. | Dec 1995 | A |
5483466 | Kawahara et al. | Jan 1996 | A |
5485460 | Schrier et al. | Jan 1996 | A |
5499343 | Pettus | Mar 1996 | A |
5515508 | Pettus et al. | May 1996 | A |
5517617 | Sathaye et al. | May 1996 | A |
5526492 | Ishida | Jun 1996 | A |
5530852 | Meske, Jr. et al. | Jun 1996 | A |
5537546 | Sauter | Jul 1996 | A |
5537548 | Fin et al. | Jul 1996 | A |
5541927 | Kristol et al. | Jul 1996 | A |
5548726 | Pettus | Aug 1996 | A |
5551030 | Linden et al. | Aug 1996 | A |
5553242 | Russell et al. | Sep 1996 | A |
5557732 | Thompson | Sep 1996 | A |
5557748 | Norris | Sep 1996 | A |
5561769 | Kumar et al. | Oct 1996 | A |
5566302 | Khalidi et al. | Oct 1996 | A |
5572643 | Judson | Nov 1996 | A |
5572674 | Ernst | Nov 1996 | A |
5574934 | Mirashrafi et al. | Nov 1996 | A |
5579469 | Pike | Nov 1996 | A |
5583563 | Wanderscheid et al. | Dec 1996 | A |
5583992 | Kudo | Dec 1996 | A |
5586312 | Johnson et al. | Dec 1996 | A |
5592626 | Papadimitriou et al. | Jan 1997 | A |
5594490 | Dawson et al. | Jan 1997 | A |
5596745 | Lai et al. | Jan 1997 | A |
5606493 | Duscher et al. | Feb 1997 | A |
5619716 | Nonaka et al. | Apr 1997 | A |
5623656 | Lyons | Apr 1997 | A |
5644720 | Boll et al. | Jul 1997 | A |
5657390 | Elgamal et al. | Aug 1997 | A |
5671379 | Kuse et al. | Sep 1997 | A |
5680549 | Raynak et al. | Oct 1997 | A |
5701451 | Rogers et al. | Dec 1997 | A |
5706437 | Kirchner et al. | Jan 1998 | A |
5708786 | Teruuchi | Jan 1998 | A |
5710918 | Lagarde et al. | Jan 1998 | A |
5721876 | Yu et al. | Feb 1998 | A |
5734865 | Yu | Mar 1998 | A |
5737592 | Nguyen et al. | Apr 1998 | A |
5742778 | Hao et al. | Apr 1998 | A |
5748892 | Richardson | May 1998 | A |
5754830 | Butts et al. | May 1998 | A |
5757925 | Faybishenko | May 1998 | A |
5758085 | Kouoheris et al. | May 1998 | A |
5761507 | Govett | Jun 1998 | A |
5764908 | Shoji et al. | Jun 1998 | A |
5764915 | Heimsoth et al. | Jun 1998 | A |
5767849 | Borgendale et al. | Jun 1998 | A |
5768614 | Takagi et al. | Jun 1998 | A |
5802258 | Chen | Sep 1998 | A |
5802306 | Hunt | Sep 1998 | A |
5812784 | Watson et al. | Sep 1998 | A |
5819093 | Davidson et al. | Oct 1998 | A |
5826027 | Pedersen et al. | Oct 1998 | A |
5828840 | Cowan et al. | Oct 1998 | A |
5838906 | Doyle et al. | Nov 1998 | A |
5838910 | Domenikos et al. | Nov 1998 | A |
5838916 | Domenikos et al. | Nov 1998 | A |
5844553 | Hao et al. | Dec 1998 | A |
5870545 | Davis et al. | Feb 1999 | A |
5874960 | Mairs et al. | Feb 1999 | A |
5877757 | Baldwin et al. | Mar 1999 | A |
5889942 | Orenshteyn | Mar 1999 | A |
5913060 | Discavage | Jun 1999 | A |
5913920 | Adams et al. | Jun 1999 | A |
5923842 | Pedersen et al. | Jul 1999 | A |
5928324 | Sloan | Jul 1999 | A |
5938733 | Heimsoth et al. | Aug 1999 | A |
5940075 | Mutschler et al. | Aug 1999 | A |
5941949 | Pedersen | Aug 1999 | A |
5941988 | Bhagwat et al. | Aug 1999 | A |
5944791 | Scherpbier | Aug 1999 | A |
5949975 | Batty et al. | Sep 1999 | A |
5951694 | Choquier et al. | Sep 1999 | A |
5961586 | Pedersen | Oct 1999 | A |
5973696 | Agranat et al. | Oct 1999 | A |
5978847 | Kisor et al. | Nov 1999 | A |
5978848 | Maddalozzo, Jr. et al. | Nov 1999 | A |
5999179 | Kekic et al. | Dec 1999 | A |
5999950 | Krueger et al. | Dec 1999 | A |
6023721 | Cummings | Feb 2000 | A |
6034689 | White et al. | Mar 2000 | A |
6088515 | Muir et al. | Jul 2000 | A |
6108712 | Hayes, Jr. | Aug 2000 | A |
6157944 | Pedersen | Dec 2000 | A |
6161126 | Wies et al. | Dec 2000 | A |
6272493 | Pasquali | Aug 2001 | B1 |
6292827 | Raz | Sep 2001 | B1 |
20030063119 | Bloomfield et al. | Apr 2003 | A1 |
Number | Date | Country |
---|---|---|
0381645 | Aug 1990 | EP |
0384339 | Aug 1990 | EP |
0414624 | Feb 1991 | EP |
0475581 | Mar 1992 | EP |
0483576 | May 1992 | EP |
0540151 | May 1993 | EP |
0540151 | May 1993 | EP |
0643514 | Mar 1995 | EP |
0648038 | Apr 1995 | EP |
0732834 | Sep 1996 | EP |
0767563 | Apr 1997 | EP |
0841615 | May 1998 | EP |
0878759 | Nov 1998 | EP |
06125363 | May 1994 | JP |
06332782 | Dec 1994 | JP |
9315457 | Aug 1993 | WO |
9728623 | Aug 1997 | WO |
9728623 | Aug 1997 | WO |
9852320 | Nov 1998 | WO |
9852344 | Nov 1998 | WO |
Number | Date | Country | |
---|---|---|---|
20020196279 A1 | Dec 2002 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09086898 | May 1998 | US |
Child | 10068461 | US | |
Parent | 09247220 | Feb 1999 | US |
Child | 09086898 | US | |
Parent | 08855977 | May 1997 | US |
Child | 09247220 | US | |
Parent | 08556623 | Nov 1995 | US |
Child | 08855977 | US |