This invention relates generally to localization of computer-based applications, and more particularly to translating application terminology into local languages.
A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure as it appears in the Patent and Trademark Office patent file or records, but otherwise reserves all copyright rights whatsoever. The following notice applies to the software and data as described below and in the drawings hereto: Copyright ©2001, Siebel Systems, Inc., All Rights Reserved.
Interactive computer applications typically use graphical user interfaces (GuIs) to allow a user to interact with the applications. The data processed by the application is supplemented by pre-defined text, such as titles, captions, and the like. The pre-defined text is written in a human language, usually the native language of the country of the developer or a common language, such as English. When the application is destined for use in other countries, typically the text is manually translated into the various local languages as part of a process commonly referred to as “localization.” Localization must be performed for each new version of the application. However, the text may have multiple translations for each target language depending on its context. For example, the English word “account” may mean a customer in one context and a bank account in another. Therefore, accurate translation of the text is dependent upon the translator's understanding of the context in which it appears.
A visual context displays a graphical user interface for an application without executing the application. The visual context is constructed from a definition for the graphical user interface. In one aspect, executable code for various components of the graphical user interface are extracted from the definition and written into the visual context. In another aspect, the executable code for one or more of the components is written into separate files that make up the visual context. In still another aspect, some of the components are based on templates, and the appropriate template is copied into the visual context to provide the executable code for the component. The visual context, or a reference to it, may be provided to translators to aid in the translation of text strings appearing in the graphical user interface.
The present invention describes systems, clients, servers, methods, and machine-readable media of varying scope. In addition to the aspects of the present invention described in this summary, further aspects of the invention will become apparent by reference to the drawings and by reading the detailed description that follows.
FIGS. 1B-C are diagrams of graphical user interface emulation file data structures for use in with the embodiment of
In the following detailed description of embodiments of the invention, reference is made to the accompanying drawings in which like references indicate similar elements, and in which is shown by way of illustration specific embodiments in which the invention may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that logical, mechanical, electrical, functional, and other changes may be made without departing from the scope of the present invention. The following detailed description is, therefore, not to be taken in a limiting sense, and the scope of the present invention is defined only by the appended claims.
A system level overview of the operation of an embodiment of a visual context translation system 101 that facilitates localization of graphic-user interfaces (GUIs) is described by reference to
The text strings 109 are sent to translators 115 for translation. The visual context 111 may be sent to the translators as part or, or separate from, the text strings 109. Alternatively, a reference to the visual context 111 may be sent that allows access to the visual context 111 through a network connection, such as a URL (universal resource locator) that causes the visual context 111 to represent the GUI in a browser connected to the Internet.
In one embodiment, the visual context 111 comprises a GUI emulation file structure, such as illustrated in FIGS. 1B-C. A GUI generally presents multiple screens (“views”) to a user, with each view having one or more interactive controls that display and receive information. In a particular embodiment, the controls on a view are presented through applets, and each such applet may have multiple modes, such as read-only, query, etc., with the arrangement of controls in an applet varying by mode.
One embodiment of a structure for a GUI emulation file 120 is shown in FIG. IB. The GUI emulation file 120 contains view data 121, including, for example, an identifier for the view and markup code that specifies common elements for the view, such as font, color, title, etc. An applet entry 123 is present in the GUI emulation file 120 for each applet within the view. The applet entry 123 contains applet data 125 including an applet identifier and the markup code that displays the applet. The applet entry 123 also contains a mode entry 127 for each applet layout that could appear in the view. Each mode entry 127 contains mode data 129 identifying the mode and its markup code, and identifiers and markup code for one or more applet user controls 151 that are part of the applet.
When more than one mode entry 127 exists, the applet data 125 further contains markup code that presents the different applet modes in response to user input. In one embodiment, the view initially presents a default mode for the applet when the GUI emulation file 120 is executed and clicking within the boundaries of the applet causes the markup code in the applet data 125 to show all the applet modes associated with the view. Although only a single view is illustrated as being stored in the GUI emulation file 120 in
Furthermore, in alternate embodiments, the various entries in the GUI emulation file 120 may hold pointers to separate files that contain the markup code and other data for the entries. A GUI emulation file structure 130 in
A table of contents (TOC) file 131 contains HTML code 133 that presents a list of views to the user when executed. Each entry 135 in the list is hyperlink containing a view identifier. When the user selects the hyperlink, the corresponding view file 137 is invoked. Each view file 137 is based on a template, shown as template file 147. The template file 147 for a view contains HTML code 133 that presents the view and location placeholders 149 that specify where the applets appear in the view.
The placeholders 149 are replaced with applet entries 141 in the view file 137. Each applet entry 141 contains an applet identifier 143 that references an applet file 155. The applet file 155 is also based on a template file 147, which contains the HTML code 133 that presents the applet and placeholders 149 that specify the location of the controls 147 for the applet. If the applet has more than one mode, the applet identifier 143 references the applet file 155 for a default mode for the view, and “wrapper” HTML code 133 in the applet entry 141 presents the alternate modes at the user's discretion. In one embodiment, if the user clicks anywhere within the default applet mode in the view, a frame file 151 is invoked that displays each alternate mode in a frame. The frame file 151 contains HTML code 133 and mode identifiers 153 that reference the applet files 155 for the various modes.
One embodiment of a context creation method 200 performed by the visual context translation system 101 is described with reference to flowchart shown in
For each view in the GUI, the method 200 identifies the corresponding template file (block 201) using the view definition in the GUI, and copies the template code to the view file (block 203). For each placeholder in the view file, the method 200 performs an applet loop starting at block 205. The view definition specifies a placeholder identifier for each applet. If no applet is mapped to the placeholder identifier (block 207), the placeholder is deleted (block 209). If an applet is mapped to the placeholder identifier, the template file for the applet is identified (block 211) and the template is copied to the applet file (block 213). The method 200 processes each placeholder in the applet file starting at block 215. If no control is mapped to the placeholder in the applet definition (block 217), the placeholder is deleted (block 219). If a control is mapped to the placeholder, the code for the control is extracted from the applet definition and written to the applet file at the placeholder location (block 221). Once all controls for an applet have been processed (block 223), the method 200 determines if the view definition specifies the applet mode currently being processed as the default for the view (block 225). If so, the applet identifier for the current mode's applet file is written to the view file at the applet placeholder location (block 227).
If the current applet mode is not specified as the default for the view (block 225), the method 200 determines if the frame file has already been created (block 229). If not, the method 200 writes pre-defined wrapper code to the view file (block 231), and pre-defined frame code (block 233), and the applet identifier for the default mode applet file (block 235) to the frame file. In either case, the applet identifier for the current mode's applet file is written to the frame file at block 237. When all applet modes in the view have been processed (block 239), the method 200 processes the next view, if there are more views in the GUI (block 241).
In practice, the context creation method 200 may constitute one or more programs made up of machine-executable instructions. Describing the method with reference to the flowchart in
The following description of FIGS. 3A-B is intended to provide an overview of computer hardware and other operating components suitable for implementing the visual context translation system, but is not intended to limit the applicable environments. One of skill in the art will immediately appreciate that the invention can be practiced with other computer system configurations, including hand-held devices, multiprocessor systems, microprocessor-based or programmable consumer electronics, network PCs, minicomputers, mainframe computers, and the like. The invention can also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
The web server 9 is typically at least one computer system which operates as a server computer system and is configured to operate with the protocols of the World Wide Web and is coupled to the Internet. Optionally, the web server 9 can be part of an ISP which provides access to the Internet for client systems. The web server 9 is shown coupled to the server computer system 11 which itself is coupled to web content 10, which can be considered a form of a media database. It will be appreciated that while two computer systems 9 and 11 are shown in
Client computer systems 21, 25, 35, and 37 can each, with the appropriate web browsing software, view HTML pages provided by the web server 9. The ISP 5 provides Internet connectivity to the client computer system 21 through the modem interface 23 which can be considered part of the client computer system 21. The client computer system can be a personal computer system, a network computer, a Web TV system, or other such computer system. Similarly, the ISP 7 provides Internet connectivity for client systems 25, 35, and 37, although as shown in
Alternatively, as well-known, a server computer system 43 can be directly coupled to the LAN 33 through a network interface 45 to provide files 47 and other services to the clients 35, 37, without the need to connect to the Internet through the gateway system 31.
It will be appreciated that the computer system 51 is one example of many possible computer systems which have different architectures. For example, personal computers based on an Intel microprocessor often have multiple buses, one of which can be an input/output (I/O) bus for the peripherals and one that directly connects the processing unit 55 and the memory 59 (often referred to as a memory bus). The buses are connected together through bridge components that perform any necessary translation due to differing bus protocols.
Network computers are another type of computer system that can be used with the present invention. Network computers do not usually include a hard disk or other mass storage, and the executable programs are loaded from a network connection into the memory 59 for execution by the processing unit 55. A Web TV system, which is known in the art, is also considered to be a computer system according to the present invention, but it may lack some of the features shown in
It will also be appreciated that the computer system 51 is controlled by operating system software which includes a file management system, such as a disk operating system, which is part of the operating system software. One example of an operating system software with its associated file management system software is the family of operating systems known as Windows® from Microsoft Corporation of Redmond, Wash., and their associated file management systems. The file management system is typically stored in the non-volatile storage 65 and causes the processing unit 55 to execute the various acts required by the operating system to input and output data and to store data in memory, including storing files on the non-volatile storage 65.
A visual context that displays a graphical user interface for an application without executing the application has been described. Although specific embodiments have been illustrated and described herein, it will be appreciated by those of ordinary skill in the art that any arrangement which is calculated to achieve the same purpose may be substituted for the specific embodiments shown. This application is intended to cover any adaptations or variations of the present invention. For example, although exemplary embodiments of the visual context that use HTML have been described, the invention is suitable for use with any programming language capable of presenting a GUI.
The terminology used in this application with respect to files is meant to include all types of data storage environments, including flat files, relational databases, indexed files, linked lists, and the like. Therefore, it is manifestly intended that this invention be limited only by the following claims and equivalents thereof.