Interactive mapping method and system

Abstract
Method and computer program product for presenting a set of address locations in a browser window of a user device via the Internet are disclosed. The method includes receiving a set of address locations in a given order, presenting the set of address locations as a list of directions, and presenting the set of address locations graphically on a map, where the map includes a route connecting the set of address locations according to the given order and a marker for each of the address locations. The method further includes creating a new order of the set of address locations from the given order by dragging an address location from the map to a different position in the list of directions, updating the list of directions according to the new order of the set of address locations, and updating the map according to the new order of the set of address locations.
Description
FIELD OF THE INVENTION

The present invention relates to the field of computer-network-based mapping. In particular, the present invention relates to an interactive mapping method and system.


BACKGROUND OF THE INVENTION

With the increasing popularity of the Internet, millions of users use the Internet to get maps of address locations of interest to them or to get driving directions for getting to such address locations. With conventional map applications, a user would enter a start address and an end address in order to get a driving direction. The conventional map applications would return a map and a list of driving directions from the start address to the end address.


One drawback of the conventional map applications is that they are limited to a point-to-point solution, for getting from point A to point B, for example. However, if the user wants to visit a number of other address locations in the same trip, he would have to break down the whole trip into a series of point-to-point entries and get the map and driving directions for each point-to-point entry separately. This conventional approach involves printing multiple maps and their corresponding driving directions on multiple pages of paper, typically one page for each point-to-point entry. It is not only time-consuming but also a waste of resources because of the multiple maps and their corresponding driving directions that the user has to create and print.


Therefore, there is a need for a new interactive mapping method and system to address the drawbacks of the conventional map applications.


SUMMARY

The present invention generally relates to an interactive mapping method and system. In one embodiment, a method for presenting a set of address locations in a browser window of a user device via the Internet includes receiving a set of address locations in a given order, presenting the set of address locations as a list of directions, and presenting the set of address locations graphically on a map, where the map includes a route connecting the set of address locations according to the given order and a marker for each of the address locations. The method further includes creating a new order of the set of address locations from the given order by dragging an address location from the map to a different position in the list of directions, updating the list of directions according to the new order of the set of address locations, and updating the map according to the new order of the set of address locations.




BRIEF DESCRIPTION OF THE DRAWINGS

The aforementioned features and advantages of the invention as well as additional features and advantages thereof will be more clearly understandable after reading detailed descriptions of embodiments of the invention in conjunction with the following drawings.



FIGS. 1
a-1d illustrate a multipoint routing method according to embodiments of the present invention.



FIGS. 2
a-2c illustrate re-ordering of destinations in the multipoint routing method according to embodiments of the present invention.



FIGS. 3
a-3b illustrate removing a destination in the multipoint routing method according to embodiments of the present invention.



FIGS. 4
a-4b illustrate creating a roundtrip in the multipoint routing method according to embodiments of the present invention.



FIGS. 5
a-5e illustrate a map navigator according to embodiments of the present invention.



FIG. 6 illustrates result clusters associated with the map navigator according to embodiments of the present invention.



FIGS. 7
a-7b illustrate aspect ratio of the map navigator according to embodiments of the present invention.



FIGS. 8
a-8c illustrate an address-to-business lookup method according to embodiments of the present invention.



FIGS. 9
a-9c illustrate a method for updating an address in the uniform resource locator (URL) according to embodiments of the present invention.



FIGS. 10
a-10c illustrate a method for printing a map with directions and search results according to embodiments of the present invention.



FIG. 11 illustrates a method for auto-completing an address entry using information from an address book according to an embodiment of the present invention.




DESCRIPTION OF EMBODIMENTS

The following descriptions are presented to enable any person skilled in the art to make and use the invention. Descriptions of specific embodiments and applications are provided only as examples. Various modifications and combinations of the examples described herein will be readily apparent to those skilled in the art, and the general principles defined herein may be applied to other examples and applications without departing from the spirit and scope of the invention. Thus, the present invention is not intended to be limited to the examples described and shown, but is to be accorded the widest scope consistent with the principles and features disclosed herein.


Some portions of the detailed description that follows are presented in terms of procedures, steps, logic blocks, processing, and other symbolic representations of operations on data bits that can be performed on computer memory. A procedure, computer-executed step, logic block, process, etc., are here conceived to be a self-consistent sequence of steps or instructions leading to a desired result. The steps are those utilizing physical manipulations of physical quantities. These quantities can take the form of electrical, magnetic, or radio signals capable of being stored, transferred, combined, compared, and otherwise manipulated in a computer system. These signals may be referred to at times as bits, values, elements, symbols, characters, terms, numbers, or the like. Each step may be performed by hardware, software, firmware, or combinations thereof.


