Foreign language translator in a document editor

Information

  • Patent Application
  • 20080172219
  • Publication Number
    20080172219
  • Date Filed
    January 17, 2007
    18 years ago
  • Date Published
    July 17, 2008
    16 years ago
Abstract
Apparatus and methods allow users of document editors to real-time translate language of text from a first to a second language. During use, users indicate a selection for translation in a typing area of the document editor. The document editor seeks translation from a remote language translation service, especially by way of internet http requests. Processing of returned translations also occurs to present users with a useable form of the translation. Other aspects include seeking translations from multiple language translation services and selecting a best translation for display, according to a predetermined criteria. Users can also select preferred languages for translation. Retrofitting existing document editors contemplates inserting executable code, in the form of plug-ins or macros, and executing them to obtain translations. Executable code is available as a computer program product in the form of a download or on a computer-readable medium.
Description
FIELD OF THE INVENTION

Generally, the present invention relates to computing environments having document editor software for creating and editing documents. Particularly, it relates to real-time translating text of open documents from first to second languages, or more. Various features include seeking language translation from sources remote to the document editor, such as by way of the internet, without the user needing to interface with a browser or other application external to the document editor. Still other features include the seeking of multiple language translations and selecting a best translation according to predetermined criteria. Establishing executable code in the document editor as a macro to-be-run is another noteworthy aspect.


BACKGROUND OF THE INVENTION

“Document editors,” such as Microsoft's Word program, Corel's WordPerfect program and Sun Microsystem's OpenOffice.org Writer program, to name a few, have been known for some time for the creation, editing and viewing of documents. Also known as word processing software, the document editors are robust products with numerous text functions, such as spelling and grammar checkers, dictionary and thesaurus resources, and foreign language dictionaries, but none of the products have language translation features. For this, users are left to their own devices.


Namely, human users translate words or texts of documents on their own with or without the assistance of other services. To the extent they use services, it is not uncommon to seek language-translation assistance from a stand-alone, handheld language translator, from a dedicated piece of language-translating software on a computing device, or by way of searching the internet. For the latter, many language translation services abound on the world wide web (wbb) and typical usage consists of cutting/pasting or typing to-be-translated words or text into a page of an open browser to get the translation from the remote databases of the translation service. Upon its translation (regardless of source), users then take the text back to the document editor and continue word processing functions as normal.


A problem with all these approaches, however, lies in the cumbersomeness of needing to consult a physical device, software application or internet web site external to the word processing software in which the text (in need of translation) resides. Stated differently, users experience inconvenience in time and effort (and sometimes money for the purchase of services) for want of a document editor having language translation services that can translate text of an open document without having to perform additional roles, like seeking language translations from the internet.


Still another problem with the prior art relates to a user's incognizance of how well a translation service actually performed. For example, many users take translations at face value without awareness of the properness of the translation, especially in relation to other words or text in the document.


Accordingly, there is need in the art of document editors for language translation services. There is further need to make the services invisible or silently-operated relative to the user of the document editor to minimize inconvenience. It is also important to translate quickly and provide appropriate translations in the context of an open document of the editor. In that many users already own and/or use a document editor, it is further desirable to convert existing document editor software to the type having language translation services. Naturally, any improvements along such lines should further contemplate good engineering practices, such as relative inexpensiveness, stability, ease of implementation, low complexity, flexibility, etc.


SUMMARY OF THE INVENTION

The above-mentioned and other problems become solved by applying the principles and teachings associated with the hereinafter-described foreign language translator in a document editor. In a basic sense, users indicate text for translation directly in a document of the software and, silently or invisibly to the user, the text becomes translated. This adds robustness heretofore unavailable.


In one embodiment, a document editor is installed on a computing device. Upon configuration with appropriate executable instructions, the editor formulates requests to seek translation from a language translation service remote from the computing device upon an indication of a selection of text for translation by the user. Representatively, the document editor fashions one or more http requests to query the language translation service by way of the internet. Upon a translation received from the translation service, the document editor distills sundry code to provide a clean or useable translation form to the user. In this manner, users receive real-time translations to their text, but without any inconvenience, such as by way of opening browser applications, visiting web sites, consulting stand-alone products or software. It also appears to the user that the functionality of language translation was built directly into the document editor.


In another embodiment, the document editor solicits translations from many language translation services, and returns only a best translation to the user, based on predetermined criteria. In this manner, users get an appropriate translation, especially in the context of other text in the document. Naturally, users can also choose among different foreign languages, and translate a selection into or out of various languages, going straight from one to the other without going back to the original user-entered text.


