SYSTEM AND METHOD OF INDICATING TRANSITION BETWEEN STREET LEVEL IMAGES
A system and method of displaying transitions between street level images is provided. In one aspect, the system and method creates a plurality of polygons that are both textured with images from a 2D street level image and associated with 3D positions, where the 3D positions correspond with the 3D positions of the objects contained in the image. These polygons, in turn, are rendered from different perspectives to convey the appearance of moving among the objects contained in the original image.
The present application is a continuation of U.S. patent application Ser. No. 12/391,516, filed on Feb. 24, 2009, the disclosure of which is incorporated herein by reference.
BACKGROUND OF THE INVENTIONServices such as Google Maps are capable of displaying street level images of geographic locations. These images, identified in Google Maps as “Street Views”, typically comprise photographs of buildings and other features and allow a user to view a geographic location from a person's perspective as compared to a top-down map perspective.
The street level images tend to be taken at discrete locations. The Google Maps service provides a variety of mechanisms that allow a user to change from street level image at one location to another, such as clicking an arrow icon.
The Google Maps service also shows an animated transition between two street level images. For example, if the user indicates that he or she wants to move forward to the next image, the client computer is provided with instructions to zoom into the current street level. The zooming is intended to convey the impression of travelling into the image. Similarly, if the user moves to the next street level image, the currently-displayed image pans to the right or left, respectively.
The animation of the current street level image may be shown semi-transparently over the next street level image. More specifically, the next street level image is first sent in a low resolution JPEG format, and the current street level image moves across the low quality image while a higher resolution version of the next image is loaded. When the current street level image is finished moving or zooming, it is hidden from the user, at which point the second street level image is displayed.
If the server has access to street level images taken at locations between the geographic location of the current street level image and the location of the street level image to be displayed, the server may send these images to the client computer for display. While advantageous in many circumstances, many client computers lack a sufficiently fast connection to the server to receive and display the intervening images.
BRIEF SUMMARY OF THE INVENTIONOne aspect of the invention provides a method of displaying an image. The method includes receiving a first image representing a geographic object captured by a camera at a first location; receiving object position data associated with the geographic location of the geographic object; determining, with a processor, a plurality of regions based on the first image and the object position data, each region being associated with a portion of the first image and a geographic location; generating, with a processor, a second image representing the geographic object from the perspective of a second location, the second image comprising a plurality of the regions displayed from the perspective of the second location; and displaying, on an electronic display, the second image.
Another aspect of the invention provides a method of displaying a street level image that includes receiving a first street level image of a geographic object captured by a camera at a first position, receiving depth data representing the position of surface of the geographic object with respect to the first position, generating, with a processor, a plurality of polygons where the vertices of the polygons are associated with positions, the positions of the vertices being determined based on the depth data, and where each polygon is further associated with a portion of the first street level image, and displaying, on an electronic display, a second street level image of the geographic object such that the street level image appears as if it were captured by a camera at the second position. The second street level image is calculated by a processor based on a second position, a plurality of the polygons, and the position of the polygons relative to the second position.
Yet another aspect of the invention relates to system that has a user input device as well as a memory that stores instructions, two-dimensional image data representing a street level image of geographic objects captured by a camera, and location data representing the three-dimensional location of the surfaces of the objects that are facing the camera. The system also includes a processor in communication with the user input device so as to process information received from the user input device in accordance with the instructions, as well as a display in communication with, and displaying information received from, the processor. The instructions include: receiving an identification of a second location and a second orientation; associating portions of the image data with different regions; determining surface location data for a plurality of points associated with each region, where the surface location data of a point represents the three-dimensional location of the portion of the surface of the object that is displayed in the image at the point, and where the surface location data is based on the location data; rendering a two-dimensional second image based on the image data of the regions, the surface location data for the regions, the second location and the second orientation; displaying the second image on the display.
Still another system displays images, and it includes a first computer at a first node of a network, the first computer comprising a first memory storing a first set of instructions, a first processor that processes data in accordance with the first set of instructions, and an electronic display. It also includes a second computer at a second node of a network, the second computer comprising a second memory storing a second set of instructions and a second processor that processes data in accordance with the second set of instructions. The second set of instructions comprise receiving a location from the first computer, transmitting a first image of geographic objects captured by a camera to the first computer, and transmitting position data defining the geographic location of the surfaces of the object represented in the image. The first set of instructions comprise: receiving the first image; receiving the position data; receiving a second location; for a plurality of portions of the image, associating each image portion with an image portion location, where the image portion location is calculated based on at least one geographic location of a surface represented by the portion; generating a second image from the image portions, where the position of each image portion within the second image is calculated based on the appearance of the image portion when viewed from the perceptive of the second location; and displaying the second image.
A further aspect of the invention relates to a method of providing a transition between street level images that includes: receiving a first street level image of geographic objects taken from a first geographic location; receiving object position data representing the geographic location of surfaces of the objects; requesting a second street level image, the second street level image being associated with a second geographic location; determining, with a processor, a plurality of polygons where each vertex of the polygon is associated with both a pixel position and a geographic location, the pixel position representing the position of the vertex relative to the first image, the geographic location of each vertex representing the geographic location of the portion of the object that is displayed at the pixel position of the vertex; determining a first intermediate geographic location based on the first geographic location and the second geographic location; determining, with a processor, a first intermediate image representing at least one of the geographic objects from the perspective of the first intermediate geographic location, the first intermediate image comprising a plurality of the polygons positioned within the first intermediate image based on the geographic location of each polygon's vertices relative to the first intermediate geographic location; and displaying the first intermediate image on a display.
In one aspect, the system and method determines the position of the surfaces of geographic objects displayed in a street level image, such as buildings, and uses this information to create an animation that conveys the impression of moving through the scene represented in the image. The animation may be generated entirely by a client computer, which uses the position information received from a server to create polygons that are textured with image information from the current street level image. The client computer may also calculate a series of intermediate geographic locations from the current street level image to the next street level image; these intermediate locations are used to render and display a series of two-dimensional views based on the polygons from these locations. This aspect of the system and method provides a great deal of flexibility for creating the impression of animated movement through the geographic objects shown in a street level image.
As shown in
Memory 220 stores information accessible by processor 210, including instructions 240 that may be executed by the processor 210. It also includes data 230 that may be retrieved, manipulated or stored by the processor. The memory may be of any type capable of storing information accessible by the processor, such as a hard-drive, memory card, ROM, RAM, DVD, CD-ROM, write-capable, and read-only memories. The processor 210 may be any well-known processor, such as processors from Intel Corporation or AMD. Alternatively, the processor may be a dedicated controller such as an ASIC.
The instructions 240 may be any set of instructions to be executed directly (such as machine code) or indirectly (such as scripts) by the processor. In that regard, the terms “instructions,” “steps” and “programs” may be used interchangeably herein. The instructions may be stored in object code format for direct processing by the processor, or in any other computer language including scripts or collections of independent source code modules that are interpreted on demand or compiled in advance. Functions, methods and routines of the instructions are explained in more detail below.
Data 230 may be retrieved, stored or modified by processor 210 in accordance with the instructions 240. For instance, although the system and method is not limited by any particular data structure, the data may be stored in computer registers, in a relational database as a table having a plurality of different fields and records, XML documents, or flat files. The data may also be formatted in any computer-readable format such as, but not limited to, binary values, ASCII or Unicode. By further way of example only, image data may be stored as bitmaps comprised of pixels that are stored in compressed or uncompressed, or lossless or lossy formats (e.g., JPEG), vector-based formats (e.g., SVG) or computer instructions for drawing graphics. Moreover, the data may comprise any information sufficient to identify the relevant information, such as numbers, descriptive text, proprietary codes, pointers, references to data stored in other memories (including other network locations) or information that is used by a function to calculate the relevant data.
Although
In one aspect, computer 110 is a server communicating with one or more client computers 150, 170 (only client 150 being shown in
Although the client computers 150 and 170 may comprise a full-sized personal computer, the system and method may also be used in connection with mobile devices capable of wirelessly exchanging data with a server over a network such as the Internet. For example, client computer 170 may be a wireless-enabled PDA such as a Blackberry phone or an Internet-capable cellular phone. In either regard, the user may input information using a small keyboard (in the case of a Blackberry phone), a keypad (in the case of a typical cell phone), a touch screen (in the case of a PDA) or any other means of user input.
Client computers 150 and 170 may include a component, such as circuits, to determine the geographic location of the device. For example, mobile device 170 may include a GPS receiver 155. By way of further example, the component may include software for determining the position of the device based on other signals received at the mobile device 170, such as signals received at a cell phone's antenna from one or more cell phone towers if the mobile device is a cell phone.
The server 110 and client computers 150 and 170 are capable of direct and indirect communication, such as over a network 295. Although only a few computers are depicted in
Although certain advantages are obtained when information is transmitted or received as noted above, other aspects of the system and method are not limited to any particular manner of transmission of information. For example, in some aspects, information may be sent via a medium such as a disk, tape or CD-ROM. In other aspects, the information may be transmitted in a non-electronic format and manually entered into the system. Yet further, although some functions are indicated as taking place on a server and others on a client, various aspects of the system and method may be implemented by a single computer having a single processor.
Map database 270 of server 110 stores map-related information, at least a portion of which may be transmitted to a client device. For example, map database 270 may store map tiles 272, where each tile is a map image of a particular geographic area. Depending on the resolution (e.g., whether the map is zoomed in or out), one tile may cover an entire region such as a state in relatively little detail. Another tile may cover just a few streets in high detail. The map information is not limited to any particular format. For example, the images may comprise street maps, satellite images, or a combination of these, and may be stored as vectors (particularly with respect to street maps) or bitmaps (particularly with respect to satellite images). The various map tiles are each associated with geographical locations, such that the server 110 is capable of selecting, retrieving and transmitting one or more tiles in response to receipt of a geographical location.
As noted below, the locations may be expressed in various ways including but not limited to latitude/longitude positions, street addresses, points on a map (such as when a user clicks on a map), building names, other data capable of identifying one or more geographic locations, and ranges of the foregoing.
The map database may also store street level images 274. Street level images comprise images of objects at geographic locations, captured by cameras at geographic locations, in a direction generally parallel to the ground. Thus, as shown in
The street level image may be captured by a camera mounted on top of a vehicle, from a camera angle pointing roughly parallel to the ground and from a camera position at or below the legal limit for vehicle heights (e.g., 7-14 feet). Street level images are not limited to any particular height above the ground, for example, a street level image may be taken from the top of building. Panoramic street-level images may be created by stitching together a plurality of photographs taken from different camera angles.
Each street level image may be stored as a set of pixels associated with color and brightness values. For example, if the images are stored in JPEG format, the image will be displayed as a set of pixels in rows and columns, with each pixel being associated with a value that defines the color and brightness of the image at the pixel's location.
In addition to being associated with geographic locations, street level images 274 are typically associated with information indicating the orientation of the image. For example, if the street level image comprises a typical photograph, the orientation may simply be the camera angle, which in turn may be represented as an angle that is 30° east of true north and rises 2° from ground level. If the street level images are panoramic images, such as 360° panoramas centered at the geographic location associated with the image, the orientation may indicate the portion of the image corresponding with looking due North from the camera position at an angle directly parallel to the ground.
Street level images may also be stored in the form of videos, such as by displaying MPEG videos captured by an analog video camera or displaying, in succession, time-sequenced photographs that were captured by a digital still camera.
Memory 220 also stores object position data representing the geographic position of the geographic objects in the street level images. The object position data may be stored in any number of formats. (The terms “location” and “position” are used interchangeably herein.)
In one aspect, the object position data stores values representing the geographic positions of the surfaces facing the camera. In that regard, a separate value may be stored for each pixel of the street level image where the value represents the geographic position of the surface that is illustrated at that pixel. Thus, as shown in
The second value associated with the pixel is the geographic location of that portion of the surface. For example, the value may reflect the portion's latitude/longitude and altitude position and expressed as a coordinate of the form (Lat2°, Lon2°, Alt2 meters). The geographic location of the portion of building 322 shown at the pixel at position “B” may be similarly represented as (Lat3, Lon3, Alt3). The object position data 550 may also store the geographic location of the camera position as (Lat1, Lon1, Alt1). Pixels that are not associated with a surface may be associated with a null or default surface value.
In still another aspect, the object position data may store the distances from the objects to the camera at each pixel of the image. Thus, as shown in
In another aspect, the geographic locations of the surfaces facing the camera are stored as polygons. Thus, as shown in
Other formats for storing the object position data may also be used. For example, rather than being associated with absolute values such as latitude/longitude, the values may be relative and in any scale. Moreover, even if a first type of information is used (such as storing the latitude, longitude and altitude of the camera and surface), information of another type may be generated from it (such as using differences between latitude/longitude positions and altitudes to calculate distances).
Certain formats permit the surface information to be stored independently of the street level images taken by the camera. For example, object position data stored as described in
A variety of systems and methods may be used to collect the surface information. By way of example only, a laser range finder may be used. In addition, stereoscopic systems employing two video cameras, spaced slightly apart yet looking at the same scene, may be used as well; by analyzing the slight differences between the images seen by each camera, it is possible to estimate the distance at each point in the images. In yet another aspect, the information may be compiled by using a single video camera, travelling at a particular velocity, to capture the street level imagery as the scenery passes by. The video may not only be used as the street level image, but subsequent frames may be compared to extract the different distances between the objects and the camera (e.g., mountains in the distance will stay in the frame much longer than a fire hydrant passing by along the street).
In addition to the operations illustrated in
When requesting a street level image, the map may indicate the location and orientation of the camera position with a street viewpoint cursor 890.
Server 110 retrieves the appropriate street level image based on the requested location. For example, if the street level images are associated with the latitude/longitude coordinates of the camera when it captured the image, the server may retrieve the closest image to the requested latitude/longitude.
As shown in
The user may also change the location of the viewpoint. For example, the user may move the viewpoint forwards or backwards in the currently-viewed direction by selecting controls 940.
Other navigation controls may be included as well, such as controls in the form of arrows disposed along a street that may be selected to move the vantage point up or down the street. A user may also operate the arrow controls of a keyboard to change the zoom, direction or location of the view. A user may further select portions of the image, such as by moving and clicking a computer mouse or tapping a touch-sensitive screen, to select and move closer to the objects displayed in the image.
Depending on the street level image data that was downloaded, a change in location may necessitate the client computer obtaining more street level image data from the server. For example, and referring to both
The system and method uses the currently retrieved street level image to show an animation that conveys the impression of moving through the scene to the next street level image.
In this aspect, the client computer uses information relating to the location of the street level image's objects in three-dimensional space along with the visual appearance of the objects shown in the street level image.
Before the client computer displays the new street level image, its processor determines a series of intermediate images to display. The intermediate images reflect intermediate viewpoints between the current street level image and the next street level image.
For example, assume the user is moving from a street level image at location 840 to another street level image at location 850 as reflected in
Before the first intermediate image is displayed, the object position data is retrieved for the currently displayed street level image. This object position data may have been retrieved with the street level image.
The processor analyzes individual portions of the street level image, and associates the portions with both image data and the geographic position of objects displayed in the image. For example, as shown in
Because the image represents geographic objects, the pixels represent the color and brightness of the geographic objects in the image. In other words, the pixel at (x1, y1) defines the color and brightness of one portion of building 320, the pixel at (x2, y2) defines the color and brightness at another portion of building 320, and the pixel at (x3, y3) defines the color and brightness of a portion of building 322. The other pixels within the region 1120 similarly define the appearance of geographic objects within the region.
Because each pixel in the region 1120 is associated with a geographic object, the pixels are also associated with geographic locations in three-dimensional space.
The geographic locations of the vertices may be determined from the object position data. For example, if the object position data was pre-calculated by the server and transmitted in the format as described in connection with
This process is repeated for each region of the image, such as each triangular region shown in
The client computer uses the regions to render a new street level image from the first intermediate location. For example, as shown in
For example, the data representing the regions may be structured as polygons, where each polygon is textured with its respective portion of the street level image, and where the coordinates of the vertices of the polygons correspond with the vertices' geographic locations. The 2D projection relative to the screen of the 3D coordinates may be computed using standard camera projections. Moreover, affirm transformation may be used for the texture mapping to approximate the perspective transformation in 3D space. The textured polygons may be provided to a browser plug-in that supports 3D rendering along with instructions to display the polygons from a camera position having coordinates that correspond with the first intermediate location.
The resultant intermediate image is then displayed on the client computer. For example, the street level image—now seen from the vantage point of an intermediate location—may be displayed in a web browser on the client computer.
As also shown in
After the first intermediate image is displayed, an intermediate image associated with a second intermediate location may also be displayed. In one aspect of the invention, the same regions may be used to render the second and subsequent intermediate images. For example, having already structured the regions as textured polygons positioned within a 3D space, the client computer may simply redraw the polygons from a vantage point that corresponds with the second intermediate location.
Each of the images calculated for the intermediate locations may also be shown in sequence. Thus, as shown in
Any number of intermediate images may be generated and displayed in series, either as fast as such images may be generated or as slow as may be desired. Typically, the animation looks smoother when many images are shown in rapid succession, rather than showing a few images with long pauses between them.
The intermediate images are displayed until the last intermediate location is reached, which is typically the intermediate location that is closest to the geographic location of the next street level image to be displayed. After the last intermediate location is displayed, the street level image retrieved of the server is displayed.
In one aspect of the invention, the client computer generates and displays the intermediate images while the server retrieves the next street level image and transmits it to the client computer. This has the added advantage of giving the user something interesting to watch while the image is loading. Moreover, the number of intermediate images, and the duration of time between displays of individual intermediate images, may be calculated to coincide with the estimated time to load and display the next street level image.
In one aspect of the system and method and as shown in
In one aspect, a system and method in accordance with the foregoing is used when the user is transitioning from street level images separated by relatively large distances. However, when transitioning between shorter distances such as neighboring street level images, a system and method that pans and zooms images as described in the background may be sufficient.
Most of the foregoing alternative embodiments are not mutually exclusive, but may be implemented in various combinations to achieve unique advantages. As these and other variations and combinations of the features discussed above can be utilized without departing from the invention as defined by the claims, the foregoing description of the embodiments should be taken by way of illustration rather than by way of limitation of the invention as defined by the claims. It will also be understood that the provision of examples of the invention (as well as clauses phrased as “such as,” “including” and the like) should not be interpreted as limiting the invention to the specific examples; rather, the examples are intended to illustrate only one of many possible embodiments.
Claims
1-22. (canceled)
23. A method of displaying an image comprising:
- receiving a first image comprised of pixels that capture, from a first geographic location, the visual characteristics of a surface of a three-dimensional (3D) geographic object, wherein each pixel is associated with a two-dimensional (2D) position within the first image;
- determining, by the one or more processors and based on the 2D positions of the pixels, a plurality of vertices of a plurality of polygons wherein each vertex of each polygon is associated with a pixel, and wherein each polygon defines a 2D region of the image;
- determining, by the one or more processors, a texture for each polygon based on the visual characteristics of pixels having 2D positions within the region defined by the polygon;
- determining, by the one or more processors, a 3D geographic position for each vertex based on the 3D geographic position of the portion of the object's surface captured by the pixel associated with the vertex;
- receiving a second geographic location different from the first geographic location;
- determining, by the one or more processors, a 3D intermediate position based on the first and second geographic locations;
- displaying, by the one or more processors and based on the 3D geographic positions of the polygons' vertices, the polygons from the viewpoint of the 3D intermediate position.
24. The method of claim 23 further comprising receiving object position data associating each pixel with the 3D geographic position of the portion of the object's surface captured by the pixel.
25. The method of claim 24 wherein, at the time the object position data is received, the object position data provides the latitude, longitude and altitude of the portion of the object's surface captured by the pixel.
26. The method of claim 24 wherein, at the time the object position data is received, the object position data provides the 3D geographic distance from the first geographic location to the portion of the object's surface captured by the pixel.
27. The method of claim 23 wherein the vertices are determined after the second geographic location is received.
28. The method of claim 23 further comprising:
- before the polygons are displayed, displaying a street level image captured from the first geographic location as the first image; and
- after the polygons are displayed, displaying a second street level image captured from the second geographic location.
29. The method of claim 23 wherein the second geographic location is based on input from a user and the polygons are displayed as a second street level image is downloaded from a server.
30. The method of claim 23 wherein determining a 3D intermediate position further comprises determining a series of different intermediate positions between the first and second geographic locations, the method further comprising:
- determining, for each intermediate position, an intermediate image that displays the polygons from the viewpoint of the intermediate position; and
- displaying the intermediate images in series.
31. The method of claim 30 wherein the geographic location and orientation of the viewpoint are different for each image.
32. A system comprising:
- one or more processors, and
- memory storing instructions and a first image comprised of pixels that capture, from a first geographic location, the visual characteristics of a surface of a three-dimensional (3D) geographic object, wherein each pixel is associated with a two-dimensional (2D) position within the first image;
- wherein the instructions are executable by the one or more computing devices and comprise:
- determining, based on the 2D positions of the pixels, a plurality of vertices of a plurality of polygons wherein each vertex of each polygon is associated with a pixel, and wherein each polygon defines a 2D region of the image;
- determining a texture for each polygon based on the visual characteristics of pixels having 2D positions within the region defined by the polygon;
- determining a 3D geographic position for each vertex based on the 3D geographic position of the portion of the object's surface captured by the pixel associated the vertex;
- receiving a second geographic location different from the first geographic location;
- determining a 3D intermediate position based on the first and second geographic locations;
- displaying, based on the 3D geographic positions of the polygons' vertices, the polygons from the viewpoint of the 3D intermediate position.
33. The system of claim 32 wherein the instructions further comprise receiving object position data associating each pixel with the 3D geographic position of the portion of the object's surface captured by the pixel.
34. The system of claim 33 wherein, at the time the object position data is received, the object position data provides the latitude, longitude and altitude of the portion of the object's surface captured by the pixel.
35. The system of claim 33 wherein, at the time the object position data is received, the object position data provides the 3D geographic distance from the first geographic location to the portion of the object's surface captured by the pixel.
36. The system of claim 32 wherein the vertices are determined after the second geographic location is received.
37. The system of claim 32 wherein the instructions further comprise:
- before the polygons are displayed, displaying a street level image captured from the first geographic location as the first image; and
- after the polygons are displayed, displaying a second street level image captured from the second geographic location.
38. The system of claim 32 wherein the second geographic location is based on input from a user and the polygons are displayed as a second street level image is downloaded from a server.
39. The system of claim 32 wherein determining a 3D intermediate position further comprises determining a series of different intermediate positions between the first and second geographic locations, and wherein the instructions further comprise:
- determining, for each intermediate position, an intermediate image that displays the polygons from the viewpoint of the intermediate position; and
- displaying the intermediate images in series.
40. The system of claim 39 wherein the geographic location and orientation of the viewpoint are different for each image.
41. A non-transitory computing-device readable storage medium on which computing-device readable instructions of a program are stored, the instructions, when executed by one or more computing devices, causing the one or more computing devices to perform a method, the method comprising:
- receiving a first street level image comprising pixels that capture, from a first geographic location, the visual characteristics of a surface of a building, wherein each pixel is associated with a two-dimensional (2D) position within the first image;
- receiving object position data associating each pixel of the first street level image with the 3D geographic position of the portion of the building's surface captured by the pixel.
- determining, based on the 2D positions of the pixels, a plurality of vertices of a plurality of polygons wherein each vertex of each polygon is associated with a pixel, and wherein each polygon defines a 2D region of the image;
- determining a texture for each polygon based on the visual characteristics of pixels having 2D positions within the region defined by the polygon;
- determining a 3D geographic position for each vertex based on the object position data;
- receiving a request for another street level image of the building captured from a different geographic location;
- identifying, based on said different geographic location, a second street level image of the building captured from a second geographic location different from the first geographic location;
- determining a series of different 3D intermediate positions between the first and second geographic locations;
- determining, for each intermediate position of the series, an intermediate image that displays the polygons based on the 3D geographic positions of the polygon's vertices relative to the intermediate position; and
- displaying the second street level image after displaying the intermediate images.
42. The medium of claim 41 wherein:
- the first street level image is associated with a first orientation;
- the second street level image is associated with a second orientation different from the first orientation;
- determining, for each intermediate position and based on the first and second orientations, a different orientation; and
- determining an intermediate image further comprises displaying the polygons from the orientation associated with the intermediate position.
Type: Application
Filed: Aug 15, 2016
Publication Date: Dec 1, 2016
Inventor: Jiajun Zhu (Palo Alto, CA)
Application Number: 15/236,852