This invention relates generally to mobile enterprise application platforms (MEAPs), and more specifically, to cross-platform interoperability between web-based applications and hardware functions of a mobile device.
Mobile applications are becoming more prevalent as the proliferation of sophisticated mobile devices increases. Mobile devices (e.g., smart phones, cellular phones, smart TV's, portable media players, tablets, etc.) are typically implemented on their own operating systems and do not provide compatibility of application services. Embedded systems such as mobile devices can have dependencies or constraints on hardware resources unlike personal computers and/or web-based applications. This is problematic, as many companies wish to develop one solution that can operate across multiple platforms without having to write specific code for each device. Web applications (e.g., MEAPs) are one way to fill this role as they allow companies to utilize existing infrastructure including development staff, servers, training resources, and the like. MEAPs reduce the development effort by using one tool set and code base to support multiple platforms, provide pre-built interfaces and templates for small form-factor devices, and reduce the amount of transport and network layer software needed to handle mobile traffic. However, with mobile devices, the application often needs to access hardware-specific functionality, such as bar code scanners, cameras, radios, magnetic stripe readers, and the like. Web-based applications, including MEAPs, do not easily interface with this hardware-based functionality.
In general, embodiments of the invention provide an approach for increased interoperability between web-based applications and hardware functions of a mobile device. Embodiments include a thick-client hardware compatibility wrapper (HCW) to render web-based applications and manage communication between hardware functionality and the web-based application. Specifically, the HCW monitors the web-based application and identifies commands to the hardware components of the mobile device. These commands are interpreted by the HCW, which then uses native calls to perform the hardware-specific activities. The HCW is also capable of calling functions on a webpage within the web-based application in response to query commands to the web-based application or in response to hardware events.
One aspect of the present invention includes a method for increased interoperability between web-based applications and hardware functions of a mobile device, comprising the computer implemented steps of: receiving a web-based application at a hardware compatibility wrapper (HCW) of a mobile device; monitoring for a request between a hardware component of the mobile device and the web-based application; and calling an execution request to one of the hardware component and the web-based application based on the request.
Another aspect of the present invention provides a system for increased interoperability between web-based applications and hardware functions of a mobile device, comprising: a memory medium comprising instructions; a bus coupled to the memory medium; and a processor coupled to the bus that when executing the instructions causes the system to: receive a web-based application at a hardware compatibility wrapper (HCW) of a mobile device; monitor for a request between a hardware component of the mobile device and the web-based application; and call an execution request to one of the hardware component and the web-based application based on the request.
Another aspect of the present invention provides a computer-readable storage device storing computer instructions, which when executed, enables a computer system to provide interoperability between web-based applications and hardware functions of a mobile device, the computer instructions comprising: receiving a web-based application at a hardware compatibility wrapper (HCW) of a mobile device; monitoring for a request between a hardware component of the mobile device and the web-based application; and calling an execution request to one of the hardware component and the web-based application based on the request.
Another aspect of the present invention provides a computer implemented method for increased interoperability between web-based applications and hardware functions of a mobile device, comprising: providing a computer infrastructure being operable to: receive a web-based application at a hardware compatibility wrapper (HCW) of a mobile device; monitor for a request between a hardware component of the mobile device and the web-based application; and call an execution request to one of the hardware component and the web-based application based on the request.
The drawings are not necessarily to scale. The drawings are merely schematic representations, not intended to portray specific parameters of the invention. The drawings are intended to depict only typical embodiments of the invention, and therefore should not be considered as limiting the scope of the invention. In the drawings, like numbering represents like elements.
Exemplary embodiments now will be described more fully herein with reference to the accompanying drawings, in which exemplary embodiments are shown. Embodiments of the invention provide increased interoperability between web-based applications and hardware functions of a mobile device, the approach including a thick-client hardware compatibility wrapper (HCW) to render web-based applications and manage communication between hardware functionality and the web-based application. Specifically, the HCW monitors the web-based application and identifies commands to the hardware components of the mobile device. These commands are interpreted by the HCW, which then uses native API calls to perform the hardware-specific activities. The HCW is also capable of calling functions on a webpage within the web-based application in response to query commands to the web-based application or in response to hardware events from the hardware components.
This disclosure may, however, be embodied in many different forms and should not be construed as limited to the exemplary embodiments set forth herein. Rather, these exemplary embodiments are provided so that this disclosure will be thorough and complete and will fully convey the scope of this disclosure to those skilled in the art. The terminology used herein is for the purpose of describing particular embodiments only and is not intended to be limiting of this disclosure. As used herein, the singular forms “a”, “an”, and “the” are intended to include the plural forms as well, unless the context clearly indicates otherwise. Furthermore, the use of the terms “a”, “an”, etc., do not denote a limitation of quantity, but rather denote the presence of at least one of the referenced items. It will be further understood that the terms “comprises” and/or “comprising”, or “includes” and/or “including”, when used in this specification, specify the presence of stated features, regions, integers, steps, operations, elements, and/or components, but do not preclude the presence or addition of one or more other features, regions, integers, steps, operations, elements, components, and/or groups thereof.
Reference throughout this specification to “one embodiment,” “an embodiment,” “embodiments,” or similar language means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Thus appearances of the phrases “in one embodiment,” “in an embodiment,” “in embodiments” and similar language throughout this specification may, but do not necessarily, all refer to the same embodiment.
With reference now to the figures,
In the depicted example, servers 54 and a set of mobile devices 102 connect to network 115. These mobile devices may be, for example, personal computers (e.g., laptop computers and tablet computers), mobile telephones, personal digital assistants (PDAs), and the like. In the depicted example, servers 54 provide data, such as boot files, operating system images, and applications to mobile devices 102. Mobile devices 102 are clients to servers 54 in this example. Network data processing system 10 may include additional servers, clients, and other devices not shown.
In the exemplary embodiment, network data processing system 10 is the Internet with network 115 representing a worldwide collection of networks and gateways that use the Transmission Control Protocol/Internet Protocol (TCP/IP) suite of protocols to communicate with one another. At the heart of the Internet is a system of high-speed data communication lines between major nodes or host computers, consisting of thousands of commercial, governmental, educational and other computer systems that route data and messages. Of course, network data processing system 10 also may be implemented as a number of different types of networks, such as for example, an intranet, a local area network (LAN), or a wide area network (WAN). Network data processing system 10 represents one environment in which one or more web-based applications operate with mobile devices 102, as will be described in further detail below. It will be appreciated that
Turning now to
Computer system 104 is intended to represent any type of computer system that may be implemented in deploying/realizing the teachings recited herein. In this particular example, computer system 104 represents an illustrative system for providing increased interoperability between web-based applications and hardware functions of a mobile device. It should be understood that any other computers implemented under the present invention may have different components/software, but will perform similar functions. As shown, computer system 104 includes a processing unit 106 capable of operating with a hardware compatibility wrapper (HCW) 150 stored in a memory unit 108 to provide increased interoperability between hardware functions and web-based applications, as will be described in further detail below. Also shown is a bus 110, and device interfaces 112.
Processing unit 106 refers, generally, to any apparatus that performs logic operations, computational tasks, control functions, etc. A processor may include one or more subsystems, components, and/or other processors. A processor will typically include various logic components that operate using a clock signal to latch data, advance logic states, synchronize computations and logic operations, and/or provide other timing functions. During operation, processing unit 106 collects and routes data from a set of applications 120 (e.g., web-based applications) to HCW 150, as well as from device components 118. The signals can be transmitted over a LAN and/or a WAN (e.g., T1, T3, 56 kb, X.25), broadband connections (ISDN, Frame Relay, ATM), wireless links (802.11, Bluetooth, etc.), and so on. In some embodiments, the signals may be encrypted using, for example, trusted key-pair encryption. Different systems may transmit information using different communication pathways, such as Ethernet or wireless networks, direct serial or parallel connections, USB, Firewire®, Bluetooth®, or other proprietary interfaces. (Firewire is a registered trademark of Apple Computer, Inc. Bluetooth is a registered trademark of Bluetooth Special Interest Group (SIG)).
In general, processing unit 106 executes computer program code, such as program code for operating HCW 150, which is stored in memory 108 and/or storage system 116. While executing computer program code, processing unit 106 can read and/or write data to/from memory 108 and storage system 116. Storage system 116 can include VCRs, DVRs, RAID arrays, USB hard drives, optical disk recorders, flash storage devices, and/or any other data processing and storage elements for storing and/or processing data. Although not shown, computer system 104 could also include I/O interfaces that communicate with one or more hardware device components 118 of mobile device 102 that enable a user to interact with computer system 104 (e.g., a keyboard, a display, camera, etc.).
Turning now to
As further shown, HCW 150 comprises a monitoring component 154 that monitors for a request originating from hardware components 118 and web-based application 120. Based on the request, caller component 156 calls an execution request (e.g., a command or function) to either hardware component 118 or a web-based application 120 to execute the request, e.g., turn on a barcode scanner, change the device volume, or execute a function.
In one embodiment, the execution request comprises a command from web-based application 120 to hardware components 118. In this case, HCW 150 monitors activity within browser control 152 for commands and/or parameters sent by a webpage 158 (e.g., via JavaScript®) or in response to a user-initiated click, button, selection, etc. Specifically, a monitoring component 154 is configured to monitor a uniform resource locator (URL) of webpage 158 within browser control 152, and parse the URL for hash tags that are used to indicate commands to one or more hardware components 118. That is, the URL string is broken down into its component parts: scheme, host, port, path, and query string, wherein the hash tags are used to separate the commands. These commands are extracted and analyzed at HCW 150, which then uses native API calls from an API 160 to perform the hardware-specific function(s). As used herein, API 160 may refer to computer code that supports application access to operating system functionality. API 160 uses device specific libraries or native code allowing access to mobile device 102, including hardware components 118, at a low level.
The execution request may also comprise a function called on webpage 158 of browser control 152. In this embodiment, HCW 150 is capable of communicating with webpage 158 hosted in browser control 152 by calling a function (e.g., JavaScript®) on the page. Monitoring component 154 is configured to monitor for a hardware event from hardware components 118, such as a barcode scan initiated by a user via a scanner, or a GPS location change event. Monitoring component 154 also monitors for a query command to browser control 152, such as a query to webpage 158. Caller component 156 is then configured to call a function on webpage 158 of browser control 152 in response to the hardware event from hardware component 118 or the query command to webpage 158 of browser control 152.
Furthermore, HCW 150 is not limited to a uni-directional command/function request. Instead, HCW 150 is capable of intelligent handling of a series of requests configured in a request/response communication format. For instance, the browser may indicate (e.g., via a hash tag) a request for a current GPS location. HCW 150 recognizes the command request and may query a hardware GPS device for the current location. Based on this, HCW 150 may then call a JavaScript® function to browser control 152, passing the function the current GPS coordinates.
Turning to
As shown, browser control 152 enables web pages to be implemented in Hypertext Markup Language (HTML), JavaScript®, Asynchronous JavaScript® and XML (AJAX), Extended Hypertext Markup Language (XHTML), Wireless Markup Language (WML), and so on. Browser control 152 enables display of XHTML, HTML, WML, CSS, or scripted content inside an application. In an exemplary embodiment, browser control 152 operates with an action servlet 162 (e.g., a web standard Struts/Struts II for building front ends to Java® applications) to serve up more sophisticated web pages. During operation, action servlet 162 receives an HTTP request, uses the Struts configuration files to determine the appropriate application module, and routes the request to the module's request processor. Action servlet 162 is also responsible for initialization and clean-up of resources.
Browser control 152 further operates with a web services servlet 164 used by JavaScript® on the pages for real-time activities. In one embodiment, an AJAX development approach may be implemented on the client-side for asynchronous web applications. AJAX allows web pages to be updated asynchronously (i.e., behind the scenes) by exchanging small amounts of data with the server to update parts of a web page, as opposed to reloading the whole page. For example, a webpage in which a user selects Ohio in a state dropdown causes the JavaScript® to use web services servlet 164 to look up all the cities in Ohio and populate a city dropdown. In another example, a bar code scan by the scanner causes the JavaScript® to upload bar code data via web services servlet 164 rather than submitting a form each time. AJAX is based on Internet standards, and is browser and platform-independent. AJAX uses a combination of XMLHttpRequest object (e.g., to exchange data asynchronously with a server) JavaScript/DOM (e.g., to display/interact with the information) CSS (e.g., to style the data) and XML (e.g., as the format for transferring data). It will be appreciated that the use of AJAX in this embodiment is intended as exemplary, and not as a limitation for different embodiments.
Furthermore, during use, HCW 150 monitors browser control 152 and accepts commands to manage mobile device hardware components 118 of mobile phone 102. As discussed above, with mobile device 102, the web-based application may need to access hardware specific functionality, such as bar code scanners, GPS devices, keyboards, cameras, radios, magnetic stripe readers, native volume components, and the like. HCW 150 monitors the browser and accepts commands to mange hardware components 118, e.g., by natively turning up the volume, beeping, turning on a barcode scanner, etc. HCW 150 is also capable of calling functions on a web-based application in response to query commands to the web-based application or in response to hardware events via hardware components 118.
As implemented, embodiments of the invention provide increased interoperability between web-based applications and mobile hardware components of a mobile device by offering solutions that can be modified on the server without having to re-deploy the application to the mobile device. Once the HCW has been installed on a device, no further local installation is necessary. Therefore, when a new device becomes available, a new version of the HCW can be produced for that device, allowing the existing enterprise application to run on the new device without modification. Additionally, the invention allows organizations having significant infrastructure in place for the design, development, and management of Web 2.0 applications to extend their reach to mobile platforms without a considerable amount of custom mobile application development by allowing the web solution to run on any device for which an HCW has been designed.
It can be appreciated that the approaches disclosed herein can be used within a computer system to provide interoperability between hardware functions and web-based applications, as shown in
The exemplary computer system 104 may be described in the general context of computer-executable instructions, such as program modules, being executed by a computer. Generally, program modules include routines, programs, people, components, logic, data structures, and so on that perform particular tasks or implements particular abstract data types. Exemplary computer system 104 may be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
Computer system 104 carries out the methodologies disclosed herein, as shown in
Turning now to
The flowcharts of
Many of the functional units described in this specification have been labeled as modules in order to more particularly emphasize their implementation independence. For example, a module may be implemented as a hardware circuit comprising custom VLSI circuits or gate arrays, off-the-shelf semiconductors such as logic chips, transistors, or other discrete components. A module may also be implemented in programmable hardware devices such as field programmable gate arrays, programmable array logic, programmable logic devices or the like. Modules may also be implemented in software for execution by various types of processors. An identified module or component of executable code may, for instance, comprise one or more physical or logical blocks of computer instructions which may, for instance, be organized as an object, procedure, or function. Nevertheless, the executables of an identified module need not be physically located together, but may comprise disparate instructions stored in different locations which, when joined logically together, comprise the module and achieve the stated purpose for the module.
Further, a module of executable code could be a single instruction, or many instructions, and may even be distributed over several different code segments, among different programs, and across several memory devices. Similarly, operational data may be identified and illustrated herein within modules, and may be embodied in any suitable form and organized within any suitable type of data structure. The operational data may be collected as a single data set, or may be distributed over different locations including over different storage devices, over disparate memory devices, and may exist, at least partially, merely as electronic signals on a system or network.
Furthermore, as will be described herein, modules may also be implemented as a combination of software and one or more hardware devices. For instance, a module may be embodied in the combination of a software executable code stored on a memory device. In a further example, a module may be the combination of a processor that operates on a set of operational data. Still further, a module may be implemented in the combination of an electronic signal communicated via transmission circuitry.
As noted above, some of the embodiments may be embodied in hardware. The hardware may be referenced as a hardware element. In general, a hardware element may refer to any hardware structures arranged to perform certain operations. In one embodiment, for example, the hardware elements may include any analog or digital electrical or electronic elements fabricated on a substrate. The fabrication may be performed using silicon-based integrated circuit (IC) techniques, such as complementary metal oxide semiconductor (CMOS), bipolar, and bipolar CMOS (BiCMOS) techniques, for example. Examples of hardware elements may include processors, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. The embodiments are not limited in this context.
Also noted above, some embodiments may be embodied in software. The software may be referenced as a software element. In general, a software element may refer to any software structures arranged to perform certain operations. In one embodiment, for example, the software elements may include program instructions and/or data adapted for execution by a hardware element, such as a processor. Program instructions may include an organized list of commands comprising words, values or symbols arranged in a predetermined syntax, that when executed, may cause a processor to perform a corresponding set of operations.
For example, an implementation of exemplary computer system 104 (
“Computer-readable storage device” includes volatile and non-volatile, removable and non-removable computer storable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules, or other data. Computer storage device includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computer.
“Communication media” typically embodies computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as carrier wave or other transport mechanism. Communication media also includes any information delivery media.
The term “modulated data signal” means a signal that has one or more of its characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media includes wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, RF, infrared, and other wireless media. Combinations of any of the above are also included within the scope of computer readable media.
It is apparent that there has been provided an approach for providing interoperability between hardware functions and web-based applications. While the invention has been particularly shown and described in conjunction with a preferred embodiment thereof, it will be appreciated that variations and modifications will occur to those skilled in the art. Therefore, it is to be understood that the appended claims are intended to cover all such modifications and changes that fall within the true spirit of the invention.
The present patent document is a continuation of U.S. patent application Ser. No. 14/729,349, filed Jun. 3, 2015, which is a continuation of U.S. patent application Ser. No. 13/396,128, filed Feb. 14, 2012, now U.S. Pat. No. 9,092,540, issued Jul. 28, 2015. The entire contents of each of such applications are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6791579 | Markel | Sep 2004 | B2 |
6816880 | Strandberg | Nov 2004 | B1 |
6941344 | Prell | Sep 2005 | B2 |
7111056 | Ramey et al. | Sep 2006 | B1 |
7424704 | Orton et al. | Sep 2008 | B2 |
7472375 | Ye et al. | Dec 2008 | B2 |
7725605 | Palmeri | May 2010 | B2 |
7814234 | Hawkins et al. | Oct 2010 | B2 |
7870188 | Mazzitelli et al. | Jan 2011 | B2 |
8265918 | Neema et al. | Sep 2012 | B1 |
8370428 | Bayliss et al. | Feb 2013 | B1 |
8572178 | Frazzini et al. | Oct 2013 | B1 |
8875159 | Nieuwejaar et al. | Oct 2014 | B1 |
9092540 | Hansknecht | Jul 2015 | B2 |
9329879 | Shah et al. | May 2016 | B2 |
20040003033 | Kamen et al. | Jan 2004 | A1 |
20040024787 | Edwards et al. | Feb 2004 | A1 |
20040073443 | Gabrick et al. | Apr 2004 | A1 |
20040122908 | Konopka | Jun 2004 | A1 |
20040128651 | Lau | Jul 2004 | A1 |
20040226027 | Winter | Nov 2004 | A1 |
20050008003 | Ramey et al. | Jan 2005 | A1 |
20050015781 | Brown et al. | Jan 2005 | A1 |
20050220286 | Valdez et al. | Oct 2005 | A1 |
20050228693 | Webb et al. | Oct 2005 | A1 |
20060173951 | Arteaga et al. | Aug 2006 | A1 |
20070006184 | Andrews et al. | Jan 2007 | A1 |
20070039010 | Gadre | Feb 2007 | A1 |
20080040426 | Synstelien et al. | Feb 2008 | A1 |
20080040490 | Karlberg | Feb 2008 | A1 |
20080104195 | Hawkins et al. | May 2008 | A1 |
20080122675 | Bilodeau et al. | May 2008 | A1 |
20080184248 | Barua et al. | Jul 2008 | A1 |
20080235708 | Lopez | Sep 2008 | A1 |
20090055836 | Supalov | Feb 2009 | A1 |
20090063502 | Coimbatore | Mar 2009 | A1 |
20090064301 | Sachdeva | Mar 2009 | A1 |
20090172657 | Makelainen et al. | Jul 2009 | A1 |
20090249300 | Vainer et al. | Oct 2009 | A1 |
20090259934 | Prisament | Oct 2009 | A1 |
20090319529 | Bartlett et al. | Dec 2009 | A1 |
20100013842 | Green et al. | Jan 2010 | A1 |
20100088404 | Mani et al. | Apr 2010 | A1 |
20100155471 | Heinz et al. | Jun 2010 | A1 |
20100192124 | Hall | Jul 2010 | A1 |
20100312821 | Bannoura | Dec 2010 | A1 |
20100332994 | Istvan | Dec 2010 | A1 |
20110022552 | Zimmerman et al. | Jan 2011 | A1 |
20110111743 | Boukai et al. | May 2011 | A1 |
20110153796 | Branson | Jun 2011 | A1 |
20110252117 | Sng et al. | Oct 2011 | A1 |
20110302571 | O'Farrell et al. | Dec 2011 | A1 |
20110320715 | Ickman | Dec 2011 | A1 |
20110321139 | Jayaraman et al. | Dec 2011 | A1 |
20120066487 | Brown et al. | Mar 2012 | A1 |
20120179587 | Hill et al. | Jul 2012 | A1 |
20120188584 | Sng et al. | Jul 2012 | A1 |
20120203592 | Ravindran | Aug 2012 | A1 |
20120278082 | Borodin et al. | Nov 2012 | A1 |
20120317238 | Beard | Dec 2012 | A1 |
20130007575 | Bacus et al. | Jan 2013 | A1 |
20130031462 | Calvo et al. | Jan 2013 | A1 |
20130054533 | Hao | Feb 2013 | A1 |
20130073738 | Reisman | Mar 2013 | A1 |
20130103380 | Brandstatter | Apr 2013 | A1 |
20130138810 | Binyamin et al. | May 2013 | A1 |
20130212146 | Hansknecht | Aug 2013 | A1 |
20130227354 | Shah | Aug 2013 | A1 |
20130275957 | Villar et al. | Oct 2013 | A1 |
20130298007 | Cullen et al. | Nov 2013 | A1 |
20140019638 | Kurabayashi et al. | Jan 2014 | A1 |
20140082117 | Unhale et al. | Mar 2014 | A1 |
20140095589 | Johnson | Apr 2014 | A1 |
20140096081 | Carpenter et al. | Apr 2014 | A1 |
20140304583 | Fabbri | Oct 2014 | A1 |
20150118992 | Wyatt et al. | Apr 2015 | A1 |
20150271269 | Hansknecht | Sep 2015 | A1 |
Number | Date | Country |
---|---|---|
1349061 | Oct 2003 | EP |
2270658 | Jan 2011 | EP |
2008054951 | May 2008 | WO |
Entry |
---|
Biggs et al., “Native robot software framework inter-operation”, 2010, pp. 180-191. |
Microsoft Computer Dictionary, “wrapper”, 5 edition, 2002. |
Lee, K. H. et al., “An Implementation of Mobile Desktop Manager for Mobile Web Devices”, Chungnam National University, Korea, Feb. 13-16, 2011, pp. 284-287. |
Microsoft Computer Dictionary, Fifth Edition, “wrapper”, 2002, p. 575. |
Ioannidis et al., “Building a Secure Web Browser”, 2001, 8 pages. |
Sharma et al., “Automated Evaluation of Search Engine Performance via Implicit User Feedback”, SIGIR '05, Aug. 15-19, 2005, Salvador, Brazil, pp. 649-650. |
Lehtonen et al., “Towards User-Friendly Mobile Browsing”, AAA—Ideal 06, Oct. 10, 2006, Pisa, Italy, 7 pages. |
Filho et al., “UML: Unified Modeling Language”, 2008, pp. 1183-1212. |
Binun et al., “Policy and State based Secure Wrapper and its application to Mobile agents”, Proceedings of the First Latin American Web Congress (LA-WEB 2003), Copyright 2003, 13 pages. |
Ondrej C. Vostal, USPTO Office Action, U.S. Appl. No. 13/396,128, dated May 22, 2014, 23 pages. |
Ondrej C. Vostal, USPTO Office Action, U.S. Appl. No. 13/396,128, dated Sep. 5, 2014, 16 pages. |
Ondrej C. Vostal, USPTO Final Office Action, U.S. Appl. No. 13/396,128, dated Dec. 24, 2014, 30 pages. |
Ondrej C. Vostal, USPTO Notice of Allowance and Fee(s) Due, U.S. Appl. No. 13/396,128, dated Mar. 20, 2015, 12 pages. |
Ondrej C. Vostal, USPTO Office Action, U.S. Appl. No. 14/729,349, dated Aug. 23, 2016, 22 pages. |
Ondrej C. Vostal, USPTO Notice of Allowance and Fee(s) Due, U.S. Appl. No. 14/729,349, dated Mar. 20, 2017, 21 pages. |
Geoffrey Biggs et al., “Native Robot Software Framework Inter-operation”, SIMPAR 2010, pp. 180-191. |
Preetham Chandrian, “Efficient Java Native Interface for Android based Mobile Devices”, 2011, 70 pages. |
S. Martignoni et al., “Call Control in the Mobile Terminal of a Wireless ATM Network”, Copyright IEEE 1998, pp. 135-141. |
Manuel Palmieri et al., “Comparison of Cross-Platform Mobile Development Tools”, Copyright IEEE 2012, pp. 179-186. |
Adam Barth et al., “Attacks on JavaScript Mashup Communication”, 2009, 8 pages. |
Judith Bishop et al., “Experience in integrating Java with C# and .NET”, Copyright 2005 John Wiley & Sons, Ltd., 18 pages. |
Crenna, “Professional Twitter Development: With Examples in .NET 3.5”, 2009, 6 pages. |
Crowley et al., “Chapter 3 Enriching Web Applications with AJAX and JSON”, 2010, pp. 55-99. |
Jeffrey D. Stewart, “An XML-based knowledge management system of port information for U.S. Coast Guard Cutters”, 2003, 124 pages. |
McIntyre et al., “Pro PHP Programming”, 2011, 432 pages. |
Dominic Lovell, “Collaborative Coding in the Cloud”, 2009, 130 pages. |
Number | Date | Country | |
---|---|---|---|
20170257438 A1 | Sep 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14729349 | Jun 2015 | US |
Child | 15602338 | US | |
Parent | 13396128 | Feb 2012 | US |
Child | 14729349 | US |