In still another embodiment, configuring existing document editors simply requires the insertion of executable code to seek translation services as an executable macro of the document editor. This, of course, translates into ease of implementation. In an OpenOffice.org Writer version of the invention, for example, a prototype macro (written as a JavaScript macro, but could be in any language format) is easily inserted by menu commands and run from open documents. In other document editors, the code can be in macro format or compiled as a plug-in if the target application has a plug-in API capabilities, for example.


Regardless of form, the present invention allows users of document editors to real-time translate language of text in an open document from a first to a second language, or more, and back again, if desired. Simply, the document editor is configured with executable code seeking translation services from locations remote of the document editor, especially by way of http calls to the internet. During use, users simply indicate a selection for translation by highlighting text in a typing area of the document editor and the editor, returns real-time translations.


Still other embodiments contemplate computer program products available on computer-readable media or as downloads. Programming languages other than JavaScript are contemplated and include, but are not limited to, C, C++, C#, Python, BeanShell, or other.


These and other embodiments of the present invention will be set forth in the description which follows, and in part will become apparent to those of ordinary skill in the art by reference to the following description of the invention and referenced drawings or by practice of the invention. The claims, however, indicate the particularities of the invention.





BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying drawings incorporated in and forming a part of the specification, illustrate several aspects of the present invention, and together with the description serve to explain the principles of the invention. In the drawings:



FIG. 1 is a diagrammatic view in accordance with the present invention of a representative computing environment for a foreign language translator in a document editor;



FIG. 2 is a flow chart in accordance with the present invention for translating language in a document editor;



FIGS. 3A-3F are screens shots from a computing monitor in accordance with the present invention of a prototype foreign language translator in a document editor;



FIGS. 4A-4D are screen shots from a computing monitor in accordance with the present invention for using the prototype foreign language translator of FIGS. 3A-3F;



FIG. 5 is a screen shot from a computing monitor in accordance with the present invention of an alternate embodiment for using the prototype foreign language translator in a document editor;



FIG. 6 is a flow chart in accordance with the present invention of an alternate embodiment for translating language in a document editor; and



FIG. 7 is a flow chart in accordance with the present invention of another alternate embodiment for translating language in a document editor, especially conversion of a formatted document from a first to a second language.





DETAILED DESCRIPTION OF THE ILLUSTRATED EMBODIMENTS

In the following detailed description of the illustrated embodiments, reference is made to the accompanying drawings that form a part hereof, 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 like numerals represent like details in the various figures. Also, it is to be understood that other embodiments may be utilized and that process, mechanical, electrical, arrangement, software and/or other changes may be made without departing from the scope of the present invention. In accordance with the present invention, methods and apparatus for foreign language translation in a document editor are hereinafter described.


With reference to FIG. 1, a representative environment 10 for language translation in a document editor (Doc. Ed.) consists of one or more computing devices 15 available per each document editor, especially as an installed application of executable code on a computing device remote from a language translation service 20. In a traditional sense, an exemplary computing device includes a general or special purpose computing device in the form of a conventional fixed or mobile computer 17 having an attendant monitor 19 and user interface 21. The computer internally includes a processing unit for a resident operating system, such as DOS, WINDOWS, MACINTOSH, VISTA, UNIX and LINUX, to name a few, a memory, and a bus that couples various internal and external units, e.g., other 23, to one another. Representative other items 23 include, but are not limited to, PDA's, cameras, scanners, printers, microphones, joy sticks, game pads, satellite dishes, hand-held devices, consumer electronics, minicomputers, computer clusters, main frame computers, a message queue, a peer machine, a broadcast antenna, a web server, an AJAX client, a grid-computing node, a peer, a virtual machine, a web service endpoint, a cellular phone or palm device, or the like. The other items may also be stand alone computing devices 15′ in the environment 10 or the computing device itself, upon which the document editor is installed.


In either, storage devices are contemplated and may be remote or local. While the line is not well defined, local storage generally has a relatively quick access time and is used to store frequently accessed data, while remote storage has a much longer access time and is used to store data that is accessed less frequently. The capacity of remote storage is also typically an order of magnitude larger than the capacity of local storage. Regardless, storage is representatively provided for aspects of the invention contemplative of computer executable instructions, e.g., software, as part of computer program products on readable media, e.g., disk 14 for insertion in a drive of computer 17. Computer executable instructions may also be available as a download or reside in hardware, firmware or combinations in any or all of the depicted devices 15 or 15′.


