The present disclosure relates to digital maps and, more particularly, to an application programming interface (API) for prefetching map data on a computing device.
The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
Today, various computing devices, including many portable devices, support software applications that display interactive digital maps. Some of these software applications, such as mapping and navigation applications, are developed primarily for displaying interactive digital maps. Other software applications, such as web browsers, may display interactive digital maps along with other content.
To display an interactive digital map, a software application usually requests map data from a map data provider for a particular geographic area. A software application executing on a portable device (such as a smart phone) typically requests map data from the map data provider via a wireless communication network in which the portable device operates. As a result, the software application can only receive map data when the portable device has wireless network coverage that supports a data connection. When the portable device cannot establish a data connection, or when the portable device leaves the area of network coverage altogether, the software application often cannot display a map of the area in which the portable device is located, for example.
One embodiment of the techniques discussed below is a computer-readable medium storing instructions that implement an API for prefetching map data. The map data is prefetched on a computing device having a processor and a display device and configured to communicate with a map data provider via a communication network. When invoked in a software application executed on the processor, the API is configured to receive a prefetch request for an indicated geographic area from the software application. In response to the prefetch request, the API is configured to retrieve map data corresponding to the indicated geographic area from the map data provider and store the map data in a map data cache without causing a map image based on the map data to be displayed on the display device, where the map data cache is accessible to the software application only via the API. The API is further configured to, subsequently to storing the map data in the map data cache, receive a request to render the map image from the software application and, in response to the request to render the map image, render the map image using the map data stored in the map data cache, where the map image is displayed on the display device.
Another embodiment of these techniques is a method for prefetching map data in computing device including a memory, a processor, and a display device. The method includes allocating a portion of the memory for use as a map data cache that stores map data received from a map data provider via a communication network, and preventing software applications being executed by the processor from accessing the map data cache. The method further includes providing an API for use by the software applications. In response to the API being invoked for prefetching map data, the method includes retrieving map data for an indicated geographic area and storing the map data in the map data cache, where a map image based on the map data is not displayed on the display device in response to the API being invoked for prefetching the map data. In response to the API subsequently being invoked for displaying the prefetched map data, the method includes retrieving the map data from the map data cache and generating a map image using the map data for display on the display device.
According to yet another embodiment, a mobile device is configured to communicate via a wireless communication link and includes a processor, a display device, a network interface communicatively coupled to the wireless communication link, a memory communicatively coupled to the processor, a map data cache disposed in the memory, and instructions stored in the memory that implement an API for prefetching map data. The map data cache is not accessible to software applications executing on the mobile device via read or write operations. The API, when invoked by a software application executing on the mobile device, is configured to, in response to receiving a prefetch request indicating a geographic area from a software application executing on the mobile device, retrieve map data for the indicated geographic area via the network interface and store the map data in the map data cache, where a map image based on the map data is not displayed on the display device in response to receiving the prefetch request. In response to subsequently receiving a request to render the map image from the software application, the API is configured to cause the map image to be displayed on the display device using the map data stored in the map data cache.
An Application Programming Interface (API) allows software applications to prefetch map data for a geographic area in advance of a user request or an automated decision to display a digital map image (for simplicity, a “digital map”) of the geographic area. According to an example implementation, a software application invokes the API to specify a polyline or a point, and the API retrieves map data for a geographic area within a certain radius of the polyline or point from a map data provider. The API stores the received map data in a map data cache over which the API has exclusive control, so that a software application that invokes the API cannot access the map data cache directly. In other words, the software application can access the map data cache only via calls to the API. Further, the API may control the level of detail of the prefetched map data. At a later time, the software application invokes the API to display a digital map of the geographic area, and the API renders the digital map using the stored map data without requesting the map data from the map data provider.
When the portable device 12 operates in the wireless communication network 16, the software application 20 requests and receives map data from the map data provider 14 on demand. For example, the software application 20 may be a mapping application, and a user may request a digital map for a specified location (e.g., “San Francisco, Calif.”). The software application 20 generates and transmits a request for map data corresponding to the specified location upon receiving the user request. The map data server 14 in response provides the requested map data, and the software application 20 renders and displays a digital map for the specified location. As another example, the software application 20 may be a navigation application configured to display a digital map for the current location of the portable device 12. When the portable device 12 enters a location for which map data is not yet available, the software application 20 automatically generates a request for map data corresponding to this new location.
However, the software application 20 (or, in some cases, the user) may determine that the portable device 12 will soon leave the area of coverage of the wireless communication network 16, or that the portable device 12 will roam to a wireless network that offers a significantly slower or a significantly more expensive data connection. If the software application 20 or the user can anticipate for which locations map data will be needed, the software application 20 can invoke the API 22 to prefetch map data for some of all of these anticipated locations. In some embodiments, the software application 20 is configured to automatically prefetch map data only if the user explicitly configures the software application 20 to do so, particularly if the software application 20 uses the user's profile to determine which map data should be prefetched. In other embodiments, the software application 20 automatically prefetches map data without the user's explicit configuration, but in any case with user's consent and in accordance with relevant privacy policies.
Generally speaking, the software application 20 may respond to various events or “signals” to determine that map data should be prefetched, and identify the geographic area for which map data should be prefetched. For example, the user may search for driving directions, and the software application 20 may anticipate loss of network coverage along the route from a source location to the destination. If the user configured her user profile so as to allow the software application 20 to prefetch based on driving directions, the software application 20 invokes the API 22 to prefetch map data along the entire route or parts of the route. As another example, the user may configure his user profile so as to cause the software application 20 to unconditionally prefetch map data along a route, regardless of whether the portable device 12 is expected to have network coverage.
With continued reference to
The portable device 12 can be a laptop or tablet computer, a smart phone, a car navigation system, a hand-held global positioning system (GPS) unit, or any other suitable device. An example embodiment of a portable device that can operate in the communication system 10 is discussed next with reference to
An example portable device 50 illustrated in
The instruction memory 52 stores sets of instructions of an operating system (OS) 70, an API for prefetching and rendering map data 72, and a software application 74. The OS 70 may be a mobile OS developed specifically for portable devices. As such, the OS 70 may include functions that allow the software application to access such data as wireless network parameters (e.g., identity of the wireless network, quality of service), as well as invoke such services as telephony, location determination (e.g., via global positioning service (GPS) or WLAN), wireless network data call origination, etc. In another implementation, the OS 70 is a general-purpose operating system that operates on both mobile and stationary devices, such as smartphones and desktop computers, for example.
Similar to the API 22 discussed above, the API for prefeteching and rendering map data 72 allows software applications to prefetch map data along a polyline, a point, an arc, etc., or within a shape that encloses a geographic area such as a polygon, a circle, a rectangle, etc., or according to another suitable principle. The API 72 in one scenario receives a specification of a polyline as a set of points interconnected by straight line segments. For example, the software application 74 may generate or receive driving directions in the form of endpoints and intermediate points (e.g., Source=starting address at 1010 Fifth, P1=Fifth at Main, P2=Main and Third, etc.) and provide these endpoints to the API 72 as a parameter to prefetch map data along the corresponding polyline. In another scenario, the software application 74 specifies only the endpoints (e.g., Source=1010 Fifth, Destination=2020 Third), and the API 72 automatically requests map data along the polyline that forms the route between the points S and E from the map data provider.
The API 72 in one embodiment is provided as a part of a “larger” API for retrieving map data. For example, the API 72 may be a component of an API for obtaining map data, business data, driving directions, etc. from a map data provider. The API 72 also may share some of the interface exposed to software applications with the larger API. In particular, the larger API may include a function which the software application 74 invokes to retrieve map data on demand, such that an additional parameter supplied to the function indicates that the software application 74 invokes the API 72 to prefetch map data in advance of an event that triggers the display of the map data. Thus, the API 72 in general can support fetching as well as prefetching of map data, and the software application 74 can select between fetching and prefetching via special parameters, different function calls, or in any other suitable manner.
The API 72 can be implemented as one or several functions, a data structure, a messaging scheme, etc. Further, the API 72 may include compiled code that executes directly on the processor 54 or, alternatively, instructions in a any other form such as a scripting language interpreted at runtime by the application 74. The API 72 in one example includes well-documented prototypes of several functions which a developer can include in the code of the software application 74, as well as instructions that implement these functions. If desired, the implementation instructions can be provided in a binary format unreadable by the developer.
In some cases, the API 72 is provided as a part of the OS 70. In one such implementation, the software application 74 is “native” to the OS 70, i.e., the software application 74 is developed to execute specifically on the OS 70 using the function library supported by the OS 70, including using the functions that are unique to the OS 70. The API 72 alternatively can be developed as a separate module compatible with the OS 70. Also, the software application 74 in other implementations can operate on a variety of platforms, and can operate on the OS 70 using the corresponding porting instructions.
The software application 74 can be, for example, a mapping application, a navigation application, a shopping guide application, etc. Further, the software application 74 can be a web browser application that invokes the API 72 to display map within an allocated portion of a browser window. In general, the API 72 can be made available to any suitable software application that executes on the portable device 50. Also, multiple different software applications may invoke the API 72.
Referring still to
The OS 70 and/or the API 72 may allocate a portion of the memory 60 for use as the map data cache 80 when the API 72 is initialized or when the portable device 50 powers up, for example. In at least some of the implementations, the software application 74 cannot directly access the map data cache 80. Thus, even though the software application 74 in general can invoke standard functions for writing and reading data to and from the memory 60, the map data cache 80 is inaccessible to the software application 74 other than via the API 72. To this end, the OS 70 may control access to the map data cache 80 at the level of read and write operations, so that the software application 74 cannot inadvertently or purposefully refer to memory locations within the map data cache 80. In another implementation, the API 72 allocates memory for map data cache 80 without exposing the location of the map data cache 80 to the software application 74 but also without any additional protection from the OS 70. In yet another implementation, the map data cache 80 stores map data in an encoded format which the software application 74 cannot interpret.
The map data cache 80 need not be limited to prefetched map data and, according to some implementations, stores all map data received from a map data provider. The API 72 may be configured to both save map data to the map data cache and remove map data from the map data cache when necessary. For example, the API 72 may be configured to remove those portions of the map data that are no longer current. As another example, the API 72 may remove the oldest map data once the entire map data cache 80 is occupied.
The map data in the map data cache 80 can correspond to various types of geographic data including topographical data, street data, urban transit information, and traffic data. The geographic data in turn may be schematic or based on photography, such as satellite imagery. Further, the map data can be for rendering a digital map in two-dimensional (2D) or three-dimensional (3D) format.
The map data can conform to any suitable format including a raster format and a vector graphics format, for example. Generally speaking, an image in a raster format specifies which colors are applied to various pixels that make up an image, whereas a graphic in a vector graphics format includes mathematical descriptions of points and various shapes (e.g., a line can be specified using a vector graphics format as two endpoints and an indication of thickness and color). In the scenarios in which the map data cache 80 stores map data in a raster format, the map data may be organized into regular sized component images, or “tiles” corresponding to a certain zoom level. For example, at a particular zoom level, a map tile can be a square 128 pixels wide that in the physical world corresponds to a square geographic area that is two hundred meters wide. In another scenario in which the map data cache 80 stores map data in a vector graphics format, the shapes that make up a digital map are organized according to square map tiles for convenience. In yet another scenario, the shapes stored in the map data cache 80 are not organized into tiles at all.
In some implementations, in addition to data used to render a digital map, the map data in the map data cache 80 includes other information associated with geographic coordinates. For example, the API 72 can retrieve business data such as names, hours of operation, customer reviews, etc. for businesses located within a radius of a polyline, a point, within an enclosed polygon, etc.
To better illustrate which map data that can be stored in the map data cache 80, several example approaches are discussed next with reference to
Referring first to
In another scenario illustrated in
As one alternative to the approaches illustrated in
Referring to
With reference to
Now referring to
At block 302, a portion of a memory is allocated to serve as a map data cache. Next, at block 304, access to the map data cache is restricted so as to prevent software applications, such as the software applications 20 and 74, from accessing the map data cache directly. At block 306, the method 300 includes providing an API for prefetching and rendering map data, to be stored in the map data cache. In an embodiment, the API has read and write permissions for the map data cache allocated at block 302. More generally, the API can operate the map data cache in accordance with the techniques discussed above with reference to
Map data then is retrieved from a map data provider at block 354 and stored in the map data cache at block 356. Next, at block 358, a request is received to render a digital map depicting the entire geographic area for which map data was prefetched at block 354. The request at block 358 sometimes may specify only a portion of the geographic area. For example, if map data is retrieved along a polyline (e.g., a driving route from a source city to a destination city), the request at block 358 may indicate a point proximate to the polyline (e.g., a town on this route). At block 360, a digital map is rendered using the map stored in the map data cache without requesting the map data from a map data provider.
Additional Considerations
The following additional considerations apply to the foregoing discussion. Throughout this specification, plural instances may implement components, operations, or structures described as a single instance. Although individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and nothing requires that the operations be performed in the order illustrated. Structures and functionality presented as separate components in example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter of the present disclosure.
Additionally, certain embodiments are described herein as including logic or a number of components, modules, or mechanisms. Modules may constitute either software modules (e.g., code stored on a machine-readable medium) or hardware modules. A hardware module is tangible unit capable of performing certain operations and may be configured or arranged in a certain manner. In example embodiments, one or more computer systems (e.g., a standalone, client or server computer system) or one or more hardware modules of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) as a hardware module that operates to perform certain operations as described herein.
In various embodiments, a hardware module may be implemented mechanically or electronically. For example, a hardware module may comprise dedicated circuitry or logic that is permanently configured (e.g., as a special-purpose processor, such as a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC)) to perform certain operations. A hardware module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software to perform certain operations. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
Accordingly, the term hardware should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. Considering embodiments in which hardware modules are temporarily configured (e.g., programmed), each of the hardware modules need not be configured or instantiated at any one instance in time. For example, where the hardware modules comprise a general-purpose processor configured using software, the general-purpose processor may be configured as respective different hardware modules at different times. Software may accordingly configure a processor, for example, to constitute a particular hardware module at one instance of time and to constitute a different hardware module at a different instance of time.
Hardware and software modules can provide information to, and receive information from, other hardware and/or software modules. Accordingly, the described hardware modules may be regarded as being communicatively coupled. Where multiple of such hardware or software modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the hardware or software modules. In embodiments in which multiple hardware modules or software are configured or instantiated at different times, communications between such hardware or software modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple hardware or software modules have access. For example, one hardware or software module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further hardware or software module may then, at a later time, access the memory device to retrieve and process the stored output. Hardware and software modules may also initiate communications with input or output devices, and can operate on a resource (e.g., a collection of information).
The various operations of example methods described herein may be performed, at least partially, by one or more processors that are temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions. The modules referred to herein may, in some example embodiments, comprise processor-implemented modules.
Similarly, the methods or routines described herein may be at least partially processor-implemented. For example, at least some of the operations of a method may be performed by one or processors or processor-implemented hardware modules. The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the processor or processors may be located in a single location (e.g., within a home environment, an office environment or as a server farm), while in other embodiments the processors may be distributed across a number of locations.
The one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as an SaaS. For example, as indicated above, at least some of the operations may be performed by a group of computers (as examples of machines including processors), these operations being accessible via a network (e.g., the Internet) and via one or more appropriate interfaces (e.g., APIs).
The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the one or more processors or processor-implemented modules may be located in a single geographic location (e.g., within a home environment, an office environment, or a server farm). In other example embodiments, the one or more processors or processor-implemented modules may be distributed across a number of geographic locations.
Some portions of this specification are presented in terms of algorithms or symbolic representations of operations on data stored as bits or binary digital signals within a machine memory (e.g., a computer memory). These algorithms or symbolic representations are examples of techniques used by those of ordinary skill in the data processing arts to convey the substance of their work to others skilled in the art. As used herein, an “algorithm” or a “routine” is a self-consistent sequence of operations or similar processing leading to a desired result. In this context, algorithms, routines and operations involve physical manipulation of physical quantities. Typically, but not necessarily, such quantities may take the form of electrical, magnetic, or optical signals capable of being stored, accessed, transferred, combined, compared, or otherwise manipulated by a machine. It is convenient at times, principally for reasons of common usage, to refer to such signals using words such as “data,” “content,” “bits,” “values,” “elements,” “symbols,” “characters,” “terms,” “numbers,” “numerals,” or the like. These words, however, are merely convenient labels and are to be associated with appropriate physical quantities.
Unless specifically stated otherwise, discussions herein using words such as “processing,” “computing,” “calculating,” “determining,” “presenting,” “displaying,” or the like may refer to actions or processes of a machine (e.g., a computer) that manipulates or transforms data represented as physical (e.g., electronic, magnetic, or optical) quantities within one or more memories (e.g., volatile memory, non-volatile memory, or a combination thereof), registers, or other machine components that receive, store, transmit, or display information.
As used herein any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. For example, some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other. The embodiments are not limited in this context.
As used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments herein. This is done merely for convenience and to give a general sense of the description. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise.
Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs for providing an API for prefetching and rendering map data through the disclosed principles herein. Thus, while particular embodiments and applications have been illustrated and described, it is to be understood that the disclosed embodiments are not limited to the precise construction and components disclosed herein. Various modifications, changes and variations, which will be apparent to those skilled in the art, may be made in the arrangement, operation and details of the method and apparatus disclosed herein without departing from the spirit and scope defined in the appended claims.
This application claims priority to U.S. Provisional Patent Application No. 61/678,065, filed on Jul. 31, 2012, and entitled “Application Programming Interface for Prefetching Map Data,” the entire disclosure of which is hereby expressly incorporated by reference herein.
| Number | Name | Date | Kind |
|---|---|---|---|
| 4984279 | Kidney et al. | Jan 1991 | A |
| 5345086 | Bertram | Sep 1994 | A |
| 5793310 | Watanabe et al. | Aug 1998 | A |
| 6094685 | Greenberg et al. | Jul 2000 | A |
| 6199150 | Yoshikawa | Mar 2001 | B1 |
| 6330453 | Suzuki et al. | Dec 2001 | B1 |
| 6400690 | Liu et al. | Jun 2002 | B1 |
| 6442757 | Hancock et al. | Aug 2002 | B1 |
| 6453233 | Kato | Sep 2002 | B1 |
| 6571279 | Herz et al. | May 2003 | B1 |
| 6853911 | Sakarya | Feb 2005 | B1 |
| 7006820 | Parker et al. | Feb 2006 | B1 |
| 7136748 | Umezu et al. | Nov 2006 | B2 |
| 7263368 | Knauerhase et al. | Aug 2007 | B2 |
| 7315259 | Sacks | Jan 2008 | B2 |
| 7327349 | Robbins et al. | Feb 2008 | B2 |
| 7464109 | Modi | Dec 2008 | B2 |
| 7502780 | Thorpe | Mar 2009 | B2 |
| 7502876 | Nemirovsky et al. | Mar 2009 | B1 |
| 7551182 | Bethune et al. | Jun 2009 | B2 |
| 7571422 | Adel et al. | Aug 2009 | B2 |
| 7577520 | Nomura | Aug 2009 | B2 |
| 7584434 | Okamura | Sep 2009 | B2 |
| 7610147 | Umezu et al. | Oct 2009 | B2 |
| 7663671 | Gallagher et al. | Feb 2010 | B2 |
| 7710421 | Muramatsu | May 2010 | B2 |
| 7711473 | Sekine et al. | May 2010 | B2 |
| 7734412 | Shi et al. | Jun 2010 | B2 |
| 7739037 | Sumizawa et al. | Jun 2010 | B2 |
| 7796837 | Lueck | Sep 2010 | B2 |
| 7831383 | Oohashi | Nov 2010 | B2 |
| 7831387 | Golding et al. | Nov 2010 | B2 |
| 7839421 | Bethune et al. | Nov 2010 | B2 |
| 7873465 | Geelen et al. | Jan 2011 | B2 |
| 7920968 | Chapin et al. | Apr 2011 | B2 |
| 7925624 | Vosshall et al. | Apr 2011 | B2 |
| 7925982 | Parker et al. | Apr 2011 | B2 |
| 7962565 | Coker | Jun 2011 | B2 |
| 7974959 | Sawai et al. | Jul 2011 | B2 |
| 7975025 | Szabo et al. | Jul 2011 | B1 |
| 7983659 | Shinya | Jul 2011 | B2 |
| 7996445 | Fair et al. | Aug 2011 | B2 |
| 8005612 | Asahara et al. | Aug 2011 | B2 |
| 8010407 | Santoro et al. | Aug 2011 | B1 |
| 8014796 | Boudreau et al. | Sep 2011 | B2 |
| 8032297 | Jakobson | Oct 2011 | B2 |
| 8060389 | Johnson | Nov 2011 | B2 |
| 8078641 | Mao et al. | Dec 2011 | B2 |
| 8095307 | Ebert et al. | Jan 2012 | B2 |
| 8204966 | Mendis et al. | Jun 2012 | B1 |
| 8280414 | Nourse et al. | Oct 2012 | B1 |
| 20020133491 | Sim et al. | Sep 2002 | A1 |
| 20030187984 | Banavar et al. | Oct 2003 | A1 |
| 20040203998 | Knauerhase et al. | Oct 2004 | A1 |
| 20040220730 | Chen et al. | Nov 2004 | A1 |
| 20060026170 | Kreitler et al. | Feb 2006 | A1 |
| 20060067224 | Ohara | Mar 2006 | A1 |
| 20060069749 | Herz et al. | Mar 2006 | A1 |
| 20060080032 | Cooper et al. | Apr 2006 | A1 |
| 20060195256 | Nakamura et al. | Aug 2006 | A1 |
| 20060277271 | Morse et al. | Dec 2006 | A1 |
| 20070050128 | Lee et al. | Mar 2007 | A1 |
| 20070080830 | Sacks | Apr 2007 | A1 |
| 20070143014 | Sekine et al. | Jun 2007 | A1 |
| 20070242077 | Danan | Oct 2007 | A1 |
| 20070273558 | Smith et al. | Nov 2007 | A1 |
| 20070282915 | Vosshall et al. | Dec 2007 | A1 |
| 20080071988 | Schloter et al. | Mar 2008 | A1 |
| 20080082225 | Barrett | Apr 2008 | A1 |
| 20080102857 | Kim | May 2008 | A1 |
| 20080132249 | Hamilton | Jun 2008 | A1 |
| 20080177469 | Geelen et al. | Jul 2008 | A1 |
| 20080238723 | Fein et al. | Oct 2008 | A1 |
| 20080270579 | Herz et al. | Oct 2008 | A1 |
| 20080291205 | Rasmussen et al. | Nov 2008 | A1 |
| 20090063042 | Santesson et al. | Mar 2009 | A1 |
| 20090125228 | Dicke et al. | May 2009 | A1 |
| 20090128483 | Robbins et al. | May 2009 | A1 |
| 20090132163 | Ashley, Jr. et al. | May 2009 | A1 |
| 20090153563 | Tudose | Jun 2009 | A1 |
| 20090182500 | Dicke | Jul 2009 | A1 |
| 20090198767 | Jakobson et al. | Aug 2009 | A1 |
| 20090244095 | Bowman et al. | Oct 2009 | A1 |
| 20090281718 | Gibran et al. | Nov 2009 | A1 |
| 20090287750 | Banavar et al. | Nov 2009 | A1 |
| 20090319177 | Khosravy et al. | Dec 2009 | A1 |
| 20090319188 | Otto | Dec 2009 | A1 |
| 20090326810 | Callaghan et al. | Dec 2009 | A1 |
| 20100020091 | Rasmussen et al. | Jan 2010 | A1 |
| 20100106397 | Van Essen | Apr 2010 | A1 |
| 20100106801 | Bliss et al. | Apr 2010 | A1 |
| 20100117810 | Hagiwara et al. | May 2010 | A1 |
| 20100131186 | Geelen et al. | May 2010 | A1 |
| 20100153007 | Crowley | Jun 2010 | A1 |
| 20100179940 | Gilder et al. | Jul 2010 | A1 |
| 20100250646 | Dunagan et al. | Sep 2010 | A1 |
| 20100274899 | Shrivastava et al. | Oct 2010 | A1 |
| 20100321399 | Ellren et al. | Dec 2010 | A1 |
| 20100333085 | Criddle et al. | Dec 2010 | A1 |
| 20110054776 | Petrov et al. | Mar 2011 | A1 |
| 20110093515 | Albanese | Apr 2011 | A1 |
| 20110095993 | Zuverink | Apr 2011 | A1 |
| 20110098917 | LeBeau et al. | Apr 2011 | A1 |
| 20110098918 | Siliski et al. | Apr 2011 | A1 |
| 20110161875 | Kankainen | Jun 2011 | A1 |
| 20110213798 | Osuka et al. | Sep 2011 | A1 |
| 20110276263 | Shimotani et al. | Nov 2011 | A1 |
| 20110300848 | Boudreau et al. | Dec 2011 | A1 |
| 20110316854 | Vandrovec | Dec 2011 | A1 |
| 20120022786 | Siliski et al. | Jan 2012 | A1 |
| 20120022787 | LeBeau et al. | Jan 2012 | A1 |
| 20120083995 | Vorona | Apr 2012 | A1 |
| 20130151645 | Siliski et al. | Jun 2013 | A1 |
| Number | Date | Country |
|---|---|---|
| 10-2008-071228 | Aug 2008 | KR |
| WO-9828714 | Jul 1998 | WO |
| WO-2009027161 | Mar 2009 | WO |
| Entry |
|---|
| Google Developers, “Google Maps API,” (2012). Retrieved from the Internet on Aug. 31, 2012: URL:http://developers.google.com/maps/. |
| Mapquest, “JavaScript Maps API,” (2012). Retrieved from the Internet on Aug. 31, 2012: URL:http://developer.mapquest.com/web/products/featured/javascript. |
| MSDN, “Get Started Using Bing Maps,” (2012). Retrieved from the Internet on Aug. 31, 2012: URL:http://msdn.microsoft.com/en-us/library/dd877180.aspx. |
| Wiki, “API,” (2012). Retrieved from the Internet on Aug. 31, 2012: URL:http://wiki.openstreetmap.org/wiki/API. |
| International Search Report and Written Opinion for Application No. PCT/US2012/051574, dated Feb. 15, 2013. |
| International Search Report and Written Opinion for Application No. PCT/US2012/051577, dated Feb. 15, 2013. |
| International Search Report and Written Opinion for Application No. PCT/US2012/065002, dated Mar. 29, 2013. |
| International Search Report and Written Opinion for Application No. PCT/US2012/065008, dated Mar. 29, 2013. |
| International Search Report for Application No. PCT/US2012/051564, dated Feb. 18, 2013. |
| Kirchner et al. “A Location-aware Prefetchting Mechanism,” Project work at Distributed Information Systems Laboratory LSIR (2004). |
| Molina, “Aiming and Guiding Navigation with a Non-visual GPS Application,” Department of Design Sciences Faculty of Engineering, Lund University (2010). |
| Office action for U.S. Appl. No. 13/244,717, dated Nov. 15, 2011. |
| Office action for U.S. Appl. No. 13/244,764, dated Nov. 28, 2011. |
| Piras et al., “Compact GML: merging mobile computing and mobile cartography,” CRS4, Center for Advanced Studies, Research and Development in Sardinia (2004). |
| Reichenbacher et al., “The World in Your Pocket—Towards a Mobile Cartography,” Proc. of the 20th International Cartographic Conference (2001). |
| Weber, “Mobile Map Browsers: Anticipated User Interaction for Data Pre-Fetching,” Thesis, The University of Maine, (2010). |
| Number | Date | Country | |
|---|---|---|---|
| 61678065 | Jul 2012 | US |