In various embodiments, the interactive mapping method and system of the present invention implement Web 2.0 functionalities using a combination of HTML, CSS, JavaScript, Asynchronous JavaScript and XML (AJAX), Y!Q, Yahoo! Maps, Yahoo! Widget Engine, and Yahoo! Toolbar for Internet Explorer.



FIGS. 1
a-1d illustrate a multipoint routing method according to embodiments of the present invention. FIG. 1a shows a user entering a first location at the location entry box A. FIG. 1b shows the user entering a second location at the location entry box B. Similarly, FIGS. 1c and 1d show the third and fourth locations are entered at locations entry boxes C and D respectively. Note that upon entering the second location at the location entry box B, the method automatically provides the next location entry box C for the user to enter additional locations, if any. This process is repeated for the subsequent entries, for example the fourth and fifth locations at location entry boxes D and E respectively.


As shown in FIGS. 1a-1d, the interactive mapping system affords a user the ability to create routes with multiple way-points. The user not only is able to create a route from one address/location (A) to another address/location (B), but also may have the option to continue his route to other addresses/locations, such as addresses/locations C, D, and beyond. The route steps between two way-points (e.g., A and B) are described in U.S application Ser. No. 10/849,083, filed May 19, 2004, entitled “Mapping Method and System,” and its continuation-in-part U.S. application Ser. No. 11/137,603, filed May 25, 2005, entitled “Mapping Method and System,” both of which are incorporated herein by reference in their entirety.



FIGS. 2
a-2c illustrate re-ordering of destinations in the multipoint routing method according to embodiments of the present invention. FIG. 2a shows the user (cursor shown as a hand) grabbing the D point to be moved to in front of the C point (Livermore) in the route. FIG. 2b shows the D point (Oakland) being dragged and inserted prior to the C point (Livermore). FIG. 2c shows the new C point (Oakland) both in the map and directions list and in the route drawn on the map. The previous C point (Livermore) becomes the new D point.


As shown in FIGS. 2a-2c, the user may re-order way-points within his route by dragging and dropping within the list view of the route or by dragging a way-point from the map view into the desired point in the list view. For example, the user may decide to change way-point D to be the first stop, so he can drag that point and drop it before the current B way-point in the route list view, and it becomes the new B way-point. The previous B way-point is displaced and becomes the new C way-point and so on. The route steps description and representation on the map are refreshed to describe and show the new route.



FIGS. 3
a-3b illustrate removing of a destination in the multipoint routing method according to embodiments of the present invention.



FIGS. 3
a-3b show the user may delete one or more way-points from his route. For example, the user may remove way-point B from a route that has way-points A-B-C-D. After way-point B is removed, way-point C becomes the new B way-point, and D becomes the new C way-point. In FIG. 3a, the delete icon at the right-side of way-point C is selected. After the way-point C (Oakland) is deleted, the original way-point D (Livermore) becomes the new way-point C as shown in FIG. 3b.



FIGS. 4
a-4b illustrate creating a roundtrip in the multipoint routing method according to embodiments of the present invention. This is done by selecting the Roundtrip link as indicated by the cursor (hand) in FIG. 4a. The user may create a multipoint route by drag and drop of local entities (e.g., businesses) represented on the map from the map to the desired position within the route list view. FIG. 4b shows the complete roundtrip both on the map and on the directions list. As a result, the total distance of the trip is increased to 70.7 miles (the sum of the distance of each of the two routes), and the amount of time is increased to one hour and thirty four minutes (the sum of the time of each of the two routes).



FIGS. 5
a-5e illustrate a map navigator according to embodiments of the present invention. A map navigator includes a small map that gives the surrounding geographic context of the large map view. Within the map navigator, the extent of the current large map view is represented by a shaded rectangular driving (panning) control super-imposed on the surrounding geographic context map, as shown in FIG. 5a. For example, while the large map may show the City of San Francisco, the map navigator map shows the Bay Area with a shaded rectangular area representing San Francisco.


The user can use this shaded area as a control to “drive” to other locations and so explore the geographic context of the current map. As shown in FIG. 5b, this is done by dragging the driving control (shown as the cursor over the grey box) in the direction he wants to drive. In FIG. 5c, the map navigator continuously pans in the direction the user is moving the panning control for as long as the user continues to hold and drag it. In FIG. 5d, the user releases the panning control, and in FIG. 5e, the driving control then settles on the center of the map navigator area, and the large map redraws to the new location the user just drove to.



FIG. 6 illustrates result clusters associated with the map navigator according to embodiments of the present invention. The map navigator may also show representations of data points of interest, for example, businesses such as cafes, hotels, or restaurants. While the large map may only show, say, three points of interest, the map navigator is able to display representations of further similar points of interest in geographic areas adjacent to the view shown by the large map. This allows the user to quickly see and navigate to areas outside the large map view that may contain data of interest. For example, the large map only shows three hotels, but the map navigator shows a cluster of six more to the southwest. Other data of interest such as routes, traffic, demographic statistics, and any other geo-data may be similarly represented.