When described in the context of computer program products, it is denoted that items thereof, such as modules, routines, programs, objects, components, data structures, etc., perform particular tasks or implement particular abstract data types within various structures of the computing system which cause a certain function or group of functions. In form, the computer product can be any available media, such as RAM, ROM, EEPROM, CD-ROM, DVD, or other optical disk storage devices, magnetic disk storage devices, floppy disks, or any other medium which can be used to store the items thereof and which can be assessed in the environment.


In network, the computing device of the document editor communicates with one or more other devices 20, 20′ via wired, wireless or combined connections 12 that are either direct 12a or indirect 12b. If direct, they typify connections within physical or network proximity (e.g., intranet). If indirect, they typify connections such as those found with the internet, satellites, radio transmissions, or the like, and are given indistinctly as element 13. In this regard, other contemplated items include servers, routers, peer devices, modems, T1 lines, satellites, microwave relays or the like. The connections may also be local area networks (LAN) and/or wide area networks (WAN) that are presented by way of example and not limitation. The topology is also any of a variety, such as ring, star, bridged, cascaded, meshed, or other known or hereinafter invented arrangement.


In form, the other devices 20, 20′ represent language translation services available to the document editor for seeking translations, upon user indication of selections of text. In one embodiment, the other devices consist of web servers 22 and attendant databases 24, containing logic for translating language. Altavista's Babel Fish, for instance, is representative of the other device, but may be any of a variety of language translators, such as those found at wordreference.com, translation.langenberg.com, or other. In other embodiments, more than one other device is contemplated, and optional features are shown in dashed lines in the figure. Regardless of form, however, it is where the document editor of the invention will seek translation of text, without inconveniencing the user of the editor.


With reference to FIG. 2, a high-level organization for language translation in a document editor is given generally as element 40. At step 42, a document editor is provided. In this regard, the document editor is of an existing type, such as Microsoft's Word program, Corel's WordPerfect program or Sun Microsystem's OpenOffice.org Writer program, to name a few, or is of a proprietary nature not yet known commercially. It is also installed on a computing device 15 or 15′ (FIG. 1) and users locally or remotely create, edit and view existing or new documents of the word processing variety through its functionality. The document editor is also configured originally with executable code to perform the hereafter-described language translation or is re-configured after initial release, such as by way of retrofit.


In either, the users indicate a selection of text for translation, such as by highlighting text in an open document of the editor (step 44). Upon this occurring, the document editor issues http requests to the translation service, e.g., 20 (FIG. 1), remote from the computing device upon which the document editor is installed (step 46).


Upon receipt of the request, the translation service translates the text so highlighted and returns it to the document editor, where it is received (step 48). In that translations often include code superfluous to the actual translation of text, the document editor processes the received translation (step 50) to clean it for ultimate presentation in a useable translation form to the user (step 52).


With reference to the sequential screen shots of a monitor 19 in FIGS. 3A-3F, a prototype installation of executable code into a document editor 30, of the OpenOffice.org Writer type, on a local computing device 15 (FIG. 1) is described. As seen in FIG. 3A, a user selects Tools>Macros>Organize Macros>JavaScript according to the drop down menus 60, 62 and 64 and highlighted bars 61, 63, 65 and 67.


In FIG. 3B, this causes opening of a “JavaScript Macros” window 70 that users use to select, such as by way of the shown pointing device, the option “Create” 72. Upon this occurring, a “Create Library” window 74 is opened that users utilize to insert an appropriate name, e.g., Foreign Language Translator, 76. They then select “OK” 78.


In FIG. 3D, this then creates the appropriate library in the JavaScript Macros window 70, at position 80, for example. Users then select or highlight the library to create the actual JavaScript macro. In this example, the user named the macro “language xlator” 82 (FIG. 3E), whereupon the “Edit” option 84 is selected to actually supply the necessary executable code, in this instance an executable macro, in the document editor. In FIG. 3F, this occurs upon the opening of an editor window 90 (“Rhino JavaScript Debugger”), where the lines of executable code 92, for seeking translation from remote translation services (described in more detail below under the heading “Code Listing”), is inserted, either by pasting, typing or on-the-go programming, to name a few. The user then “saves” the macro, such as under the File heading 94, for instance, and the document editor is provisioned with foreign language translation capabilities of the type previously outlined.


