The present disclosure relates generally to management of pre-fetched digital map data and more specifically to a system and a method for cache storage pre-fetched digital map data for viewing on a mobile device based on a user's selection of locations during a search or other actions using a web-based mapping application and selection of an option to store the map data at the mobile device.
The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named applicant, 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.
Many mobile computing devices such as cellular phones, tablet computers, notebooks, etc., incorporate global positioning system (GPS) hardware and applications. GPS hardware and applications are useful for navigation with mobile computing devices and are often paired with mobile mapping modules. When instantiated on the device, mobile mapping modules may communicate with a GPS transmitter or other GPS hardware on the device and a backend application server of a mapping system. Using mapping data pushed or pulled from the backend mapping system, the mapping module may then render a digital map of an area around the device's current position on the mobile device. Map data is often pushed to the device from the mapping system based on the device position provided to the system from the GPS hardware via the mapping module. For example, data for graphical representations of streets, buildings, and other geographical features may be pushed to the mobile device and the mapping module running on the device may render the pushed data into images on a display screen of the device based on the current position of the device or based on a search of the mapping system using the device.
The features and advantages described in this summary and the following detailed description are not all-inclusive. Many additional features and advantages will be apparent to one of ordinary skill in the art in view of the drawings, specification, and claims hereof. Additionally, other embodiments may omit one or more (or all) of the features and advantages described in this summary.
A computer-implemented method or instructions stored on a tangible computer-readable medium for pre-fetching map tile data to a mobile computing device may be based on location data. The method and instructions may include a plurality of steps. The method and instructions may send a request for mapping system data from a mapping module of a mobile computing device to a remote mapping system via a network connection. The request may include location data. The method and instructions may also receive mapping system data at the mobile computing device via the network connection from the remote mapping system. The received mapping system data may correspond to the location data. The method and instructions may further display a selectable option to store the retrieved mapping system data in a cache memory of the mobile computing device, and subsequently retrieve the received mapping system data from the cache memory.
A computer system for pre-fetching mapping system data to a mapping module of a mobile computing device may comprise a mapping module and a selection module capable of execution on a mobile computing device. The mapping module may be configured to communicate with a mapping system via a network connection and include instructions to send a request for mapping system data from the mapping module to a remote mapping system via a network connection, where the request includes location data. The mapping module may also include instructions to receive mapping system data at the mobile computing device via the network connection from the remote mapping system. The received mapping system data may correspond to the location data. The selection module may include instructions executed on the one or more processors to communicate with the mapping module and display a selectable option to store the retrieved mapping system data in a cache memory of the mobile computing device. The mapping module may include further instructions executed on the one or more processors to subsequently retrieve the received mapping system data from the cache memory.
Another computer-implemented method or instructions stored on a tangible computer-readable medium for pre-fetching map tile data to a mobile computing device may be based on location data. The method and instructions may include a plurality of steps. The method and instructions may receive a request for mapping system data from a mapping module of a mobile computing device at a remote mapping system via a network connection. The request may include location data. The method and instructions may also retrieve mapping system data at the remote mapping system, wherein the mapping system data corresponds to the location data. The method and instructions may further send the mapping system data from the remote mapping system to the mobile computing device via the network connection. The mobile computing device may be configured to display a selectable option to store the mapping system data in a cache memory of the mobile computing device and may be further configured to subsequently retrieve the mapping system data from the cache memory.
A computer system for pre-fetching mapping system data to a mapping module of a mobile computing device may comprise one or more processors and one or more memories storing instructions. The instructions may be for execution on the one or more processors to receive a request for mapping system data from a mapping module of a mobile computing device at a remote mapping system via a network connection. The request may include location data. The instructions may also be for execution on the one or more processors to retrieve mapping system data at the remote mapping system. The mapping system data may correspond to the location data. Also, the instructions may also be for execution on the one or more processors to send the mapping system data from the remote mapping system to the mobile computing device via the network connection. The mobile computing device may be configured to display a selectable option to store the mapping system data in a cache memory of the mobile computing device and may be further configured to subsequently retrieve the mapping system data from the cache memory.
An apparatus may include means to send a request for mapping system data from a mapping module of a mobile computing device to a remote mapping system via a network connection, wherein the request includes location data. The apparatus may also include means to receive mapping system data at the mobile computing device via the network connection from the remote mapping system, wherein the received mapping system data corresponds to the location data. The apparatus may further include means to display a selectable option to store the retrieved mapping system data in a cache memory of the mobile computing device, and means to subsequently retrieve the received mapping system data from the cache memory.
Another apparatus may include means to receive a request for mapping system data from a mapping module of a mobile computing device at a remote mapping system via a network connection, wherein the request includes location data. The other apparatus may also include means to retrieve mapping system data at the remote mapping system, wherein the mapping system data corresponds to the location data and means to send the mapping system data from the remote mapping system to the mobile computing device via the network connection. The mobile computing device may be configured to display a selectable option to store the mapping system data in a cache memory of the mobile computing device and be further configured to subsequently retrieve the mapping system data from the cache memory.
The figures depict a preferred embodiment for purposes of illustration only. One skilled in the art will readily recognize from the following discussion that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles described herein.
Generally speaking, a mapping module executing on a mobile device pre-fetches digital map tile data for the mapping module. The map tile data is then stored in the mobile device for possible display to a user based on locations that a user specifies during a search or other user action taken with the mapping module. An analysis of events at the mobile device may indicate that a user's desire to pre-fetch map tile data for particular locations. Once specified, the mapping module may pre-fetch the map tile data and store the data in the memory of the mobile device. The mobile device may then quickly render a digital map using the pre-fetched map tile data for the one or more specified geographical locations without having to obtain map data from a backend mapping system. Pre-fetching the map tile data may reduce map rendering latency and lead to a better user experience. Selection of the locations for pre-fetching may be performed at the mobile computing device and may include various other types of data related to the location
A mapping system server 116 may send and receive data for the mapping module 104. In some embodiments, the mapping system 112 and mapping server 116 may send computer-executable instructions and data (e.g., mapping system data 101) that allows the mapping module 104 to render a digital map in a display component of the computing device 106. For example, the mapping server 116 may include a module 117 to receive geographic location data, location selections from the client computing device 106 or the user selection system 114, or other data and, in return, send mapping system data 101 (i.e., digital map tile data 118, listing data 120 corresponding to particular businesses or addresses represented within the digital map tile data 118, place page data 122 corresponding to web sites of the particular businesses or addresses of the listing data 120, etc.) to the device 106.
In some embodiments, the mapping module 104 and selection module 108 may send user-specified location data to the mapping system 112. The mapping system 112, in turn, may send mapping system data 101 to the device 106 for display. A user interface may then present an option to the user to cache the map tiles at the mobile computing device 106 that correspond to the user-specified location data. In other embodiments, the backend components 111 may retrieve user-specified location data from the mobile computing device 106 to determine which tiles to send to the device 106 for cache storage. For example, the selection module 104 may generate user-specified location data at the computing device 106 and the mapping system 112 and/or the user selection system 114 may then retrieve the user-specified location data from the device 106. The systems 112,114 may then determine the mapping system data 101 to send to the device 106, then send the data 101 to the device for cache storage.
The mapping module 104 may include computer-executable instructions to allow the computing device 106 to render a digital representation of a user's current geographic location or any other geographic location in a display component of the computing device 106. As part of the rendering process (e.g., when the user executes the mapping module 104, conducts a geographic location search using the mapping module 104, conducts a route search between two or more geographic locations using the mapping module 104, etc.), the mapping module 104 may execute instructions to display a mapping interface 104a including data 101 from the mapping system 112 (i.e., tile data 118, listing data 120, place page data 122) and/or cached map tile data 102 within a display of the computing device 106. The mapping interface 104a may allow a user to cause the device 106 to render various digital representations of geographic locations using map data 102 from the cache 110, mapping system data 101 sent from the mapping system 112, or other map data sources.
The selection module 108 may include computer-executable instructions to allow a user to select map locations 124 for pre-fetching map tile data. In some embodiments, the selection module 108 may store user-specified location data 124 while the cache 110 stores mapping system data 101 (e.g., map tile data 102) corresponding to the user-specified location data 124. In other embodiments, a variety of other modules executing on the computing device 106 or in communication with the computing device 106 (e.g., a web browser, a user mapping activity tracking module, a trip planning module, an email module, etc.) may allow a user to specify location data 124 for pre-fetching mapping system data 101.
In some embodiments, the selection module 108 at the client device 106 may receive and send user-specified location data 124 for pre-fetching map tile data 102 that is displayed at the computing device 106 using the mapping module 104. In some embodiments, the module 108 includes instructions to analyze user-specified location data 124 including a history of locations determined by GPS hardware of the computing device, mapping module search history data, routing data from routes planned between two or more geographic locations represented by the mapping module 104, or other data 136 indicating geographical locations the user has specified using the mapping module 104. The user-specified location data 124 may include geographic location data that the module 108 may send to the mapping system 112 to retrieve mapping system data 101 for cache storage.
In other embodiments, the user selection system 114 may include a user selection system server 128 at the backend 111 that includes a module 129 to receive, send, and analyze user-specified location data 124 for pre-fetching mapping system data 101 that is displayed at the computing device 106 using the mapping module 104. In some embodiments, the server 128 stores the data 124 in one or more data repositories 130. Module 129 may include computer-executable instructions to analyze the data stored in the data repository 130. Analysis of the location data 124 by the module 129 at the backend 111 may also determine location data that the mapping and event analysis system server 128 may send to the mapping system 112.
a is a flow diagram of an example method 400 for pre-fetching map tile data 200 for storage within a map data cache 110 and display on a computing device 106. The method 400 may include one or more blocks, modules, functions or routines in the form of computer-executable instructions that are stored in a tangible computer-readable medium and executed using a processor of a computing device (e.g., a smart phone, tablet computer, or a mobile computing device, or other personal computing device, as described herein). The method 400 may be included as part of any backend 111 or computing device 106 modules of a computing environment for a system 100 for pre-fetching map tile data 200, for example, or as part of a module that is external to such a system. The method 400 may be part of a mapping module 104 and/or a selection module 108 executing within an application on a computing device of a system 100 for pre-fetching map tile data 200 or as a module of a backend component 111.
At block 402, the mapping module 104 may, after receiving user permission from an opt-in or opt-out user interface, execute instructions to request mapping system data 101 from the mapping system 112. Block 402 may include instructions to present a web page or other interface on a user's computing device from which a user may choose to opt-in or opt-out of any data collection that allows or enables the computing device 106 or any other part of the system 100 to pre-fetch map tile data. The mapping module 104 may execute instructions to request mapping system data 101 from the mapping system 112. In some embodiments, the mapping module user interface 104a or other component may send a web request to the module 117 executing at a server 116 of the mapping system 112. In other embodiments, the mapping system 112 may retrieve the user-specified location data 300 from the selection module 108 or other applications 302. The web request may include user-specified location data 300 including a geographic location data 314 and other instructions. The user-specified location data 300 retrieved or sent from the mapping module 104, selection module 108, and/or applications 302 to the mapping system 112 may be part of search results using the mapping module 104 and may also include location history data, a mapping application search history, routing data, or other data from the mapping module 104. In some embodiments, the user-specified location data 300 may be retrieved from the mapping module 104 in response to a request from the selection module 108, the backend components 111 (e.g., the user selection system 114), or other modules and components of the system 100.
At block 404, the mapping system 112 may execute instructions to retrieve mapping system data 101 corresponding to the user-specified location data 300 in general and the geographic location data 314 in particular. In some embodiments, the module 117 may execute instructions to match the received user-specified location data 300 and geographic location data 314 to mapping system data 101 including a plurality of map tiles 200 that graphically represent the geographic location data 314 of the user-specified location data 300. In some embodiments, block 404 matches the received user-specified location data 300 to data within one or more of the map tile repository 118, listing data repository 120, place page data 122 repository, etc., that corresponds to the geographic location data 314 of the user-specified location data 300.
At block 406, the module 117 may execute instructions to send the mapping system data retrieved at block 404 to a mobile computing device 106. In some embodiments, block 406 sends one or more of tile data 200, listing data 206, place page data, etc., to a computing device 106. The module 117 may also send the retrieved data to a mapping module 104 executing on the computing device 106 that sent the user-specified location data 300 to the mapping system 112.
At block 408, the mapping module 104 may execute instructions to receive and display the mapping system data 101 sent from the mapping system 112 as a map 450 (
At block 408, the selection module 108 may execute instructions to determine whether to cache the mapping system data sent to the computing device 106 at block 406. In some embodiments, the module 108 may include computer-executable instructions to present an option 450 to store or not store the a user interface on a display of the mobile computing device 106. The user interface may allow the user to select and option to cache the received mapping system data 101. If the user chooses not to cache the received mapping system data, then the method 400 ends. If the user chooses to cache the received mapping system data (i.e., the map tile data 200, location data 202, listing data 206, etc.), then the module 108 may execute instructions to store the received data in the cache 110 at block 410. Once cached, the mapping module 104 may retrieve the map tile 200 and other received data for display on the mobile computing device 106 from a memory of the device 106, as described below.
As shown in
The processor 502 of
The system memory 514 may include any desired type of volatile and/or non-volatile memory such as, for example, static random access memory (SRAM), dynamic random access memory (DRAM), flash memory, read-only memory (ROM), etc. The mass storage memory 516 may include any desired type of mass storage device. For example, if the computing device 501 is used to implement a mapping module 518 having an API 519 and a selection module 520 (including instructions as described by the method 400 of
The peripheral I/O controller 510 performs functions that enable the processor 502 to communicate with peripheral input/output (I/O) devices 522 and 524, a network interface 526, a cellular network transceiver 527, a local network transceiver 528, and a GPS transceiver 529 (via the network interface 526) via a peripheral I/O bus 528. The I/O devices 522 and 524 may be any desired type of I/O device such as, for example, a keyboard, a display (e.g., a liquid crystal display (LCD), a cathode ray tube (CRT) display, etc.), a navigation device (e.g., a mouse, a trackball, a capacitive touch pad, a joystick, etc.), etc. The I/O devices 522 and 524 may be used with the mapping module 518 and selection module 520 to receive GPS data from the GPS transceiver 529, send the GPS data to the backend components of the system 100, render, and display maps and user interfaces as described in relation to the figures. A cellular telephone transceiver 527 may be resident with the local network transceiver 528. The local network transceiver 528 may include support for a Wi-Fi network, Bluetooth, Infrared, or other wireless data transmission protocols. In other embodiments, one element may simultaneously support each of the various wireless protocols employed by the computing device 501. For example, a software-defined radio may be able to support multiple protocols via downloadable instructions. In operation, the computing device 501 may be able to periodically poll for visible wireless network transmitters (both cellular and local network) on a periodic basis. Such polling may be possible even while normal wireless traffic is being supported on the computing device 501. The network interface 528 may be, for example, an Ethernet device, an asynchronous transfer mode (ATM) device, an 802.11 wireless interface device, a DSL modem, a cable modem, a cellular modem, etc., that enables the system 100 for pre-fetching map tile data to communicate with another computer system having at least the elements described in relation to the system 100.
While the memory controller 512 and the I/O controller 510 are depicted in
Using the systems and procedures described above, the system for pre-fetching mapping data 101 and the mapping system 500 can present an option for the user to select which causes the system to execute instructions to store the mapping data 101 in a cache memory of a mobile computing device. Using the user-specified location data, the systems and procedures described herein may retrieve mapping system data and display this data at the mobile computing device. The user may then be provided with an option to store the mapping system data at the device. Thus, when the mapping module 106 is used to request the same mapping system data that is now stored in the cache memory of the device, the module 106 may access the data from a cache memory 110, 521 rather than backend components 111, 540. Of course, the systems described herein may present a user with a user interface from which the user is able to opt-in or opt-out of any of the pre-fetching methods described herein to preserve user privacy.
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 herein.
For example, the system 500 may include but is not limited to any combination of a LAN, a MAN, a WAN, a mobile, a wired or wireless network, a private network, or a virtual private network. Moreover, while only three remote computing devices 530 and 532 are illustrated in
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 embodied on a machine-readable medium or in a transmission signal, wherein the code is executed by a processor) 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 module” 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. As used herein, “hardware-implemented module” refers to a hardware module. 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 modules can provide information to, and receive information from, other hardware modules. Accordingly, the described hardware modules may be regarded as being communicatively coupled. Where multiple of such hardware modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the hardware modules. In embodiments in which multiple hardware modules are configured or instantiated at different times, communications between such hardware modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple hardware modules have access. For example, one hardware 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 module may then, at a later time, access the memory device to retrieve and process the stored output. Hardware 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 a “software as a service” (SaaS). For example, 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., application program interfaces (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” is a self-consistent sequence of operations or similar processing leading to a desired result. In this context, algorithms 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 “some embodiments” 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 some embodiments” 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.
Still further, the figures depict preferred embodiments of a map editor system for purposes of illustration only. One skilled in the art will readily recognize from the following discussion that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles described herein
Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs for a system and a process for cache storage of pre-fetched digital map data for viewing on a mobile device based on a user's selection of locations during a search or other actions using a web-based mapping application and selection of an option to store the map data at the mobile device 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 is a continuation of U.S. patent application Ser. No. 13/244,717, filed Sep. 26, 2011, which is now U.S. Pat. No. 8,180,851 issued May 15, 2012, which is a continuation of U.S. patent application Ser. No. 13/197,979, filed on Aug. 4, 2011, 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 |
5848373 | DeLorme et al. | Dec 1998 | A |
6061688 | Kilpatrick et al. | May 2000 | A |
6073076 | Crowley et al. | Jun 2000 | A |
6094685 | Greenberg et al. | Jul 2000 | A |
6191782 | Mori et al. | Feb 2001 | B1 |
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 |
6546334 | Fukuchi et al. | Apr 2003 | B1 |
6571279 | Herz et al. | May 2003 | B1 |
6615131 | Rennard et al. | Sep 2003 | B1 |
6671424 | Skoll et al. | Dec 2003 | B1 |
6691128 | Natesan et al. | Feb 2004 | B2 |
6853911 | Sakarya | Feb 2005 | B1 |
6889134 | Nakane et al. | May 2005 | B2 |
7006820 | Parker et al. | Feb 2006 | B1 |
7050905 | Nemeth | May 2006 | B2 |
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 |
7461528 | Taniguchi et al. | Dec 2008 | B2 |
7464109 | Modi | Dec 2008 | B2 |
7472172 | Anderson et al. | Dec 2008 | B2 |
7502780 | Thorpe | Mar 2009 | B2 |
7502876 | Nemirovsky et al. | Mar 2009 | B1 |
7529639 | Rasanen et al. | May 2009 | B2 |
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 |
RE41983 | Wallner | Dec 2010 | E |
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 |
8014945 | Cooper et al. | Sep 2011 | B2 |
8032297 | Jakobson | Oct 2011 | B2 |
8060389 | Johnson | Nov 2011 | B2 |
8060406 | Blegen | Nov 2011 | B2 |
8060582 | Bliss et al. | Nov 2011 | B2 |
8078641 | Mao et al. | Dec 2011 | B2 |
8095307 | Ebert et al. | Jan 2012 | B2 |
8126885 | Prasad et al. | Feb 2012 | B2 |
8180851 | CaveLie | May 2012 | B1 |
8204966 | Mendis et al. | Jun 2012 | B1 |
8229914 | Ramer et al. | Jul 2012 | B2 |
8280414 | Nourse et al. | Oct 2012 | B1 |
8301371 | Sheha et al. | Oct 2012 | B2 |
8340898 | Currie et al. | Dec 2012 | B2 |
8361543 | Nielsen et al. | Jan 2013 | B2 |
8363065 | Scott et al. | Jan 2013 | B2 |
8385591 | Anguelov et al. | Feb 2013 | B1 |
8489332 | Tomobe et al. | Jul 2013 | B2 |
8489669 | Johnson | Jul 2013 | B2 |
8538685 | Johnson | Sep 2013 | B2 |
8543130 | Golds | Sep 2013 | B2 |
8549105 | Nourse et al. | Oct 2013 | B1 |
8683008 | CaveLie | Mar 2014 | B1 |
8711181 | Nourse et al. | Apr 2014 | B1 |
8803920 | Kalai et al. | Aug 2014 | B2 |
8805959 | Mendis et al. | Aug 2014 | B1 |
8812031 | CaveLie et al. | Aug 2014 | B2 |
20020067353 | Kenyon et al. | Jun 2002 | A1 |
20020133491 | Sim et al. | Sep 2002 | A1 |
20030187984 | Banavar et al. | Oct 2003 | A1 |
20040044752 | Hamaguchi et al. | Mar 2004 | A1 |
20040117108 | Nemeth | Jun 2004 | A1 |
20040203998 | Knauerhase et al. | Oct 2004 | A1 |
20040220730 | Chen et al. | Nov 2004 | A1 |
20050287509 | Mohler | Dec 2005 | 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 |
20070218891 | Cox | Sep 2007 | A1 |
20070242077 | Danan | Oct 2007 | A1 |
20070273558 | Smith et al. | Nov 2007 | A1 |
20070282621 | Altman et al. | Dec 2007 | A1 |
20070282915 | Vosshall et al. | Dec 2007 | A1 |
20080065329 | Wilcox et al. | Mar 2008 | A1 |
20080071988 | Schloter et al. | Mar 2008 | A1 |
20080082225 | Barrett | Apr 2008 | A1 |
20080086264 | Fisher | Apr 2008 | A1 |
20080102857 | Kim | May 2008 | A1 |
20080132249 | Hamilton | Jun 2008 | A1 |
20080154655 | Hartmann et al. | Jun 2008 | A1 |
20080177469 | Geelen et al. | Jul 2008 | A1 |
20080192053 | Howell et al. | Aug 2008 | A1 |
20080195311 | Karaoguz et al. | Aug 2008 | A1 |
20080214210 | Rasanen et al. | Sep 2008 | A1 |
20080215240 | Howard et al. | Sep 2008 | A1 |
20080238723 | Fein et al. | Oct 2008 | A1 |
20080270579 | Herz et al. | Oct 2008 | A1 |
20080291205 | Rasmussen et al. | Nov 2008 | A1 |
20090030778 | Zapata et al. | Jan 2009 | A1 |
20090054103 | Stavenow et al. | Feb 2009 | 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 |
20090210388 | Elson et al. | Aug 2009 | A1 |
20090228211 | Rasanen et al. | Sep 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 |
20100017129 | Wilcox et al. | Jan 2010 | 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 |
20100174721 | Mou | Jul 2010 | A1 |
20100179940 | Gilder et al. | Jul 2010 | A1 |
20100182500 | Ishii 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 |
20100332120 | Tomobe 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 |
20110130949 | Arrasvuori | Jun 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 |
20110307648 | Nomura | Dec 2011 | A1 |
20110316854 | Vandrovec | Dec 2011 | A1 |
20120005290 | Cooper et al. | Jan 2012 | A1 |
20120022786 | Siliski et al. | Jan 2012 | A1 |
20120022787 | LeBeau et al. | Jan 2012 | A1 |
20120038662 | Dicklin et al. | Feb 2012 | A1 |
20120083995 | Vorona | Apr 2012 | A1 |
20120146809 | Oh et al. | Jun 2012 | A1 |
20120221239 | Cooper et al. | Aug 2012 | A1 |
20120253488 | Shaw et al. | Oct 2012 | A1 |
20120254804 | Sheha et al. | Oct 2012 | A1 |
20130097197 | Rincover et al. | Apr 2013 | A1 |
20130147846 | Kalai et al. | Jun 2013 | A1 |
20130325307 | Agarwal et al. | Dec 2013 | A1 |
20140073358 | Sridhar et al. | Mar 2014 | A1 |
Number | Date | Country |
---|---|---|
10-2008-071228 | Aug 2008 | KR |
WO-9828714 | Jul 1998 | WO |
WO-2009027161 | Mar 2009 | WO |
Entry |
---|
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. 14, 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). |
Descampe et al., “Data Prefetching for Smooth Navigation of Large Scale JPEG 2000 Images,” IEEE, Multimedia and Expo, pp. 1-4 (2005). |
Google Developers, “Google Maps API,” (2012). Retrieved from the Internet on Aug. 31, 2012: <URL:https://developers.google.com/maps/>. |
International Preliminary Report on Patentability for Application No. PCT/US2012/051564, dated Apr. 1, 2014. |
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. |
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 Preliminary Report on Patentability for Application No. PCT/US2012/051574, dated Jun. 17, 2014. |
International Preliminary Report on Patentability for Application No. PCT/US2012/051577, dated Jun. 17, 2014. |
International Preliminary Report on Patentability for Application No. PCT/US2012/065002, dated May 20, 2014. |
International Preliminary Report on Patentability for Application No. PCT/US2012/065008, dated Jun. 10, 2014. |
Number | Date | Country | |
---|---|---|---|
Parent | 13244717 | Sep 2011 | US |
Child | 14196484 | US | |
Parent | 13197979 | Aug 2011 | US |
Child | 13244717 | US |