FIGS. 7
a-7b illustrate aspect ratio of the map navigator according to embodiments of the present invention. FIG. 7a shows a default view of the map navigator, which has substantially the same aspect ratio as the main map. FIG. 7b shows an all-map view of the map navigator, which also has substantially the same aspect ratio as the main map. Note that the aspect ratio of the driving control corresponds to that of the large map, such that it changes due to the browser window re-sizing or the closing of the control panel.



FIGS. 8
a-8c illustrate an address-to-business lookup method according to embodiments of the present invention. The interactive mapping system matches an address entered into a location field with a known business. For example as shown in FIG. 8a, a user may enter “701 First Ave, Sunnyvale Calif. 94089” into location field A, and upon submission of this entry, the system returns a match for the business known to be at this address, as shown in FIG. 8b as Yahoo! Incorporated. Additional information about that business may then be displayed, such as the phone number, user ratings (stars) of the business, etc. The user may access further information about this business by linking to supplementary pages shown in FIG. 8c, which may include user reviews, photos, hours of operation, and other relevant information.



FIGS. 9
a-9c illustrate a method for updating an address in the URL according to embodiments of the present invention. The interactive mapping system automatically updates the URL in the browser address bar in real time. This URL contains sufficient information to allow for the redrawing of the current map view, including any data superimposed on it, such as driving directions, points of interest, etc. For example, instead of using the # symbol to designate in-page anchor links, the system designates the # symbol with a query string that describes the contents of the page (e.g., search results and other map zoom levels etc.). This is represented by the text after the “#” near the middle of the first line in the example shown in FIG. 9c. This function allows the user to copy and paste the URL of the current view, and email it to a friend who may then link to this exact view.



FIGS. 10
a-10c illustrate a method for printing a map with directions and search results according to embodiments of the present invention. The interactive mapping system provides the capability of automatically sending a layout of the current map view (shown in FIG. 10a) and data that is optimized for printing. This occurs when the user selects the print function within the application or when the user chooses the print function from the browser. The printed version of the map and map data, as shown in FIG. 10b, is not what the user is seeing on the screen, such as a “print screen,” but is a different layout specifically designed for printing. The print view of the same data is automatically sent to the printer. The user may also send a text-only variant.


In FIG. 10c, two stylesheets are used to control what is viewed onscreen as being different from what is sent to the printer. Stylesheet 1 designates the screen view and hides the print view; and stylesheet 2 designates the print view and is activated when the user initiates a print function either from within the application or from the browser print commands. This stylesheet also hides the screen view from the print function so that only the print view is sent to the printer.



FIG. 11 illustrates a method for auto-completing an address entry using information from an address book according to an embodiment of the present invention. The interactive mapping system provides the capability of displaying auto-complete selections drawn from the user's address book and the universal location manager (ULM). The ULM stores recently visited or previously saved locations. As the user types in letters or numbers of, for example, a person's name, nickname, or address, into a location box that match entries within his address book or ULM data, the system displays these matches for selection, as shown in FIG. 11. The user can choose to ignore or select these options. If the user selects one of these auto-complete options, the map then centers on the chosen address.


It will be appreciated that the above description for clarity has described embodiments of the invention with reference to different functional units and processors. However, it will be apparent that any suitable distribution of functionality between different functional units or processors may be used without detracting from the invention. For example, functionality illustrated to be performed by separate processors or controllers may be performed by the same processor or controller. Hence, references to specific functional units are only to be seen as references to suitable means for providing the described functionality rather than as indicative of a strict logical or physical structure or organization.


The invention can be implemented in any suitable form, including hardware, software, firmware, or any combination of them. The invention may optionally be implemented partly as computer software running on one or more data processors and/or digital signal processors. The elements and components of an embodiment of the invention may be physically, functionally, and logically implemented in any suitable way. Indeed the functionality may be implemented in a single unit, in a plurality of units, or as part of other functional units. As such, the invention may be implemented in a single unit or may be physically and functionally distributed between different units and processors.


One skilled in the relevant art will recognize that many possible modifications and combinations of the disclosed embodiments may be used, while still employing the same basic underlying mechanisms and methodologies. The foregoing description, for purposes of explanation, has been written with references to specific embodiments. However, the illustrative discussions above are not intended to be exhaustive or to limit the invention to the precise forms disclosed. Many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described to explain the principles of the invention and their practical applications, and to enable others skilled in the art to best utilize the invention and various embodiments with various modifications as suited to the particular use contemplated.