With reference to FIGS. 4A-4D, use of the document editor 30, so provisioned with the macro from FIGS. 3A-3F, is now described for the translation services of text. In FIG. 4A, a user adds text 100, such as by typing, pasting, etc., into a typing area 102 of the document editor. The user then indicates the selection for translation, such as by highlighting it 106 by way of a pointing device, for example. As will be appreciated, however, it is seen that all the text in the typing area is highlighted. In other examples, users may want less-than-all the available text translated and are free to indicate translation of just a single word, a single sentence, a single paragraph, etc., of a much larger document. Naturally, the invention embraces all such scenarios.


In FIG. 4B, the user then runs the macro previously installed. In one embodiment, this consists of highlighting various menu commands, such as a “Run Macro” option 108 under the Tools drop down menu 60 and the “Macros” drop down menu 62. In FIG. 4C, this then opens a “Macro Selector” window 110, whereby users select the previously-made “language xlator.js” 82, under the “Foreign Language Translator” 80, and select the “Run” option 112. Thereafter, and nearly instantaneously or “just-in-time,” the document editor issues its http request of the remote translation services, receives a translation response, and processes the response for display to a user (FIG. 2: steps 46, 48, 50, and 52). As seen in FIG. 4D, the text (at its highlighted position) is then replaced with the translation result 120. In this instance, the English text “HOW TO INSERT CODE FOR FOREIGN LANGUAGE TRANSLATOR” was replaced with “WIE MAN CODE FÜR FREMDSPRACHE-ÜBERSETZER EINSETZT” in German, complete with German symbols “Ü” and being all in capital letters, corresponding to the format specified by the user of the source document. Naturally, translations can occur from any language to any other language and the functionality for this resides in the executable code of the macro earlier established. Translations can also occur again and again, with or without returning to the original English text. That is, a user could select the German text 120 in FIG. 4D, and have it translated directly to still another language upon the running of another macro, for example, without retyping the original English text of FIG. 4A.


In other embodiments, skilled artisans will appreciate that other methods for executing translations exist. For example, FIG. 5 teaches artisans that a dedicated icon button “X” 125 for user selection can be added to a toolbar 130, in a well known manner (e.g., by way of the Tools>Customize option), to give text translations upon “clicking” the icon, provided the button itself is linked to the functionality of the macro. The button can also be duplicated many times over to provide ease of translation, per button, to specific languages, such as German, Spanish, French, etc. In still other embodiments (not shown), the functionality of translation can be exposed via various other user interface mechanisms, such as alternate menu commands, alternate toolbar buttons, hotkey combinations, or the like.


Turning to the code itself, the below macro (“Code Listing”) is that actually used in the prototype configuration of the OpenOffice.org (OOo) Writer in FIG. 3F to undertake the text translation in FIG. 4D (from Babel Fish—although no requirement for this particular service exists, as before). (The inventor has also copied and pasted the same macro code into both the Windows XP and SLED 10-compatible versions of OOo, and it works, unmodified, in both environments. It also works in a standard OOo installation with no modifications to classpaths, security settings, etc.) It is not, however, production quality, per se, but is sufficient to illustrate the invention and certainly proves the concept. At a higher level, the user only has to create a JavaScript macro doing the following (e.g., a more detailed version of FIG. 2):


1. Programmatically, using published OOo API methods, obtain in String form the text that the user has currently selected in the open document (e.g., step 44, FIG. 2).


2. Craft a set of parameters (including the user text String from the previous step, and a String indicating the desired target language, and such other info as maybe required by the remote host, e.g., 20, FIG. 1, the remote language translation service) to send to the remote host (e.g., step 46, FIG. 2).


3. In code, create a java.net.URL object and open a connection on it (e.g., next to last line of the Code Listing).


4. Use standard Java methods to obtain the output stream and write to it (via POST, for example) (e.g., step 48, FIG. 2).


5. Use standard Java methods to obtain the input stream and read from it.


6. Close the connection.


7. Parse the text obtained in Step 5 to strip away any unnecessary language, leaving just the raw translated text (e.g., step 50, FIG. 2).


8. Programmatically, using the OOo API, insert the translated text into the document at the current cursor location (e.g., step 52, FIG. 2).












Code Listing:

















importClass(Packages.com.sun.star.uno.UnoRuntime);



importClass(Packages.com.sun.star.text.XTextDocument);



