IBM® is a registered trademark of International Business Machines Corporation, Armonk, N.Y., U.S.A. Other names used herein may be registered trademarks, trademarks or product names of International Business Machines Corporation or other companies.
1. Field of the Invention
This invention relates to modifying maps received from the Internet, and particularly to modifying the maps with a browser.
2. Description of the Related Art
The World Wide Web provides many services via the Internet. These services are generally accessed using a software application referred to as a “browser.” Some of the services provide a mapping feature, which may be referred to as a “map widget.” One example of a map widget is Google Maps.
The map widget may present a map upon which a marker is illustrated. The marker is used to indicate a certain location on the map.
Some problems may arise when a map is displayed with more than one marker. In some situations where markers are close together on a small area of the map, the markers may overlap each other. When markers overlap each other, a false impression concerning the information presented by the markers may be created. The false impression may be created because a viewer may not be abler to discern the number of markers present at the small area of the map. In addition, information displayed on the map may be obstructed by the markers being close together.
Attempts have been made to overcome the problems stated above using available software with the browser. In one example, a chart is used to present information that would be presented by the markers. However, the chart can also obstruct details on the map such as country names and borders. In another example, color is used to convey marker information. The application of color, though, cannot be applied to maps that already have color. Also, the browser is unable to color only the land because the browser cannot find the border between sea and land.
The map image itself cannot be modified using image processing techniques in conjunction with the browser because JavaScript cannot be used with binary code.
Therefore, what are needed are techniques for illustrating a map while providing an accurate impression of the number or markers presented on the map. In addition, the map is illustrated so as to limit obscuring of information displayed on the map.
The shortcomings of the prior art are overcome and additional advantages are provided through the provision of a method for displaying an image of a map using a processing system, the method including: dividing a first map image obtained from a map widget into sections wherein the first map image is displayed by the processing system; recording the location of each marker to be represented in a second map image; calculating a weight factor for each section; moving and deforming each section according to the weight factor of each section to form the second map image; placing a new marker on the second map image wherein the new marker represents at least one marker with a recorded location; and displaying the second map image in place of the first map image.
Further disclosed is a computer program product stored on machine readable media and including machine executable instructions for displaying an image of a map using a processing system, the product including instructions for: dividing a first map image obtained from a map widget into sections wherein the first map image is displayed by the processing system; recording the location each marker to be represented in a second map image; calculating a weight factor for each section wherein the weight factor is proportional to the number of markers to be represented in each section; moving and deforming each section according to the weight factor of each section to form the second map image wherein at least one section that includes the location of at least one marker is expanded and at least one section that does not include the location of at least one marker is contracted; placing a new marker on the second map image wherein a size of the new marker is proportional to the number of markers the new marker represents; and displaying the second map image in place of the first map image.
Additional features and advantages are realized through the techniques of the present invention. Other embodiments and aspects of the invention are described in detail herein and are considered a part of the claimed invention. For a better understanding of the invention with advantages and features, refer to the description and to the drawings.
As a result of the summarized invention, technically we have achieved a solution, which solves the problem of displaying a map image on a processing system wherein markers located close together result in markers overlapping each other and thereby creating an inaccurate first impression. In addition, we have achieved a solution to the problem of markers obscuring information displayed on the map image.
The subject matter, which is regarded as the invention, is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other objects, features, and advantages of the invention are apparent from the following detailed description taken in conjunction with the accompanying drawings, wherein like numbered elements are numbered alike, in which:
The detailed description explains the preferred embodiments of the invention, together with advantages and features, by way of example with reference to the drawings.
The teachings provide techniques for illustrating a map with at least one marker on a display of a computer processing system. In particular, the techniques illustrate the marker on the map while limiting obscuring of information on the map by the marker. The techniques provide for an accurate first impression concerning the number of markers and their location on the map.
The techniques include a method for distorting an image of the map with a browser. Specifically, the method emphasizes (by expanding) a portion of the map that includes the marker. By expanding the emphasized portion, more area of the image is available to provide information without being obscured by the marker. The method also includes de-emphasizing (by contracting) portions of the map that do not include any markers. A portion of the map between an emphasized portion and a de-emphasized portion is generally distorted to provide a smooth transition between the two portions.
In one embodiment, when there are many markers located in a small area of the map, the method may illustrate a single marker in place of the many markers. The single marker, in these instances, will have a size proportional to the number of markers for which the single marker is substituted.
Referring to
Thus, as configured in
It will be appreciated that the system 100 can be any suitable computer or computing platform, and may include a terminal, wireless device, information appliance, device, workstation, mini-computer, mainframe computer, personal digital assistant (PDA) or other computing device.
Examples of operating systems that may be supported by the system 100 include Windows 95, Windows 98, Windows NT 4.0, Windows XP, Windows 2000, Windows CE, Windows Vista, Macintosh, Java, LINUX, and UNIX, or any other suitable operating system. The system 100 also includes a network interface 116 for communicating over a network. The network can be a local-area network (LAN), a metro-area network (MAN), or wide-area network (WAN), such as the Internet or World Wide Web.
Users of the system 100 can connect to the network through any suitable network interface 116 connection, such as standard telephone lines, digital subscriber line, LAN or WAN links (e.g., T1, T3), broadband connections (Frame Relay, ATM), and wireless connections (e.g., 802.11(a), 802.11(b), 802.11(g)).
As disclosed herein, the system 100 includes machine readable instructions stored on machine readable media (for example, the hard disk 104) for capture and interactive display of information shown on the screen 115 of a user. As discussed herein, the instructions are referred to as “software” 120. The software 120 may be produced using software development tools as are known in the art. Also discussed herein, the software 120 may also referred to as a “map display software” 120, or by other similar terms. The software 120 may include various tools and features for providing user interaction capabilities as are known in the art.
In some embodiments, the software 120 is provided as an overlay to another program. For example, the software 120 may be provided as an “add-in” to an application (or operating system). Note that the term “add-in” generally refers to supplemental program code as is known in the art. In such embodiments, the software 120 may replace structures or objects of the application or operating system with which it cooperates.
The software 120 generally provides users with a capability to distort a map provided by a widget. Commands to distort the map are used with the browser. The commands are automatically executed by the browser to distort the map. The commands may be native to (written to function within) computer application code programs (for example, C, C++, Perl, Java, JavaScript and others), other programs typically regarded as computing environments (UNIX, LINUX, DOS, and others) as well as other types of programs.
In one embodiment, the software 120 may initially be placed on a server. In this embodiment, the processing system 100 can be a client of the server. The processing system 100 running the browser can receive the software 120 via the Internet by specifying a uniform resource locator (URL). In one embodiment, the processing system 100 will receive the software 120 that includes JavaScript and Hypertext Markup Language (HTML). The browser can then run the JavaScript that was received by the processing system 100.
As a matter of convention herein, it is considered that the “software” 120 provides for interfacing with other “computer code” used for presenting a map widget. It is recognized that computer code is commonly regarded as software, however, in the interest of avoiding confusion, use of the term “software” is generally limited to describing embodiments of computer implemented instructions and computer program products that provide for distorting a map presented by a map widget.
For some perspective on the map display software 120, consider the following. A map widget may be presented on the processing system 100 by an Internet browser such as MOZILLA FIREFOX® available from Mozilla Corporation of Mountain View, Calif. A map with markers associated with the map widget may be transformed by the map display software 120. The map display software 120 may be run on Firefox to transform the map and present the markers.
As used herein, the term “distorted” generally refers to a capability of the software 120 to transform the undistorted map into an “emphasized map.” The term “transform” relates to deforming sections of the undistorted map and assembling the deformed sections to create the emphasized map. The terms “map” and “map image” relate to an image of a map displayed on the display 115 of the processing system 100. The term “weight factor” relates to a value or values that may be calculated using equations herein that include the term “weight”.
With respect to step 22, a map application programming interface (API) associated with the map widget may be used to record a location (latitude and longitude) for each of the markers 31 on the undistorted map 30. The map API may also be used to convert the geographical location for each marker 31 into a pixel position on the undistorted map 30.
Referring to
where A is a constant selected to express how much the weight in one section 31 will influence the weight in another section 32; dc represents the number of columns between c and c′; dr represents the number of rows between r and r′; and markerNum(r,c) represents the number of markers 31 in the section 32 identified by coordinates (r,c). Equation (1) represents the weight from position (r,c) to position (r′,c′). In general, the section 32 with more markers 31 than another section 32 will have a greater weight than the other section 32. In addition, the section 32 adjacent to a section 32 with heavy weight will also have heavy weight.
Referring to
where NumR represents a number of rows and NumC represents a number of columns.
With respect to step 24 of method 20, in one embodiment each section 32 is moved and deformed in accordance with the weight of each section 32. To fit all sections 32 that are deformed into the emphasized map image of a given width and height, a column weight and a row weight are calculated. Referring to
Referring to
An average row weight and an average column weight are calculated using equations (5) and (6) as follows:
avrRowWeight(r)=rowWeight(r)/NumC (5)
avrColWeight(c)=colWeight(c)/NumR (6)
Referring to
pos(r,c)[x]=pos(r,c−1)[x]+pos(r,c−1)[w′] (7)
where pos(r,c)[x] represents a pixel position in the “x” direction of the section 32 identified by row and column coordinates (r,c);
pos(r,c)[y]=pos(r−1,c)[y]+pos(r−1,c)[h′] (8)
where pos(r,c)[y] represents a pixel position in the “y” direction of the section 32 identified by row and column (r,c);
pos(r,c)[h′]=sectionH×weight(r,c)/avrColWeight(c) (9)
where sectionH is the pixel height of the section 32 identified by (r,c);
pos(r,c)[w′]=sectionW×weight(r,c)/avrRowWeight(r) (10)
where sectionW is the pixel width of the section 32 identified by (r,c);
pos(r,c)[tan X]=(pos(r+1,c)[x]−pos(r,c)[x])/pos(r,c)[h′] (11)
where pos(r,c)[tan X] represents the gradient degrees in the “x” direction of the section 32 identified by (r,c);
pos(r,c)[tan Y]=(pos(r+1,c)[y]−pos(r,c)[y])/pos(r,c)[w′] (12)
where pos(r,c)[tan Y] represents the gradient degrees in the “y” direction of the section 32 identified by (r,c);
pos(r,c)[h]=(pos(r,c+1)[h′]>pos(r,c)[h′])? pos(r,c+1)[h′]: pos(r,c)[h′] (13)
where pos(r,c)[h] represents the height in pixels of the section 32 identified by (r,c); and
pos(r,c)[w]=(pos(r+1,c)[w′]>pos(r,c)[w′])? pos(r+1,c)[w′]: pos(r,c)[w′] (14)
where pos(r,c)[w] represents the width in pixels of the section 32 identified by (r,c).
With respect to equation (13), pos(r,c)[h] uses the larger of pos(r,c)[h′] and pos(r,c+1)[h′] so that an adjacent section 32 can fill in a resulting gap. Similarly, with respect to equation (14), pos(r,c)[w] uses the larger of pos(r,c)[w′] and pos(r+1,c)[w′] so that an adjacent section 32 can fill in a resulting gap.
Referring to
Referring to
markerX′=markerX×(pos(r,c)[w]/sectionW) (15)
where markerX′ represents the number of pixels in the “x” direction from an origin (r,c) of the modified section 62, markerX represents the number of pixels in the “x” direction used to locate the marker 31 on the section 32, and sectionW represents the pixel width of the corresponding section 32; and
markerY′=markerY×(pos(r,c)[h]/sectionH) (16)
where markerY′ represents the number of pixels in the “y” direction from an origin (r,c) of the modified section 62, markerY represents the number of pixels in the “y” direction used to locate the marker 31 on the section 32, and sectionH represents the pixel height of the corresponding section 32.
Referring to
NumR=8;
NumC=16;
IMG
—
H=secH*NumR=256 [pixel];
IMG
—
W=secW*NumC=512 [pixel];
IMG_NAME=“map.img”;
A=1/16.
The code presented in this example is written in JavaScript.
The following code is used to select the section 32 for each marker 31:
The following code is used to calculate the weight for each modified section 62:
The following code is used to calculate the average row weight and the average column weight:
The following code is used to calculate the positions of each section 32:
The following code is used to clip the source image (undistorted map 30):
The following code gives the parameters to fit the image to the right position:
In the following code, the numbers in parentheses correspond to the numbers on
The following code is used to apply the transformation array:
One example of the emphasized map 60 is illustrated in
The capabilities of the present invention can be implemented in software, firmware, hardware or some combination thereof.
As one example, one or more aspects of the present invention can be included in an article of manufacture (e.g., one or more computer program products) having, for instance, computer usable media. The media has embodied therein, for instance, computer readable program code means for providing and facilitating the capabilities of the present invention. The article of manufacture can be included as a part of a computer system or sold separately.
Additionally, at least one program storage device readable by a machine, tangibly embodying at least one program of instructions executable by the machine to perform the capabilities of the present invention can be provided.
When introducing elements of the present invention or the embodiment(s) thereof, the articles “a,” “an,” and “the” are intended to mean that there are one or more of the elements. The terms “including” and “having” are intended to be inclusive such that there may be additional elements other than the listed elements.
The flow diagrams depicted herein are just examples. There may be many variations to these diagrams or the steps (or operations) described therein without departing from the spirit of the invention. For instance, the steps may be performed in a differing order, or steps may be added, deleted or modified. All of these variations are considered a part of the claimed invention.
While the preferred embodiment to the invention has been described, it will be understood that those skilled in the art, both now and in the future, may make various improvements and enhancements which fall within the scope of the claims which follow. These claims should be construed to maintain the proper protection for the invention first described.