Claims
  • 1. A method for presenting a set of address locations in a browser window of a user device via the Internet, comprising: receiving a set of address locations in a given order; presenting the set of address locations as a list of directions; and presenting the set of address locations graphically on a map, wherein the map includes a route connecting the set of address locations according to the given order, and wherein the map further includes a marker for each of the address locations.
  • 2. The method of claim 1 further comprising: creating a new order of the set of address locations from the given order by dragging an address location from the map to a different position in the list of directions; updating the list of directions according to the new order of the set of address locations; and updating the map according to the new order of the set of address locations.
  • 3. The method of claim 1 further comprising: adding a new address location to the set of address locations; updating the list of directions to include the new address location; and updating the map to include the new address location.
  • 4. The method of claim 1 further comprising: deleting a selected address location from the list of directions; updating the list of directions to exclude the selected address location; and updating the map to exclude the selected address location.
  • 5. The method of claim 1 further comprising: creating a round trip by adding an end address location to the set of address locations, wherein the end address location includes the same address as the beginning address location; updating the list of directions to include the end address location; and updating the map to include a route to the end address location.
  • 6. The method of claim 1 further comprising: providing a query string within a pair of marking characters in a uniform resource locator (URL) in a browser address; retrieving information describing a current map view using the query string in the URL; and updating the URL to include information describing the current map view.
  • 7. The method of claim 6 further comprising: providing the URL to a second user; and presenting the current map view to the second user using the URL.
  • 8. The method of claim 1 further comprising: identifying a current map view and its associated text information from a corresponding screen view in response to receiving a print map command from a user; rearranging the current map view and its associated text information to create a print view; and printing the print view.
  • 9. The method of claim 8, wherein the text information comprises: a start address; an end address; a list of driving directions from the start address to the end address; and a list of points of interest shown in the current map view.
  • 10. The method of claim 1 further comprising: entering an address location in an address field; and auto-completing the address location using information gathered from a list of recently visited or previously saved locations.
  • 11. The method of claim 1 further comprising: entering an address location in an address field; and auto-completing the address location using information gathered from a user's address book.
  • 12. A computer program product for presenting a set of address locations in a browser window of a user device via the Internet, comprising a medium storing computer programs for execution by one or more computer systems, the computer program product comprising: code for receiving a set of address locations in a given order; code for presenting the set of address locations as a list of directions; and code for presenting the set of address locations graphically on a map, wherein the map includes a route connecting the set of address locations according to the given order, and wherein the map further includes a marker for each of the address locations.
  • 13. The computer program product of claim 12 further comprising: code for creating a new order of the set of address locations from the given order by dragging an address location from the map to a different position in the list of directions; code for updating the list of directions according to the new order of the set of address locations; and code for updating the map according to the new order of the set of address locations.
  • 14. The computer program product of claim 12 further comprising: code for adding a new address location to the set of address locations; code for updating the list of directions to include the new address location; and code for updating the map to include the new address location.
  • 15. The computer program product of claim 12 further comprising: code for deleting a selected address location from the list of directions; code for updating the list of directions to exclude the selected address location; and code for updating the map to exclude the selected address location.
  • 16. The computer program product of claim 12 further comprising: code for creating a round trip by adding an end address location to the set of address locations, wherein the end address location includes the same address as the beginning address location; code for updating the list of directions to include the end address location; and code for updating the map to include a route to the end address location.
  • 17. The computer program product of claim 12 further comprising: code for providing a query string within a pair of marking characters in a uniform resource locator (URL) in a browser address; code for retrieving information describing a current map view using the query string in the URL; and code for updating the URL to include information describing the current map view.
  • 18. The computer program product of claim 17 further comprising: code for providing the URL to a second user; and code for presenting the current map view to the second user using the URL.
  • 19. The computer program product of claim 12 further comprising: code for identifying a current map view and its associated text information from a corresponding screen view in response to receiving a print map command from a user; code for rearranging the current map view and its associated text information to create a print view; and code for printing the print view.
  • 20. The computer program product of claim 19, wherein the text information comprises: a start address; an end address; a list of driving directions from the start address to the end address; and a list of points of interest shown in the current map view.
  • 21. The computer program product of claim 12 further comprising: code for entering an address location in an address field; and code for auto-completing the address location using information gathered from a list of recently visited or previously saved locations.
  • 22. The computer program product of claim 12 further comprising: code for entering an address location in an address field; and code for auto-completing the address location using information gathered from a user's address book.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application claims the benefit of application No. 60/727,206, “Interactive Mapping Method and System,” filed Oct. 14, 2005, which is incorporated herein in its entirety by reference.

Provisional Applications (1)
Number Date Country
60727206 Oct 2005 US