importClass(Packages.com.sun.star.text.XText);



importClass(Packages.com.sun.star.text.XTextRange);



importClass(Packages.com.sun.star.text.XTextViewCursorSupplier);



// define a couple of globals



var oDoc = XSCRIPTCONTEXT.getDocument( );



var oController = oDoc.getCurrentController( );



// NOTE: Skip to the very bottom for the actual invocation code



// utility method, gets user-highlighted text



function getSelectedText(controller) {



 var xViewCursorSupplier =



  UnoRuntime.queryInterface(XTextViewCursorSupplier,



controller);



 xViewCursor = xViewCursorSupplier.getViewCursor( );



 var selectedText = xViewCursor.getString( );



 return selectedText;



}



// utility method, injects text into doc at cursor location



function setSelectedText(controller, replacementString) {



 var xViewCursorSupplier =



  UnoRuntime.queryInterface(XTextViewCursorSupplier,



controller);



 xViewCursor = xViewCursorSupplier.getViewCursor( );



 xViewCursor.setString( replacementString );



}



// Use raw Java calls to open an HTTP connection and do a POST



// url == the endpoint for the POST



// content == the properly munged form data



// (This routine is portable -- no babelfish dependencies)



function doJavaPOST( url, content ) {



 var input;



 try {



 var URL = new java.net.URL(url);



 var urlConn = URL.openConnection( );



 urlConn.setDoInput (true);



 urlConn.setDoOutput (true);



 urlConn.setUseCaches(false);



 urlConn.setRequestProperty (“Content-Type”,



  “application/x-www-form-urlencoded”);



 var printout = new java.io.DataOutputStream



(urlConn.getOutputStream ( ));



 printout.writeBytes (content);



 printout.flush ( );



 printout.close ( );



 input = new java.io.DataInputStream (urlConn.getInputStream ( ));



 var str = “”;



 var str2 = “”;



 while( null != ((str=input.readLine( ) )) ) { str2 += str; }



 return str2;



 }



 catch(exception) {



 java.lang.System.out.println( exception.getMessage( ) );



 return null;



 }



 finally {



 if (typeof input != “undefined”)



  input.close( );



 }



}



// craft a “form response” for Babelfish



function createBabelRequest(text, languageCodes){



 var request = “tt=urltext&trtext=”;



 request += escape(text);



 request += “&lp=”



 request += languageCodes;



 request += “&btnTrTxt=Translate&doit=done&intl=1”;



 return request;



}



// High-level function that calls the other functions



function convertSelectedText( langs, controller, babelHint, url ) {



 var text = getSelectedText(controller);



 if (text == “”)



  return −1;



 var req = createBabelRequest(text, langs);



 var replyFromWebsite = doJavaPOST( url, req );



 if (null == replyFromWebsite)



  return −1;



 try {



  var replacementString =



   postProcessText( replyFromWebsite, babelHint );



  setSelectedText(controller, replacementString);



 }



 catch(ex) {



  java.lang.System.out.println( ex.toString( ) );



  return −1;



 }



 return 0;



}



// This function is not portable, it will vary by service



function postProcessText( replyFromWebsite, locatorHint ) {



 var index = replyFromWebsite.indexOf(locatorHint);



 if (index == −1)



  throw(“No such substring”);



 var shortReply = replyFromWebsite.substring(index);



 var regex = />[{circumflex over ( )}<]+<\/div>/;



 var match = shortReply.match( regex );



 if ( null == match )



  throw( “Null match.” );



 var theString =



  match[0].substring( 1, match[0].length - “</div>”.length );



 return unescape( theString );



}



// --- INVOKE THE CODE ---



// en_fr “En français”



// en_it “In italiano”



// en_es “En español”



theHint = “Auf deutsch”;



theLangs = “en_de”;



theURL = “http://babelfish.altavista.com/babelfish/tr”;



convertSelectedText( theLangs, oController, theHint, theURL );










With reference to FIG. 6, alternate embodiments of the invention contemplate seeking translation from more than one remote language translation services and providing a “best translation” to the user. At steps 42 and 44, the document editor is provided and a user indicates a selection for translation, as before. At step 146, the document editor issues requests to multiple translation services (e.g., elements 20 and 20′ in FIG. 1) to seek and receive multiple translations of the text, step 150. According to predetermined criteria for determining a best translation of the many translations (established at step 148 ), the document editor selects a best translation of the received translations, processes it, and provides it to the user (steps 152 and 154). In this manner, users get an appropriate translation, especially in the context of other text in the document. For the criteria, numerous objective or subjective standards can be identified to judge a “best translation” of the many translations. For instance, criteria can be based on computing criteria, such as a fastest response time or translations having the fewest extraneous lines of code or text, thereby shortening the time to display the translation. Criteria can also be based on language or grammar. For instance, a best translation may be one that includes punctuation or provides a “better answer.” For the latter, consider the scenario where the phonetically-identical Spanish words “porque” and “porqué” mean “because” and “why” in English, respectively. To the extent the document editor presented the translation without an accent mark, a best translation would then require providing the “why” translation in the context of a question or the “because” translation in the context of a conjunction. Alternatively still, an adjudicated best translation might be found in those translations that give users a choice between multiple options, such as giving users a choice between translations of “why” or “because,” according to the foregoing example. Naturally, the invention is not limited to any particular criteria and skilled artisans will be able to readily contemplate examples of criteria not listed.


In FIG. 7, a variant theme of providing translations is that of converting or actually reformatting documents from a first language (source) to a second language (target). Namely, step 42 requires the providing of the document editor, as before. Step 160, however, has users prepare the selection for conversion in a first language and, at step 162, indicate their desire to convert to the second language. In this regard, menu commands, icon buttons, hotkey combinations, etc. are contemplated, as before. The document editor then issues its requests for translation to remote translation services (step 164), such as by the previous identified executable code in macro form or that available as a download or on a computer-readable media. At step 166, the translations from the services are received whereby they are processed into a language-converted document, step 168, for display to a user, step 170. As contemplated here, however, this includes making a document in a second language of the same format type as the document in the first language. For example, the translation of text from FIG. 4A to FIG. 4D resulted in a translation of all capital letters to all capital letters, e.g., the same format (all capital letters) to the same format (all capital letters).


In this manner, the format specified by the user in the first document resulted in a second document already having the specified format. In other words, not only did the user get a language translation of the text, they got a word processing document having the same format as the first. They then have no additional tasks to make the second document ready for use. To this end, the functionality of the document editor is uniquely situated.


As another example, consider that users of an open document in a document editor often specify (or as the result of preset defaults) page items, such as font, font size, line spacing, line numbering, page numbering, tab indent amount, etc. Upon conversion of language, however, often times the amount of actual text increases or decreases, such that fewer or greater pages exist between the first and second documents. With the instant invention, if a first document has five pages, and a translation causes the elimination of words such that only four pages exist in a second document, the document editor eliminates the last page from its format. In this manner, users printing the document results in a print length of four pages, not five pages, including a blank fifth page. Alternatively, translations sometimes require the arrangement of text from right-to-left to left-to-right or up-to-down, etc. Appreciating this, a preferred document editor will further include standard defaults for reformatting the actual document in an appropriate manner, such as from left-to-right to right-to-left, etc. Users then get (with a single indication of a desire to convert their document) a fully formatted new document, complete with translations, and page setup, that does not exist when users simply get language translations in the public domain.


Certain advantages of the invention over the prior art should now be readily apparent. For example, it is heretofore unknown to include language translation within document editors. Now, however, language translation can occur in an invisible manner, thereby avoiding inconveniencing the user to seek translation from external sources. As another example, users that already own and/or use a document editor now have methodology to convert it to a type having language translation services, without requiring a new purchase of the editor. In still another example, users can be provided with language translations that are selected as a best translation of many translations, according to various criteria, without any extra obligation on the user. Still other advantages provide formatting of documents along with language translation so that, upon translation occurring, the user has a ready-to-use document. Of course, these are only a few of the many advantages of the invention and skilled artisans will immediately recognize others.


Finally, one of ordinary skill in the art will recognize that additional embodiments are also possible without departing from the teachings of the present invention. This detailed description, and particularly the specific details of the exemplary embodiments disclosed herein, is given primarily for clarity of understanding, and no unnecessary limitations are to be implied, for modifications will become obvious to those skilled in the art upon reading this disclosure and may be made without departing from the spirit or scope of the invention. Relatively apparent modifications, of course, include combining the various features of one or more figures with the features of one or more of other figures.

Claims
  • 1. In a document editor on a local computing device, a method of translating language of text, comprising: configuring the document editor with executable instructions to seek translation from a language translation service remote from the computing device upon an indication of a selection of text for translation.
  • 2. The method of claim 1, wherein the configuring the document editor includes providing one or more http requests for the document editor to query the language translation service.
  • 3. The method of claim 1, further including processing translations received by the language translation service for providing a useable translation form to a user.
  • 4. The method of claim 1, wherein the configuring the document editor further includes providing an executable macro.
  • 5. In a computing environment, a method for translating language of text, comprising: providing a document editor for installation on a computing device; andconfiguring the document editor with executable instructions to seek translation from a language translation service remote from the computing device upon an indication of a selection of text for translation.
  • 6. The method of claim 5, wherein the configuring the document editor includes providing one or more http requests for the document editor to query the language translation service by way of an internet connection of the computing device.
  • 7. The method of claim 5, wherein the configuring the document editor includes providing an executable macro for the document editor.
  • 8. In a computing environment, a method for translating language of text, comprising: providing a document editor for installation on a computing device;configuring the document editor with executable instructions to seek translation from multiple language translation services remote from the computing device upon an indication of a selection of text for translation; andupon receipt of translations for the selection from the multiple language translation services, determining a best translation for presentation to a user.
  • 9. The method of claim 8, wherein the configuring the document editor includes providing one or more http requests for the document editor to query each of the multiple language translation services by way of an internet connection.
  • 10. The method of claim 8, further including establishing predetermined criteria for the best translation.
  • 11. A document editor for installation on a computing device, comprising: a first component to display a user-typing area on a monitor of the computing device;a second component for users to indicate selections of text in the user-typing area for language translation; anda third component for seeking translation of the indicated selections of text from at least one language translation service remote from the computing device without requiring users to open a browser application.
  • 12. The document editor of claim 11, wherein the third component includes executable code for making a http request of the at least one translation service by way of the internet.
  • 13. The document editor of claim 11, further including a fourth component for displaying a translation of text to the user in the user-typing area returned from the at least one language translation service.
  • 14. A document editor for installation on a computing device, comprising: a first component to display a user-typing area on a monitor of the computing device;a second component for users to indicate selections of text in the user-typing area for language translation;a third component for users to insert executable code; andupon the insertion and execution of the executable code, a fourth component functioning to seek translation of the indicated selections of text from at least one language translation service remote from the computing device.
  • 15. The document editor of claim 14, wherein the fourth component functions to seek translation of the indicated selections of text from multiple language translation services remote from the computing device and determines a best translation from the multiple language translation services.
  • 16. The document editor of claim 14, wherein the third component recognizes an executable macro that the fourth component can act on to seek the translation of the indicated selections of text.
  • 17. A method of using a document editor on local computing device, comprising: by a user, indicating a selection for language translation;by the document editor, issuing http requests of at least one language translation service remote from the computing device;by the document editor, receiving a translation of the selection from the at least one language translation service;by the document editor, processing the translation to remove other than the translation text; andby the document editor, provide the translation text to the user.
  • 18. The method of claim 17, further including: by the user, inserting executable code functioning in the document editor to seek translation of the indicated selection from the at least one language translation service remote from the computing device.
  • 19. The method of claim 18, further including: by the user, inserting an executable macro into the document editor.
  • 20. A method of using a document editor on local computing device, comprising: by a user, preparing a first document in a first language;by the user, indicating a desired conversion of the first language of the first document to a second language in a formatted second document;by the document editor, issuing http requests of at least one language translation service remote from the computing device;by the document editor, receiving a translation for the first document from the at least one language translation service; andby the document editor, and based upon the received translation, providing the second document in the second language to the user.
  • 21. The method of claim 20, by the user: inserting executable code functioning in the document editor to seek the translation for the first document.
  • 22. The method of claim 21, the inserting executable code further including inserting an executable macro into the document editor.
  • 23. A computer program product having a data structure available as a download or on a computer-readable medium, the data structure for insertion in a document editor on a computing device to translate a text selection of an open document of the document editor from a first to a second language, comprising: a first data field containing data representing an http request from the document editor to a language translation service remote from the computing device to perform the translating of the text selection to the second language.
  • 24. The computer program product of claim 23, further including a second data field containing data functioning to discard response language received from the language translation service other than a raw language translation of the text selection.
  • 25. The computer program product of claim 23, further including a second data field containing data functioning to perform language translation in the document editor as a macro in the open document of the document editor.
  • 26. The computer program product of claim 23, further including a second data field containing data functioning to cause display to a user on a monitor of the computing device of the text selection in the second language.