Selecting time-distributed panoramic images for display

Information

  • Patent Grant
  • 9972121
  • Patent Number
    9,972,121
  • Date Filed
    Tuesday, April 22, 2014
    10 years ago
  • Date Issued
    Tuesday, May 15, 2018
    6 years ago
Abstract
Images may be automatically annotated with place identifiers based on textual metadata associated with the images. The quality of these place identifiers may be scored based on a number of different factors. For example, these annotations may also include confidence and topicality values indicative of the relationships between the place identifier and the text as well as topics of the text of the textual metadata. Images that also have additional location information that includes GPS coordinates or a location specified by a user, may be used to evaluate the quality of a given place identifier, combination of confidence and topicality values, and the overall annotation system. These valuations may, in turn, be used to score the quality of such automatic annotations of other images that do not have such additional location information.
Description
BACKGROUND

Various systems provide users with images of different locations, including panoramic images. For example, a panoramic image may include an image or collection of images having a field of view which is greater than that of the human eye, e.g., 180 degrees or greater. Some panoramic images may provide a 360-degree view of a location.


Some systems allow users to view images in sequences, such as in time or space. In some examples, these systems can provide a navigation experience in a remote or interesting location. Some systems allow users to feel as if they are rotating within a virtual world by clicking on the edges of a displayed portion of a panorama and having the panorama appear to “rotate” in the direction of the clicked edge.


SUMMARY

Aspects of the disclosure provide a computer implemented method for selecting time-distributed panoramas for display. The method includes accessing, by one or more computing devices, a plurality of panoramic images. Each given panoramic image of the plurality of panoramic images is associated with multi-dimensional location information defined in at least two dimensions, uni-dimensional (1D) location information defined in only one dimension, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the given panoramic image, and time information identifying when the given panoramic image was captured. For a first one of the plurality of panoramic images that is associated with first multi-dimensional location information, first 1D location information, and first time information, the one or more computing devices select a second panoramic image of the plurality of panoramic images. The second panoramic image panoramic image is associated with second multi-dimensional location information, second 1D location information, and second time information. The second panoramic image is selected such that the second 1D location information is closest to the first 1D location information and the first time information and second time information indicate that the first panoramic image and the second panoramic image were captured on different days. The one or more computing devices provide the first panoramic image for display with an indication that the second panoramic image is available. The one or more computing devices also determine a zoom level for the second panoramic image based on the first 3D geometry data, the first multi-dimensional location information, the second 3D geometry data, and the second multi-dimensional location information. The one or more computing devices provide the second panoramic image for display with the zoom level for the second panoramic image.


In one example, the method also includes receiving view port information identifying a viewing angle of a display of the first panoramic image and a zoom level of the display of the first panoramic image. In this example, determining the zoom level for the second panoramic image further includes identifying a first distance to a three dimensional point on a surface of an object in the viewing angle of the display of the first panoramic image based on the first 3D geometry data, the first multi-dimensional location information, and the zoom level of the display of the first panoramic image; identifying a second distance to the three dimensional point on the surface of the object in the second panoramic image based on the first location information and the second 3D geometry data; and determining the zoom level for the second panoramic image using at least the first distance and the second distance. In addition, determining the zoom level for the second panoramic image is further based on a ratio of the first distance to the second distance. Also, the second distance is a linear distance between the three dimensional point and the second location information. In some examples, when the zoom level of the display of the first panoramic image indicates that the first panoramic is not zoomed in, the first distance is a linear distance between the first location of the first panoramic image and the three dimensional point on the surface of the object in the viewing angle of the display of the first panoramic image. In other such examples, the view port information further identifies a viewing angle of a display of the first panoramic image, and the method also includes determining a viewing angle of the second panoramic image based on the viewing angle and the viewing angle for the second panoramic image is provided with the second panoramic image. In another example, the 1D location information associated with each particular panoramic image of the plurality of panoramic images is defined relative to a point on a line corresponding to a portion of road.


Another aspect of the disclosure provides a system comprising one or more computing devices. The one or more computing devices are configured to access a plurality of panoramic images. Each given panoramic image of the plurality of panoramic images being associated with multi-dimensional location information defined in at least two dimensions, uni-dimensional (1D) location information defined in only one dimension, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the given panoramic image, and time information identifying when the given panoramic image was captured. For a first one of the plurality of panoramic images associated with first multi-dimensional location information, first 1D location information, and first time information, the one or more computing devices are configured to select a second panoramic image of the plurality of panoramic images. The second panoramic image panoramic image is associated with second multi-dimensional location information, second 1D location information, and second time information. The second panoramic image is selected such that the second 1D location information is closest to the first 1D location information and the first time information and second time information indicate that the first panoramic image and the second panoramic image were captured on different days. The one or more computing devices are also configured to provide the first panoramic image for display with an indication that the second panoramic image is available and determine a zoom level for the second panoramic image based on the first 3D geometry data, the first multi-dimensional location information, the second 3D geometry data, and the second multi-dimensional location information. The one or more computing devices are also configured to provide the second panoramic image for display with the zoom level for the second panoramic image.


In one example, the one or more computing devices are further configured to receive view port information identifying a viewing angle of a display of the first panoramic image and a zoom level of the display of the first panoramic image. In this example, the one or more computing devices are configured to determine the zoom level for the second panoramic image by also identifying a first distance to a three dimensional point on a surface of an object in the viewing angle of the display of the first panoramic image based on the first 3D geometry data, the first multi-dimensional location information, and the zoom level of the display of the first panoramic image; identifying a second distance to the three dimensional point on the surface of the object in the second panoramic image based on the first location information and the second 3D geometry data; and determining the zoom level for the second panoramic image using at least the first distance and the second distance. In this example, determining the zoom level for the second panoramic image is further based on a ratio of the first distance to the second distance. Also, the second distance is a linear distance between the three dimensional point and the second location information. In some examples, when the zoom level of the display of the first panoramic image indicates that the first panoramic is not zoomed in, the first distance is a linear distance between the first location of the first panoramic image and the three dimensional point on the surface of the object in the viewing angle of the display of the first panoramic image. In other such examples, the view port information further identifies a viewing angle of a display of the first panoramic image, and the one or more computing devices are also configured to determine a viewing angle of the second panoramic image based on the viewing angle and the viewing angle for the second panoramic image is provided with the second panoramic image. In another example, the 1D location information associated with each particular panoramic image of the plurality of panoramic images is defined relative to a point on a line corresponding to a portion of road.


A further aspect of the disclosure provides a non-transitory computer-readable storage medium on which computer readable instructions of a program are stored. The instructions, when executed by one or more processors, cause the one or more processors to perform a method. The method includes accessing a plurality of panoramic images. Each given panoramic image of the plurality of panoramic images being associated with multi-dimensional location information defined in at least two dimensions, uni-dimensional (1D) location information defined in only one dimension, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the given panoramic image, and time information identifying when the given panoramic image was captured. For a first one of the plurality of panoramic images associated with first multi-dimensional location information, first 1D location information, and first time information, the method includes selecting a second panoramic image of the plurality of panoramic images. The second panoramic image panoramic image being associated with second multi-dimensional location information, second 1D location information, and second time information, the second panoramic image being selected such that the second 1D location information is closest to the first 1D location information and the first time information and second time information indicate that the first panoramic image and the second panoramic image were captured on different days. The method also includes providing the first panoramic image for display with an indication that the second panoramic image is available and determining a zoom level for the second panoramic image based on the first 3D geometry data, the first multi-dimensional location information, the second 3D geometry data, and the second multi-dimensional location information. The method also includes providing the second panoramic image for display with the zoom level for the second panoramic image.


In one example, the method also includes receiving view port information identifying a viewing angle of a display of the first panoramic image and a zoom level of the display of the first panoramic image. In this example, determining the zoom level for the second panoramic image also includes identifying a first distance to a three dimensional point on a surface of an object in the viewing angle of the display of the first panoramic image based on the first 3D geometry data, the first multi-dimensional location information, and the zoom level of the display of the first panoramic image; identifying a second distance to the three dimensional point on the surface of the object in the second panoramic image based on the first location information and the second 3D geometry data; and determining the zoom level for the second panoramic image using at least the first distance and the second distance. In addition, determining the zoom level for the second panoramic image is further based on a ratio of the first distance to the second distance. Also, the second distance is a linear distance between the three dimensional point and the second location information. In other such examples, when the zoom level of the display of the first panoramic image indicates that the first panoramic is not zoomed in, the first distance is a linear distance between the first location of the first panoramic image and the three dimensional point on the surface of the object in the viewing angle of the display of the first panoramic image. In another example, the view port information further identifies a viewing angle of a display of the first panoramic image, and the method also includes determining a viewing angle of the second panoramic image based on the viewing angle and the viewing angle for the second panoramic image is provided with the second panoramic image.





BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 is a functional diagram of an example system in accordance with aspects of the disclosure.



FIG. 2 is a pictorial diagram of the example system of FIG. 1.



FIG. 3A is an example diagram of image collection locations in accordance with aspects of the disclosure.



FIG. 3B is an example diagram of data in accordance with aspects of the disclosure.



FIG. 3C is another example diagram of data locations in accordance with aspects of the disclosure.



FIG. 4 is an example diagram of repositioning some of the collection locations of FIG. 3A in one dimension in accordance with aspects of the disclosure.



FIG. 5 is an example screen shot of a portion of a panoramic image in accordance with aspects of the disclosure.



FIG. 6 is an example screen shot of a portion of a panoramic image and a thumbnail image in accordance with aspects of the disclosure.



FIG. 7 is another example screen shot of a portion of a panoramic image and a thumbnail image in accordance with aspects of the disclosure.



FIG. 8 is an example diagram of determining corresponding orientations and zoom levels in accordance with aspects of the disclosure.



FIG. 9 is a flow diagram in accordance with aspects of the disclosure.





DETAILED DESCRIPTION

Overview


The technology relates to selecting and displaying panoramic images captured at different points in time. As an example, a user of a computing device (e.g., a smart phone, laptop, or other personal computing device) may view a street level panoramic image oriented in a particular direction. The computing device may display a “view port” or a portion of the panoramic image that includes various objects that appear to be at a particular distance from the user. The user may also want to view another panoramic image of those objects that was captured at a different point in time. From the user's perspective, he or she may select an option to switch to another panoramic image captured at a different point in time. In response, the user experiences a smooth transition from one panoramic image to another captured at a different point in time which feels like to the user was taken from the same position as the view port of the original panoramic image.


In order to provide the user with another panoramic image as described above, a plurality of such street level panoramic images may be accessed. Each of these panoramic images may have been captured by a camera device mounted on a vehicle as the vehicle is driven along a street. In other examples, the panoramic images may be collected by a person using a camera rig attached to a backpack (e.g., for paths and other non-street areas), a smartphone camera, camera, etc. As the panoramic image is captured, the camera device, or another device, may identify and associate location and orientation information corresponding to a two or three dimensional (2D or 3D) location of the panoramic image. This location and orientation information may also be processed to reduce noise in the raw data. This processed (or unprocessed) location and orientation information may be referred to as the “actual” location of the panoramic image.


In addition to the image and actual location, each panoramic image may also be associated with 3D geometry data corresponding to points on the surface of any objects in that panoramic image. For example, as a vehicle is driven along the street, a LIDAR system may be used to collect laser data or light intensity information which is converted into three dimensional points on the surface of objects. These objects will correspond to objects that are included in a panoramic image that was captured at approximately the same location as the laser data.


Each panoramic image may be processed in order to identify a second location for that image. This second location may correspond to a location along a line through the center or nearly the center of the street along which the vehicle was driven or a “snap” location. This snap location may be defined in a single dimension (1D) along the line through the center of the street.


For a first panoramic image, nearby panoramic images captured at a different point in time, for example on one or more different collection dates, may be selected by querying a plurality of images to identify an image that was both captured at the different point(s) in time and has a snap location that is closest to the snap location of the first panoramic image. Here, the different point in time refers to two different passes near the location of the given panoramic image.


Once a second panoramic image is selected, a link between the first panoramic image and the second panoramic image may be established. Thus, when a user views the first panoramic image, he or she may be provided with an option to view, for example in a thumbnail view, the second panoramic image in conjunction with the first panoramic image or to switch to a view of the second panoramic image. In this example, the second panoramic image may be selected in advance, that is before the user has requested to view the first panoramic image. Alternatively, the selection may be performed in real time (e.g., without delay and in response to the request to view the first panoramic image) in order to keep the closest available panoramic images up to date as the plurality of panoramic images may change over time as additional images are collected.


The view port of the first panoramic image may be used to determine how to display the second panoramic image. For example, the displayed orientation of the view port of the second panoramic image may be selected in order to correspond to the orientation of the view port of the second panoramic image. In addition, the three dimensional geometry data associated with the first panoramic image may be used to determine the distance between the point of view of the view port and an object. For instance, where there is no zoom, the point of view would be the actual location of the first panoramic image. This distance and the three dimensional geometry data associated with the second image are then used to adjust the zoom of the second panoramic image when the second panoramic image is displayed. In this regard, the second panoramic image may be displayed such that objects in the second panoramic image will appear to be the same distance from the user as those same objects in the view port of the first panoramic image.


The features described above simplify the selection and display of other panoramic images from different points in time. For example, it is significantly more efficient to search for images in a single direction using a snap location than using an actual two or three dimensional location. In addition, if the second panoramic image was displayed from the view point at which the second panoramic image was captured, if the images were captured at different sides of the road, switching to the second panorama could be fairly jarring to the user.


Example Systems



FIGS. 1 and 2 include an example system 100 in which the features described herein may be implemented. It should not be considered as limiting the scope of the disclosure or usefulness of the features described herein. In this example, system 100 can include one or more computing devices 110, 120, 130, and 140, storage system 150, as well as collection devices 160 and 170. One or more computing devices 110 can contain one or more processors 112, memory 114 and other components typically present in general purpose computing devices. Memory 114 of the one or more computing devices 110 can store information accessible by one or more processors 112, including instructions 116 that can be executed by the one or more processors 112.


Memory can also include data 118 that can be retrieved, manipulated or stored by the processor. The memory can be of any non-transitory 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 instructions 116 can 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,” “application,” “steps” and “programs” can be used interchangeably herein. The instructions can be stored in object code format for direct processing by the processor, or in any other computing device 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 118 can be retrieved, stored or modified by processor 112 in accordance with the instructions 116. For instance, although the subject matter described herein is not limited by any particular data structure, the data can be stored in computer registers, in a relational database as a table having many different fields and records, or XML documents. The data can also be formatted in any computing device-readable format such as, but not limited to, binary values, ASCII or Unicode. Moreover, the data can comprise any information sufficient to identify the relevant information, such as numbers, descriptive text, proprietary codes, pointers, references to data stored in other memories such as at other network locations, or information that is used by a function to calculate the relevant data.


The one or more processors 112 can include any conventional processors, such as a commercially available CPU. Alternatively, the processor can be a dedicated component such as an ASIC or other hardware-based processor. Although not necessary, one or more computing devices 110 may include specialized hardware components to perform specific computing processes, such as decoding video, matching video frames with images, distorting videos, encoding distorted videos, etc. faster or more efficiently.


Although FIG. 1 functionally illustrates the processor, memory, and other elements of computing device 110 as being within the same block, the processor, computer, computing device, or memory can actually comprise multiple processors, computers, computing devices, or memories that may or may not be stored within the same physical housing. For example, the memory can be a hard drive or other storage media located in one or more housings different from those of the one or more computing devices 110. Accordingly, references to a processor, computer, computing device, or memory will be understood to include references to a collection of processors, computers, computing devices, or memories that may or may not operate in parallel. For example, the computing devices 110 may include server computing devices operating as a load-balanced server farm. Yet further, although some functions described below are indicated as taking place on a single computing device having a single processor, various aspects of the subject matter described herein can be implemented by a plurality of computing devices, for example, communicating information over network 180.


The one or more computing devices 110 can be at various nodes of a network 180 and capable of directly and indirectly communicating with other nodes of network 180. Although only a few computing devices are depicted in FIGS. 1-2, it should be appreciated that a typical system can include a large number of connected computing devices, with each different computing device (as well as collection device) being at a different node of the network 180. The network 180 and intervening nodes described herein can be interconnected using various protocols and systems, such that the network can be part of the Internet, World Wide Web, specific intranets, wide area networks, or local networks. The network can utilize standard communications protocols, such as Ethernet, WiFi and HTTP, protocols that are proprietary to one or more companies, and various combinations of the foregoing. Although certain advantages are obtained when information is transmitted or received as noted above, other aspects of the subject matter described herein are not limited to any particular manner of transmission of information.


As an example, the one or more computing devices 110 may include one or more web servers that are capable of communicating with storage system 150 as well as computing devices 120, 130, and 140 via the network. For example, one or more server computing devices 110 may use network 180 to transmit and present information to a user, such as user 220, 230, or 240, on a display, such as displays 122, 132, or 142 of computing devices 120, 130, or 140. In this regard, computing devices 120, 130, and 140 may be considered client computing devices and may perform all or some of the features described below.


Each of the client computing devices may be configured similarly to the server computing devices 110, with one or more processors, memory and instructions as described above. Each client computing device 120, 130 or 140 may be a personal computing device intended for use by a user 220, 250, 250, and have all of the components normally used in connection with a personal computing device such as a central processing unit (CPU), memory (e.g., RAM and internal hard drives) storing data and instructions, a display such as displays 122, 132, or 142 (e.g., a monitor having a screen, a touch-screen, a projector, a television, or other device that is operable to display information), and user input device 124 (e.g., a mouse, keyboard, touch-screen or microphone). The client computing device may also include a camera for recording video streams, speakers, a network interface device, and all of the components used for connecting these elements to one another.


Although the client computing devices 120, 130 and 140 may each comprise a full-sized personal computing device, they may alternatively comprise mobile computing devices capable of wirelessly exchanging data with a server over a network such as the Internet. By way of example only, client computing device 120 may be a mobile phone or a device such as a wireless-enabled PDA, a tablet PC, or a netbook that is capable of obtaining information via the Internet. In another example, client computing device 130 may be a head-mounted computing system. As an example the user may input information using a small keyboard, a keypad, microphone, using visual signals with a camera, or a touch screen.


Storage system 150 may store various types of information. As described in more detail below, the storage system 150 may store images, such as those described above as having a field of view which is greater than that of the human eye, e.g., 180 degrees or greater. In that regard, example panoramic images described herein provide a 360-degree view of a location, though other types of images may also be used. In addition, each panoramic image may be associated with geographic location information indicating the location and, in some cases, the orientation at which the panoramic image was captured (e.g., which part of the panoramic image is oriented towards “North”, etc.) as well as timestamp information indicating the date and time at which the panoramic image was captured.


The storage system 150 may also store 3D geometry data. As explained above and described in more detail below, this 3D geometry data may correspond to points on the surface of any objects in the plurality of panoramic image. The 3D geometry data may provide the position (x,y,z) of points relative to a particular coordinate system (e.g. relative to a position of a LIDAR system that generated the geometry data or a global positioning system (GPS) such as latitude, longitude, and altitude coordinates).


Storage system 150 may also store map information. The map information may be an image based map or may include a plurality of vectors used to identify the shape, orientation, and other characteristics of streets used to display a map. In this regard, the streets may be divided into discrete road segments. As an example, collection of such road segments (or vectors) may be used to display a map.


As with memory 114, storage system 150 can be of any type of computerized storage capable of storing information accessible by server 110, such as a hard-drive, memory card, ROM, RAM, DVD, CD-ROM, write-capable, and read-only memories. In addition, storage system 150 may include a distributed storage system where data is stored on a plurality of different storage devices which may be physically located at the same or different geographic locations. Storage system 150 may be connected to the computing devices via the network 180 as shown in FIG. 1 and/or may be directly connected to or incorporated into any of the computing devices 110-140 (not shown).


Collection devices 160 and 170 may include a computing device, configured similarly to one of the server computing devices or client computing devices with a processor and memory storing data and instructions (not shown in FIG. 1 for simplicity). Collection devise 160 and 170 may also provide all or some of the images of storage system 150. Each of the collection devices 160 and 170 may include a camera or other information collection device. For example, collection device 160 may include a camera 162 mounted on a vehicle. As the vehicle is driven along a street, the camera of collection device 160 may capture panoramic images. In this regard, all or some of the panoramic images of storage system 150 may be considered “street level images.” As another example, collection device 170 may include a camera rig attached to a backpack (e.g., for paths and other non-street areas), a smartphone camera, a dedicated camera device, etc. which a person walks, bikes, or otherwise moves around with in order to capture panoramic images. In addition to capturing images, the collection devices and/or camera may be configured to provide each panoramic image with a timestamp indicating the date and time at which the image was captured. The captured panoramic images and timestamps may be uploaded or downloaded to the storage system 150.


Each of collection devices 160 or 170 may include a position system 164 in order to determine the camera's relative or absolute position on a map or on the Earth when an image is captured. For example, the position system 164 may include a GPS receiver to determine the device's latitude, longitude and/or altitude position and provide a two or three dimensional (2D or 3D) location at which each panoramic image was captured by the collection device. Other location systems such as laser-based localization systems, inertial-aided GPS, trilateration/triangulation, or camera-based localization may also be used to identify the location of the vehicle. The location of the vehicle may include an absolute geographical location, such as latitude, longitude, and altitude as well as relative location information, such as location relative to other cars immediately around it which can often be determined with less noise than an absolute geographical location.


The positioning system 164 may also include other devices in communication with the camera or collection device, such as an accelerometer, gyroscope or another direction/speed detection device to determine the orientation of the camera 162 when the panoramic image was captured. By way of example only, an acceleration device may determine its pitch, yaw or roll (or changes thereto) relative to the direction of gravity or a plane perpendicular thereto. The device may also track increases or decreases in speed and the direction of such changes.


The collection device's provision of location and orientation data as set forth herein may be associated with the panoramic images as they are being captured and provided automatically to the storage system 150, other computing devices and combinations of the foregoing. Although camera 162 and position system 164 are depicted within the collection device 160, these components may or may not be included in the same physical housing. In this regard, the position system 164 may be a different device from the camera 162 such that both components output the 2D or 3D location information and orientation information and panoramic images to the collection device which processes these outputs in order to associate them with one another and provide them to the storage system 150.


In some examples, the collection device 160 may include a LIDAR system 166 for generating the 3D geometry data described above. For example, as a vehicle is driven along the street, a LIDAR system may be used to collect laser data or light intensity information which is converted into three dimensional points on the surface of objects. These objects will correspond to objects that are included in a panoramic image that was captured by a camera, such as camera 162, at approximately the same geographic location as the laser data.


Example Methods


In order to provide a user with images, a first plurality of panoramic images (at least some of which are street level images) may be captured and stored. As noted above, these images may be captured by a camera mounted on a vehicle (or other device). In this regard, panoramic images may be captured in a sequence as the camera is moved along. Each panoramic image may be associated with 2D or 3D location and orientation information corresponding to the geographic location where the panoramic image was captured as well as a timestamp indicating the date and time when the image was captured. For example, as a collection device such as collection device 160 is moved around, such as by driving a vehicle along a street, camera 162 may capture panoramic images. At the same time, the position system 164 may provide GPS coordinates for each panoramic image captured by camera 162. Each time the collection device 160 captures a series of images may be considered a separate “run.”



FIG. 3A is an example diagram 300 of a birds-eye view of a portion of a street 302 including six lanes 304, 306, 308, 312, 314, and 316. The six lanes are divided into two sections by double lane lines 310. Those appearing above double lane lines 310 are westbound lanes, while those below are eastbound. In this example, the circles correspond to the 2D locations (x,y) of street level images. These circles are arranged into five different runs 320-328. Again, each run may correspond to a path taken by a collection device as the panoramic images of that run were captured. In this example, runes 320, 322, and 324 appear in the westbound lanes 304, 306, and 308, while runs 326 and 328 appear in the eastbound lanes 312 and 314 (but not 316). Here, the street level panoramic images of run 320 were collected by camera 162 of collection device 160 as the vehicle was driven along lane 304 of street 302. The panoramic images of runs 322-328 may have been collected by the same or a different collection device, but were each collected on different dates and times from one another. In the example of FIG. 3A, different runs occur in different lanes for clarity, but this does not necessarily need to be the case. Multiple runs (e.g., 320, 322) could appear in the same lane (e.g., 306).


As the panoramic images are collected during the different runs, 3D geometry data corresponding to objects in those images may also be collected. For example, as collection device 160 is driven along the street 302, LIDAR system 166 may be used to collect laser data or light intensity information corresponding to the surfaces of buildings 330-338. As noted above, this information is converted into three dimensional points on the surface of those buildings. Thus, this information may describe objects that are included in the panoramic image that was captured at approximately the same location as the laser data, or rather any of the panoramic images of runs 320-328. Though not required, each run may be associated with its own 3D geometry data. This 3D geometry data may be associated with individual street level panoramic images or runs, or the 3D geometry data may be retrieved using the 2D or 3D location information for a panoramic image.


In some instances, because of the noise inherent in the GPS coordinates, this information may also be processed in order to reduce noise in the raw data. For example, the laser data, for example generated by a LIDAR system, may be used to shift, confirm, or otherwise correct the GPS coordinates. Example 340 of FIG. 3B depicts two different runs through the same area (e.g., along the same portion of roadway, but not necessarily in the same lane of traffic). The first run includes 3D geometry data corresponding to the façades of buildings represented by lines 342 and 344. The first run also include a plurality of GPS coordinates shown as open circles 346. The second run includes 3D geometry data corresponding to the façades of buildings represented by lines 352 and 345. The second run also include a plurality of GPS coordinates shown as solid circles 356. Data from these two runs may then be shifted relative to one another as shown in example 350 of FIG. 3C. Here, the lines 342 and 344 and/or lines 352 and 354 are shifted so that they align with one another. In addition, the GPS coordinates of each shifted run may also be shifted so that they remain the same relative distance from the lines corresponding to the 3D geometry data for that shifted run. This processed (or in some examples, unprocessed) location and orientation information may be referred to as the “actual” location of the panoramic image.


Each panoramic image may also be processed in order to identify another location for that image which can be represented in one dimension (1D). For example, this second location may correspond to a location along a line through the center or nearly the center of the street along which the vehicle was driven or a “snap” location. The line may correspond to a road segment of the map information stored in storage system 150. In other words, the 2D or 3D location of an image is snapped to a 1D location on the road segment. In this regard, the snap location may be defined in a single dimension along the road segment or rather the line through the street.


Typically, the snap location of an image may be determined by identifying the location of a closest road segment in the map to the 2D or 3D location of a panoramic image. Where the map information has more complex arrangements of road segments (e.g., such as where the closest road segment may actually correspond to a different street), the snap location of an image may be determined based on the most likely snapped position of other images that were captured in that same run. In this regard, even if a single image is closer to a first road segment, it may be snapped to a different road segment if the images captured in the run before and/or after that image were all snapped to the different road segment.



FIG. 4 is an example diagram 400 which depicts the snapping of a small number of images of the runs of FIG. 3A to a road segment 420 corresponding to a portion of street 302. In this example, panoramic images 402-410 of runs 320-328, respectively, are snapped to the closest location along road segment 420, or locations 430-434. In this regard, a 1D location corresponding to the positions of location 430-434 along road segment 420 is identified for each of panoramic images 402-410. The other images of the runs 320-328 may also each be snapped to road segment 420 in order to identify a 1D location for those panoramic images as well.


The 1D snap locations identified as discussed above may be used by the one or more server computing devices to select one or more panoramic images that was captured at approximately the same location but at different points in time. Here, a different point in time refers to two different runs near the location of a given panoramic image. In this regard, given a 1D snap location of a first panoramic image, other panoramic images of the storage system 150 may be queried by the one or more server computing devices 110 in order to identify a second panoramic image having a 1D snap location that is both closest to the 1D snap location of the first panoramic image and has a timestamp which indicates that the second image was captured on a different day (e.g., during a different run) than the first panoramic image. In some instances if the closest panoramic image for a different run is greater than a specified distance, for example, 15 meters or more or less, than no second panoramic images may be selected for that run.


If there are multiple other runs for a given road segment, (e.g., one in August 2011, one in September 2012, etc.), the panoramic images associated with such runs (as identified by the timestamps) may be queried in groups such that a closest panoramic image along the road segment may be identified for each individual run. In this regard, a plurality of such second images, one for each run, may be selected based on a particular first image. Returning to the example of FIG. 4, if panoramic image 402 is a first panoramic image, a second panoramic image may be identified for each of runs 322-328 as each of these runs were each collected on different dates and times from one another, and also from run 320 during which panoramic image 402 was captured. Each of panoramic images 402, 406, 408, 410, and 412 may be selected as a second panoramic image for panoramic image 402 as they would have the closes 1D snap locations for each respective run to the 1D snap location of panoramic image 402.


Any such second panoramic images may be provided for display to a user in conjunction with the first panoramic image. For example, a user, such as user 220, may make a request to view the first panoramic image using a client computing device, such as client computing device 120, by selecting an option to view the first panoramic image, by searching for the first panoramic image by entering a particular location into a search engine, selecting a point on a map corresponding to the 2D or 3D location of the first panoramic image, or in other conventional way. In response, the client computing device may send a request for or identify the first panoramic image to the one or more server computing devices 110.


The one or more server computing devices may receive the request to identify any second panoramic images for the first panoramic image. In one example, any selected second panoramic images described above may be associated with the first panoramic image such that the server computing device 110, may use the first panoramic image to retrieve any second panoramic images. Thus, any second panoramic images may be selected in advance by the one or more server computing devices, that is, before the user has requested to view the first panoramic image. Alternatively, the selection may be performed in real time (e.g., without delay and in response to the request for or identifying the first panoramic image) in order to keep the closest available panoramic images up to date. This may be especially useful as the plurality of panoramic images of the storage system 150 may change over time as additional images are collected.


Once identified, the one or more server computing devices may provide the first panoramic image as well as an option to view any of the identified second panoramic images for display. For instance, when a user views the first panoramic image, he or she may be provided with an option to view one or more second panoramic images in conjunction with the first panoramic image or to switch to a view of one of the second panoramic images. In some examples, any second panoramic images, although not immediately displayed may also be provided to the client computing device, before the user has selected the option, in order to allow the client computing device to display them more quickly.



FIG. 5 is an example screen shot 500 which may be displayed to a user, such as user 220, on a display of a client computing device, such as display 122 of client computing device 120. In this example, the screen shot 500 includes a display of a portion of the panoramic image 502, or a view port. This view port includes a particular orientation and zoom level which allows the user to view portions of buildings 504, 506, and 508. In this example, panoramic image 502 may be considered a first panoramic image as described above. The screen shot 500 also includes display box 510 which includes a first part with a clock icon 512 that indicates that a second panoramic image is available for the panoramic image 502. Display box 510 also includes other information such as location data 514 identifying an approximate location of the portion of the panoramic image 502.


By selecting the option to view a second panoramic image, the user may be provided with a display of a portion of a second panoramic image. For example, as shown in example screen shot 600 of FIG. 6, once a user has selected clock icon 512, the display box 510 changes to include a time window 602. Time window 602 includes a portion (e.g., a thumbnail image) of a second panoramic image 604 that was selected for panoramic image 502. In this example, the portion of panoramic image 604 includes buildings 620, 622, and 624. Here, buildings 624 and 620 may correspond to buildings 504 and 508, respectively of panoramic image 502. However, building 622 does not correspond to building 510, as in this example building 622 did not exist at the time that panoramic image 502 was captured. Rather, at the time panoramic image 502 was captured, building 622 was replaced by building 510.


Time window 602 also includes a slider bar 606 or other selection arrangements which provides a number of different functions. In this example, slider bar 606 indicates the quantity of available second panoramic images for the panoramic image 502. As there are three points 608, 610, and 612 on the slider bar, this may indicate that there are panoramic images from at least two different runs or dates in time that correspond to the location of panoramic image 502. For example, point 608, as it is slightly larger than points 610 and 612, may indicate that panoramic image 604 was captured in 2007 and, assuming that the user was viewing the most recent panoramic image, point 612 may indicate that panoramic image 502 was captured in 2011. Point 610 may further indicate that another image, captured sometime between 2007 and 2011 is also available for viewing by the user. Thus, my manipulating the slider bar, the user may view other available panoramic images, including the panoramic image corresponding to point 610 as well as panoramic image 502 (corresponding to point 612) in the time window. Of course, other slider bars may include fewer points than available panoramic images such that locations along the slider bar between points may also correspond to available panoramic images, and other such mechanisms may be used to indicate to the user that second panoramic images are available.


As noted above, the user may also switch between the second panoramic images and the first panoramic image. For example, a user may simply select the panoramic image displayed in the time window 602 or one of the points of slider bar 606 using mouse pointer, finger and touchscreen. In response, the client computing device may transition from a display of the first panoramic image to a display of the selected second panoramic image. In between, if needed, the client computing device may request the second paranoiac image from the one or more server computing devices as well.


As shown in the example screen shot 700 of FIG. 7, user 220 may select the panoramic image 604 and the display of the portion of panoramic image 502 transitions to, for example by simply switching or fading or by using some other transition mechanism, a display of the panoramic image 604.


The orientation and zoom level, or view port information, of the first panoramic image may be used to determine how to display the second panoramic image. For example, the displayed orientation of the second panoramic image may be selected in order to correspond to that of the first panoramic image. In addition, the three dimensional geometry data associated with the first panoramic image may be used to determine the distance between the point of view of the view port (e.g., where there is no zoom, the point of view would be the actual location of the first panoramic image) to an object. This distance and the three dimensional geometry data associated with the second image are then used to adjust the zoom of the second panoramic image when the second panoramic image is displayed. In this regard, the second panoramic image may be displayed such that objects in the second panoramic image will appear to be the same distance from the user as those same objects in the view port of the first panoramic image. For example, as can be seen from screen shot 600 of FIG. 6, the displayed portion of panoramic image 502 corresponds to the displayed portion of panoramic image 604. In this regard, both the orientations of the panoramic images are corresponding as well as the zoom levels, even though they are not necessarily the same.


For example, two corresponding orientations may either be identical or may be slightly different depending on the 2D or 3D location of each panoramic image. Referring to the example diagram 800 of FIG. 8, a user may be viewing panoramic image 406 oriented in a direction corresponding to South or some particular degree (e.g., 180 degrees from North, etc.) along line 802 at some zoom level z. Thus, the view port information for the panoramic image 406 in this example would include the orientation South and zoom level z. In this regard, the center point (or pixel) of the portion of panoramic image 406 that is displayed corresponds to the location of three dimensional point 804 on building 336.


If panoramic image 402 is available as a second panoramic image, a corresponding orientation may be selected by using the same orientation or south along dashed line 806. Alternatively, the orientation may be selected such that the center point (or pixel) of the portion of panoramic image 406 that is displayed corresponds to the three dimensional point 804 on building 336. This may be determined, for example, by using the 3D geometry data collected during each of runs 320 and 324 to identify the 3D location of point 804 as well as the 2D or 3D locations of panoramic images 402 and 406 to determine the angle α between dashed line 806 and solid line 808. The orientation of panoramic image 406 may then be adjusted using the angle α in order to determine a corresponding orientation for panoramic image 402. For example, as he the dashed line 806 is oriented clockwise from the solid line 808 if the orientation H of panoramic image 406 is in degrees and a is in degrees, α may be subtracted from H (or be made a negative value and added to H) to provide the orientation for panoramic image 402. As another example, if the dashed line 806 were oriented counterclockwise from the solid line 808, a may be made negative and subtracted from H (or be made added to H) to provide the orientation. If the orientation of the first panoramic image displayed to the user is expressed in two dimensions (e.g. a point on a sphere), the same or similar calculations may be performed in two dimensions to determine the orientation of the second panoramic image.


A corresponding zoom level for the second panoramic image may also be determined. For example, referring again to FIG. 8, the distance along line 802, D1, between the 2D or 3D location of panoramic image 406 and the 3D location of point 804 may be determined. Again, the center point (or pixel) of the portion of panoramic image 406 that is displayed corresponds to the location of three dimensional point 804 on building 336. Similarly, the distance along line 808, D2, between the 2D or 3D location of panoramic image 402 and the 3D location of point 804 may also be determined. A ratio of these two distances (D2/D1) may provide a zoom value. Applying this zoom value to the zoom level of the display of panoramic image 406, for example by multiplying (z*D2/D1) may provide a zoom level for panoramic image 402. In this regard if the zoom level of panoramic image 406 is 1, such that point 804 appears to be a distance D1 from the user, than the zoom level for panoramic image 406 would be D2/D1.


The corresponding orientation and zoom level may be determined by the one or more server computing devices or in real time by the client computing device. For example, the client computing device 120 may send the view port information to the one or more server computing devices when the user selects the option to view any second panoramic images (such as clock icon 512 of FIG. 5). In response, the one or more server computing devices 1120 may determine the corresponding view port information for the second panoramic image that will be displayed in the time window 602 as described above and send this information to the client computing device 120.


The corresponding orientation and zoom level, or corresponding view port information, may be used to display the second panoramic images. For example, referring back to FIG. 6, the displayed portion of panoramic image 502 corresponds to the displayed portion of panoramic image 604 even though they may not necessarily have (or been captured at) the same exact 2D or 3D location. In this regard, if the user changes the orientation of panoramic image 502, a corresponding change to the orientation of panoramic image 604 may be made in the time window 602. Thus, when the user selects to transition between the panoramic image 502 and 604 (as shown between FIGS. 6 and 7), the user experiences a smooth transition from one panoramic image to another captured at a different point in time which feels like to the user was taken from the same position as the view port of the original panoramic image.


Flow diagram 900 of FIG. 9 is an example of some of the features described above that may be performed by one or more computing devices, such as computing devices 110, described above. As shown in block 902 of this example, the one or more computing devices access a plurality of panoramic images. Each given panoramic image of the plurality of panoramic images is associated with multi-dimensional location information defined in at least two dimensions, uni-dimensional (1D) location information defined in only one dimension, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the given panoramic image, and time information identifying when the given panoramic image was captured. At block 904, for a first panoramic image of the plurality of images, the first panoramic image being associated with first multi-dimensional location information, first 1D location information, and first time information, a second panoramic image of the plurality of panoramic images is selected. The second panoramic image panoramic image being associated with second multi-dimensional location information, second 1D location information, and second time information. The second panoramic image is selected such that the second 1D location information is closest to the first 1D location information and the first time information and second time information indicate that the first panoramic image and the second panoramic image were captured on different days. At block 906, first panoramic image is provided for display with an indication that the second panoramic image is available. At block 908, a zoom level for the second panoramic image is determined based on the first 3D geometry data, the first multi-dimensional location information, the second 3D geometry data, and the second multi-dimensional location information. The second panoramic image is provided for display with the zoom level for the second panoramic image at block 910.


Unless otherwise stated, the foregoing alternative examples 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 subject matter 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 subject matter defined by the claims. In addition, the provision of the examples described herein, as well as clauses phrased as “such as,” “including” and the like, should not be interpreted as limiting the subject matter of the claims to the specific examples; rather, the examples are intended to illustrate only one of many possible embodiments. Further, the same reference numbers in different drawings can identify the same or similar elements.

Claims
  • 1. A computer implemented method for selecting time-distributed panoramas for display, the method comprising: accessing, by one or more computing devices, a plurality of panoramic images, each panoramic image being associated with multi-dimensional location information defined in at least two dimensions, a one-dimensional (1D) snap location along a path at least partially traveled during image capture, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the panoramic image, and time information identifying when the panoramic image was captured;for a first panoramic image of the plurality, querying the plurality of panoramic images and selecting, by the one or more computing devices, a second panoramic image of the plurality such that a second 1D snap location associated with the second panoramic image is closest to a first 1D snap location associated with the first panoramic image relative to 1D snap locations information associated with others of the plurality of panoramic images, at least a portion of a geographic area depicted in the first panoramic image is also depicted in the second panoramic image, and first time information associated with the first panoramic image and second time information associated with the second panoramic image indicate that the first panoramic image and the second panoramic image were captured on different days;determining whether the second 1D snap location is within a threshold range of the first 1D snap location;providing, by the one or more computing devices, the first panoramic image for display with an indication that the second panoramic image is available when the second 1D snap location is within the threshold range of the first 1D snap location;determining, by the one or more computing devices, a zoom level for the second panoramic image based on first 3D geometry data and first multi-dimensional location information of the first panoramic image, and second 3D geometry data and second multi-dimensional location information of the second panoramic image, such that the zoom level for the second panoramic image is consistent with a zoom level of the first panoramic image; andproviding, by the one or more computing devices, the second panoramic image for display with the zoom level for the second panoramic image.
  • 2. The method of claim 1, further comprising: receiving view port information identifying a viewing angle of a display of the first panoramic image and a zoom level of the display of the first panoramic image,wherein determining the zoom level for the second panoramic image further includes: identifying a first distance to a three dimensional point on a surface of an object in the viewing angle of the display of the first panoramic image based on the first 3D geometry data, the first multi-dimensional location information, and the zoom level of the display of the first panoramic image;identifying a second distance to the three dimensional point on the surface of the object in the second panoramic image based on the first location information and the second 3D geometry data; anddetermining the zoom level for the second panoramic image using at least the first distance and the second distance.
  • 3. The method of claim 2, wherein determining the zoom level for the second panoramic image is further based on a ratio of the first distance to the second distance.
  • 4. The method of claim 2, wherein the second distance is a linear distance between the three dimensional point and the second location information.
  • 5. The method of claim 2, wherein when the zoom level of the display of the first panoramic image indicates that the first panoramic is not zoomed in, the first distance is a linear distance between the first location of the first panoramic image and the three dimensional point on the surface of the object in the viewing angle of the display of the first panoramic image.
  • 6. The method of claim 2, wherein the view port information further identifies a viewing angle of a display of the first panoramic image, and the method further comprises: determining a viewing angle of the second panoramic image based on the viewing angle; andthe viewing angle for the second panoramic image is provided with the second panoramic image.
  • 7. The method of claim 1, wherein the 1D snap location associated with each of the plurality of panoramic images is defined as a point on a line along a central portion of roadway.
  • 8. The system of claim 2, wherein the 1D snap location associated with each particular panoramic image of the plurality of panoramic images is defined relative to a point on a line along a central portion of road.
  • 9. A system comprising one or more computing devices, the one or more computing devices being configured to: access a plurality of panoramic images, each panoramic image being associated with multi-dimensional location information defined in at least two dimensions, a one-dimensional (1D) snap location along a path at least partially traveled during image capture, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the panoramic image, and time information identifying when the panoramic image was captured;for a first panoramic image of the plurality, query the plurality of panoramic images and select a second panoramic image of the plurality such that a second 1D snap location associated with the second panoramic image is closest to a first 1D snap location associated with the first panoramic image relative to 1D snap locations associated with others of the plurality of panoramic images, at least a portion of a geographic area depicted in the first panoramic image is also depicted in the second panoramic image, and first time information associated with the first panoramic image and second time information associated with the second panoramic image indicate that the first panoramic image and the second panoramic image were captured on different days;determine whether the second 1D snap location is within a threshold range of the first 1D snap location;provide the first panoramic image for display with an indication that the second panoramic image is available when the second 1D snap location is within the threshold range of the first 1D snap location;determine a zoom level for the second panoramic image based on first 3D geometry data and first multi-dimensional location information of the first panoramic image, and second 3D geometry data and second multi-dimensional location information of the second panoramic image, such that the zoom level for the second panoramic image is consistent with a zoom level of the first panoramic image; andprovide the second panoramic image for display with the zoom level for the second panoramic image.
  • 10. The system of claim 9, wherein the one or more computing devices are further configured to: receive view port information identifying a viewing angle of a display of the first panoramic image and a zoom level of the display of the first panoramic image, anddetermine the zoom level for the second panoramic image further by: identifying a first distance to a three dimensional point on a surface of an object in the viewing angle of the display of the first panoramic image based on the first 3D geometry data, the first multi-dimensional location information, and the zoom level of the display of the first panoramic image;identifying a second distance to the three dimensional point on the surface of the object in the second panoramic image based on the first location information and the second 3D geometry data; anddetermining the zoom level for the second panoramic image using at least the first distance and the second distance.
  • 11. The system of claim 10, wherein determining the zoom level for the second panoramic image is further based on a ratio of the first distance to the second distance.
  • 12. The system of claim 10, wherein the second distance is a linear distance between the three dimensional point and the second location information.
  • 13. The system of claim 10, wherein when the zoom level of the display of the first panoramic image indicates that the first panoramic is not zoomed in, the first distance is a linear distance between the first location of the first panoramic image and the three dimensional point on the surface of the object in the viewing angle of the display of the first panoramic image.
  • 14. The system of claim 10, wherein the view port information further identifies a viewing angle of a display of the first panoramic image, and the one or more computing devices are further configured to: determine a viewing angle of the second panoramic image based on the viewing angle; andwherein the viewing angle for the second panoramic image is provided with the second panoramic image.
  • 15. A non-transitory computer-readable storage medium on which computer readable instructions of a program are stored, the instructions, when executed by one or more processors, cause the one or more processors to perform a method, the method comprising: accessing a plurality of panoramic images, each panoramic image being associated with multi-dimensional location information defined in at least two dimensions, a one-dimensional (1D) snap location along a path at least partially traveled during image capture, three dimensional (3D) geometry data corresponding to a surface of an object depicted in the panoramic image, and time information identifying when the panoramic image was captured;for a first panoramic image of the plurality, query the plurality of panoramic images and select a second panoramic image of the plurality such that a second 1D snap location associated with the second panoramic image is closest to a first 1D snap location associated with the first panoramic image relative to 1D snap locations associated with others of the plurality of panoramic images, at least a portion of a geographic area depicted in the first panoramic image is also depicted in the second panoramic image, and first time information associated with the first panoramic image and second time information associated with the second panoramic image indicate that the first panoramic image and the second panoramic image were captured on different days;determining whether the second 1D snap location is within a threshold range of the first 1D snap location;providing the first panoramic image for display with an indication that the second panoramic image is available when the second 1D snap location is within the threshold range of the first 1D snap location;determining a zoom level for the second panoramic image based on first 3D geometry data and first multi-dimensional location information of the first panoramic image, and second 3D geometry data and second multi-dimensional location information of the second panoramic image, such that the zoom level for the second panoramic image is consistent with a zoom level of the first panoramic image; andproviding the second panoramic image for display with the zoom level for the second panoramic image.
  • 16. The medium of claim 15, wherein the method further comprises: receiving view port information identifying a viewing angle of a display of the first panoramic image and a zoom level of the display of the first panoramic image, anddetermining the zoom level for the second panoramic image further includes: identifying a first distance to a three dimensional point on a surface of an object in the viewing angle of the display of the first panoramic image based on the first 3D geometry data, the first multi-dimensional location information, and the zoom level of the display of the first panoramic image;identifying a second distance to the three dimensional point on the surface of the object in the second panoramic image based on the first location information and the second 3D geometry data; anddetermining the zoom level for the second panoramic image using at least the first distance and the second distance.
  • 17. The medium of claim 16, wherein determining the zoom level for the second panoramic image is further based on a ratio of the first distance to the second distance.
  • 18. The medium of claim 16, wherein the second distance is a linear distance between the three dimensional point and the second location information.
  • 19. The medium of claim 16, wherein when the zoom level of the display of the first panoramic image indicates that the first panoramic is not zoomed in, the first distance is a linear distance between the first location of the first panoramic image and the three dimensional point on the surface of the object in the viewing angle of the display of the first panoramic image.
  • 20. The medium of claim 16, wherein the view port information further identifies a viewing angle of a display of the first panoramic image, and the method further comprises: determining a viewing angle of the second panoramic image based on the viewing angle; andthe viewing angle for the second panoramic image is provided with the second panoramic image.
US Referenced Citations (338)
Number Name Date Kind
5710875 Harashima Jan 1998 A
5754174 Carpenter et al. May 1998 A
D399501 Arora et al. Oct 1998 S
5912165 Cabib et al. Jun 1999 A
D418495 Brockel et al. Jan 2000 S
6075595 Malinen Jun 2000 A
6195122 Vincent Feb 2001 B1
6373568 Miller et al. Apr 2002 B1
6504571 Narayanaswami et al. Jan 2003 B1
D471225 Gray Mar 2003 S
6769131 Tanaka Jul 2004 B1
7009699 Wolleschensky et al. Mar 2006 B2
D523442 Hiramatsu Jun 2006 S
D525632 Jost et al. Jul 2006 S
D536340 Jost et al. Feb 2007 S
7225207 Ohazama et al. May 2007 B1
D550236 Armendariz Sep 2007 S
D555664 Nagata et al. Nov 2007 S
D557272 Glaser et al. Dec 2007 S
D558220 Maitlen et al. Dec 2007 S
D561191 Haning et al. Feb 2008 S
D563975 Vigesaa Mar 2008 S
D566716 Rasmussen et al. Apr 2008 S
7353114 Rohlf et al. Apr 2008 B1
D571819 Scott et al. Jun 2008 S
D572719 Beamish et al. Jul 2008 S
7398156 Funato Jul 2008 B2
D574388 Armendariz et al. Aug 2008 S
7420598 Ito Sep 2008 B1
D578544 Nathan et al. Oct 2008 S
7535497 Ouchi May 2009 B2
D593578 Ball et al. Jun 2009 S
D595304 Rasmussen Jun 2009 S
7561169 Carroll Jul 2009 B2
D599812 Hirsch Sep 2009 S
D601165 Truelove et al. Sep 2009 S
D601166 Chen et al. Sep 2009 S
D602495 Urn et al. Oct 2009 S
D605657 Denton Dec 2009 S
D606551 Willis Dec 2009 S
7720359 Koyanagi May 2010 B2
RE41428 Mayer et al. Jul 2010 E
D619614 O'Mullan et al. Jul 2010 S
D620950 Rasmussen Aug 2010 S
7840032 Ofek Nov 2010 B2
7912634 Reed et al. Mar 2011 B2
7921108 Wang et al. Apr 2011 B2
7971155 Yoon Jun 2011 B1
D642195 Marks et al. Jul 2011 S
7983489 Aguera y Arcas Jul 2011 B2
D645052 Rasmussen Sep 2011 S
D645470 Matas Sep 2011 S
8064633 Noda Nov 2011 B2
8077918 Kirmse et al. Dec 2011 B2
D652053 Impas et al. Jan 2012 S
8090714 Yang et al. Jan 2012 B2
8103081 Gossage et al. Jan 2012 B2
8145703 Frishert Mar 2012 B2
D656950 Shallcross et al. Apr 2012 S
D661702 Asai et al. Jun 2012 S
D661704 Rasmussen Jun 2012 S
8213749 Di Bernardo Jul 2012 B2
D664983 Moreau et al. Aug 2012 S
D665409 Gupta et al. Aug 2012 S
D667432 Phelan Sep 2012 S
D667834 Coffman et al. Sep 2012 S
8274524 Cornell Sep 2012 B1
8302007 Barcay Oct 2012 B2
8339394 Lininger Dec 2012 B1
8352465 Jing Jan 2013 B1
8422825 Neophytou Apr 2013 B1
D682842 Kurata et al. May 2013 S
D682876 MacNeil May 2013 S
D683356 Hally May 2013 S
D684167 Yang et al. Jun 2013 S
8510041 Anguelov Aug 2013 B1
D689072 Park et al. Sep 2013 S
D689079 Edwards et al. Sep 2013 S
D689082 Stiffler Sep 2013 S
D689085 Pasceri et al. Sep 2013 S
D689089 Impas et al. Sep 2013 S
8543323 Gold Sep 2013 B1
D690737 Wen et al. Oct 2013 S
D692450 Convey et al. Oct 2013 S
D696279 Bortman et al. Dec 2013 S
8610741 Szeliski Dec 2013 B2
8649663 Saitou Feb 2014 B2
D701879 Foit et al. Apr 2014 S
D701882 Soegiono et al. Apr 2014 S
D706822 Wang Jun 2014 S
D708638 Manzari et al. Jul 2014 S
8791983 Shikata Jul 2014 B2
D712920 Sloo et al. Sep 2014 S
D713853 Jaini et al. Sep 2014 S
D715316 Hemeon et al. Oct 2014 S
D715820 Rebstock Oct 2014 S
D715836 Huang et al. Oct 2014 S
8872847 Nash et al. Oct 2014 B2
D716827 Dowd Nov 2014 S
8893026 Lindemann Nov 2014 B2
D719186 Kim Dec 2014 S
8928691 Maurer Jan 2015 B2
8930141 Wither Jan 2015 B2
D726204 Prajapati et al. Apr 2015 S
D728616 Gomez et al. May 2015 S
D730379 Xiong et al. May 2015 S
D731524 Brinda et al. Jun 2015 S
D731545 Lim et al. Jun 2015 S
D732062 Kwon Jun 2015 S
D732567 Moon et al. Jun 2015 S
9047692 Seitz Jun 2015 B1
D733741 Lee et al. Jul 2015 S
D734356 Xiong et al. Jul 2015 S
9106872 Tsurumi Aug 2015 B2
D738900 Drozd et al. Sep 2015 S
D738901 Amin Sep 2015 S
D738914 Torres et al. Sep 2015 S
9158414 Gluzberg Oct 2015 B1
D743984 Salituri Nov 2015 S
9189839 Sheridan Nov 2015 B1
D745020 Mariet et al. Dec 2015 S
D745038 Abbas Dec 2015 S
D746313 Ivalmsley et al. Dec 2015 S
D746319 Zhang et al. Dec 2015 S
9218682 Arrasvuori Dec 2015 B2
9218789 Lininger Dec 2015 B1
9225947 Lee Dec 2015 B2
D746856 Jiang et al. Jan 2016 S
9244940 Donsbach Jan 2016 B1
9256961 Lynch Feb 2016 B2
9256983 Lynch Feb 2016 B2
D754720 Yang Apr 2016 S
9311396 Meadow Apr 2016 B2
9317188 Gregotski Apr 2016 B2
9325946 Tanaka Apr 2016 B2
D757784 Lee et al. May 2016 S
9330504 Ege May 2016 B2
9377320 Sheridan Jun 2016 B2
D762238 Day et al. Jul 2016 S
D762702 Hoang et al. Aug 2016 S
9424536 Bear et al. Aug 2016 B2
D766263 Rice et al. Sep 2016 S
D767589 Ye et al. Sep 2016 S
9442956 Konig Sep 2016 B2
D768178 Valade et al. Oct 2016 S
D769279 Woo et al. Oct 2016 S
D769931 McMillan et al. Oct 2016 S
9471834 Filip Oct 2016 B1
9477368 Filip Oct 2016 B1
9529803 Kisielius Dec 2016 B2
D780210 Kisielius Feb 2017 S
D780211 Kisielius Feb 2017 S
D780777 Kisielius et al. Mar 2017 S
D780794 Kisielius Mar 2017 S
D780795 Kisielius Mar 2017 S
D780796 Kisielius Mar 2017 S
D780797 Kisielius Mar 2017 S
D781317 Kisielius Mar 2017 S
D781318 Kisielius Mar 2017 S
D781337 Kisielius Mar 2017 S
9601087 Suzuki Mar 2017 B2
9633167 Yoshioka Apr 2017 B2
9710886 Gold Jul 2017 B2
9805064 Kojima Oct 2017 B2
9864481 Misawa Jan 2018 B2
20010014185 Chitradon et al. Aug 2001 A1
20010017668 Wilcock Aug 2001 A1
20020047895 Bernardo Apr 2002 A1
20020075322 Rosenzweig et al. Jun 2002 A1
20020122073 Abrams Sep 2002 A1
20020171668 Samra Nov 2002 A1
20030025803 Nakamura Feb 2003 A1
20030030636 Yamaoka Feb 2003 A1
20030117611 Chon Jun 2003 A1
20030142523 Biacs Jul 2003 A1
20040001109 Blancett et al. Jan 2004 A1
20040125133 Pea Jul 2004 A1
20040125148 Pea Jul 2004 A1
20040196282 Oh Oct 2004 A1
20040264919 Taylor Dec 2004 A1
20050063608 Clarke Mar 2005 A1
20050216186 Dorfman Sep 2005 A1
20050232606 Hosoda Oct 2005 A1
20060041591 Rhoads Feb 2006 A1
20060120624 Jojic Jun 2006 A1
20060181546 Jung et al. Aug 2006 A1
20060203335 Martin Sep 2006 A1
20060208926 Poor et al. Sep 2006 A1
20060221229 Ogawa Oct 2006 A1
20060238379 Kimchi Oct 2006 A1
20060251338 Gokturk Nov 2006 A1
20060266942 Ikeda Nov 2006 A1
20060271287 Gold Nov 2006 A1
20070024722 Eura Feb 2007 A1
20070081081 Cheng Apr 2007 A1
20070096945 Rasmussen et al. May 2007 A1
20070110338 Snavely May 2007 A1
20070113255 Kurosawa May 2007 A1
20070136259 Dorfman Jun 2007 A1
20070150188 Rosenberg Jun 2007 A1
20070216709 Kojima Sep 2007 A1
20070250477 Bailly Oct 2007 A1
20070279438 Takakura Dec 2007 A1
20080002962 Ito Jan 2008 A1
20080016472 Rohlf et al. Jan 2008 A1
20080043020 Snow et al. Feb 2008 A1
20080060004 Nelson Mar 2008 A1
20080066000 Ofek Mar 2008 A1
20080077597 Butler Mar 2008 A1
20080089593 Ohwa Apr 2008 A1
20080158366 Jung Jul 2008 A1
20080174593 Ham et al. Jul 2008 A1
20080198178 Julin Aug 2008 A1
20080291201 Lafon Nov 2008 A1
20080291217 Vincent Nov 2008 A1
20080292213 Chau Nov 2008 A1
20090046057 Umezawa Feb 2009 A1
20090063424 Iwamura Mar 2009 A1
20090064014 Nelson Mar 2009 A1
20090202102 Miranda Aug 2009 A1
20090240431 Chau Sep 2009 A1
20090279794 Brucher Nov 2009 A1
20090284551 Stanton Nov 2009 A1
20090290812 Naaman Nov 2009 A1
20090303251 Balogh et al. Dec 2009 A1
20100064239 Crawford et al. Mar 2010 A1
20100115455 Kim May 2010 A1
20100122208 Herr May 2010 A1
20100149212 Fukuya Jun 2010 A1
20100173678 Kim Jul 2010 A1
20100184451 Wang Jul 2010 A1
20100215250 Zhu Aug 2010 A1
20100215254 Prokhorov Aug 2010 A1
20100250581 Chau Sep 2010 A1
20100305844 Choi Dec 2010 A1
20100309512 Onoda Dec 2010 A1
20100316357 Saitou Dec 2010 A1
20110007094 Nash et al. Jan 2011 A1
20110007130 Park Jan 2011 A1
20110010668 Feldstein Jan 2011 A1
20110016398 Hanes Jan 2011 A1
20110022634 Takata Jan 2011 A1
20110050706 Cherna Mar 2011 A1
20110055749 Wallace Mar 2011 A1
20110074707 Watanabe et al. Mar 2011 A1
20110074811 Hanson Mar 2011 A1
20110085778 Iwase Apr 2011 A1
20110123120 Quack May 2011 A1
20110141103 Cohen Jun 2011 A1
20110173565 Ofek Jul 2011 A1
20110211764 Krupka Sep 2011 A1
20110234832 Ezoe Sep 2011 A1
20110249166 Moriyama Oct 2011 A1
20110254976 Garten Oct 2011 A1
20110302527 Chen et al. Dec 2011 A1
20120011464 Hayashi Jan 2012 A1
20120011593 Oka Jan 2012 A1
20120062695 Sakaki Mar 2012 A1
20120075410 Matsumoto Mar 2012 A1
20120092447 Jeong Apr 2012 A1
20120098854 Ohnishi Apr 2012 A1
20120127066 Iida May 2012 A1
20120169769 Minamino Jul 2012 A1
20120188247 Cheung Jul 2012 A1
20120191339 Lee Jul 2012 A1
20120194547 Johnson Aug 2012 A1
20120242783 Seo Sep 2012 A1
20120281119 Ohba Nov 2012 A1
20120293607 Bhogal Nov 2012 A1
20120300019 Yang Nov 2012 A1
20120301039 Maunder Nov 2012 A1
20120316782 Sartipi Dec 2012 A1
20130035853 Stout Feb 2013 A1
20130076784 Maurer Mar 2013 A1
20130076888 Hibino Mar 2013 A1
20130100114 Lynch Apr 2013 A1
20130106990 Williams May 2013 A1
20130182108 Meadow Jul 2013 A1
20130201216 Nakamura Aug 2013 A1
20130239057 Ubillos et al. Sep 2013 A1
20130294650 Fukumiya Nov 2013 A1
20130321461 Filip Dec 2013 A1
20130332890 Ramic Dec 2013 A1
20140002439 Lynch Jan 2014 A1
20140002440 Lynch Jan 2014 A1
20140016193 Terashima Jan 2014 A1
20140023355 Terashima Jan 2014 A1
20140078177 Yamaji Mar 2014 A1
20140078263 Kim Mar 2014 A1
20140079322 Yamaji Mar 2014 A1
20140118405 Chand May 2014 A1
20140164988 Barnett et al. Jun 2014 A1
20140181259 You Jun 2014 A1
20140184727 Xiao Jul 2014 A1
20140210940 Barnes Jul 2014 A1
20140240455 Subbian Aug 2014 A1
20140244160 Cragun Aug 2014 A1
20140253542 Jung Sep 2014 A1
20140253693 Shikata Sep 2014 A1
20140320488 Ege Oct 2014 A1
20140362108 Aguera-Arcas Dec 2014 A1
20140376823 Cui Dec 2014 A1
20150009327 Love Jan 2015 A1
20150077521 Borchert Mar 2015 A1
20150109328 Gallup Apr 2015 A1
20150109513 Nayar Apr 2015 A1
20150113474 Gallup Apr 2015 A1
20150130848 Sakaniwa May 2015 A1
20150154736 Seitz Jun 2015 A1
20150161807 Pack Jun 2015 A1
20150170615 Siegel Jun 2015 A1
20150185018 Hesch Jul 2015 A1
20150185873 Ofstad Jul 2015 A1
20150185991 Ho Jul 2015 A1
20150235398 Kim Aug 2015 A1
20150248197 Peters Sep 2015 A1
20150262391 Chau Sep 2015 A1
20150278878 Chau Oct 2015 A1
20150301695 Leong Oct 2015 A1
20160005437 Barry Jan 2016 A1
20160014190 Sheory Jan 2016 A1
20160019223 Kisielius Jan 2016 A1
20160019713 Dillard Jan 2016 A1
20160048934 Gross Feb 2016 A1
20160063516 Terrazas Mar 2016 A1
20160069703 Nakano Mar 2016 A1
20160080654 Chang Mar 2016 A1
20160140744 Strelow May 2016 A1
20160156840 Arai Jun 2016 A1
20160179760 Strong Jun 2016 A1
20160209648 Haddick Jul 2016 A1
20160321783 Citrin Nov 2016 A1
20160349066 Chung Dec 2016 A1
20170104938 Shimosato Apr 2017 A1
20170132224 Yang May 2017 A1
20170199050 Masuko Jul 2017 A1
20170205997 Gold Jul 2017 A9
20170308752 Takeuchi Oct 2017 A1
Foreign Referenced Citations (2)
Number Date Country
102661748 Sep 2012 CN
1703426 Sep 2006 EP
Non-Patent Literature Citations (38)
Entry
Blackcoffee Design, 1000 Icons Symbols and Pictograms: Visual Communication for Every Language, Gloucester, MA: Rockport Publishers, 2006, 29, 49, 65, 101.
Iconfinder, “Expand Icons”, [unknown date], Iconfinder [online], [site visited Oct. 19, 2015]. Available from internet: <URL:https://www.iconfinder.com/search/?q=expand>.
Frutiger, Adrian, Signs and Symbols: their design and meaning, New York: Watson-Guptill Publications, 1998, 337, 350.
Dreyfuss, Henry, Symbol Sourcebook, New York: Van Nostrand Reinhold Co., 1972, 28.
Taylor, Frank, New Google Maps Moon Update, Sep. 13, 2007, Google Earth Blog [online], [site visited Oct. 15, 2015]. Available from Internet: <URL: https://www.gearthblog.com/blog/archives/2007/09/new_goolge_maps_moon_update.html>.
Abair, Randy, Google Maps Changes, Sep. 2013 Online Marketing Year in Review, Jan. 2, 2014, Vermont DesignWorks Blog [online], [site visited Oct. 15, 2015]. Available from Internet: <URL: http://www.vtdesignworks.com/blog/seo-2013>.
GordyHanner, Why can't I watch Videos in full screen on Youtube?, Dec. 6, 2010, Youtube [online], [site visited Oct. 15, 2015]. Available from Internet: <URL:https://www.youtube.com/watch?v=8n7nn-3CI2A>.
Clohessy, James W. and Patrick J Cerra, How do you warn 19 million people at the drop of a hat?, ArcNews, Fall 2011, [online], [site visited Oct. 15, 2015]. Available from Internet: <URL:https://www.esri.com/news/arcnews/fall11articles/how-do-you-warn-19-million-people-at-the-drop-of-a-hat.html>.
Icons, Google Design Library, updated, Google Inc. [online], [site visited Oct. 19, 2015]. Available from Internet: <https://www.google.com/design/icons/>.
Barclay, et al., “Microsoft TerraServer: A Spatial Data Warehouse”, 2005.
Bauman, “Raster Databases”, 2007.
Bhagavathy et al., “Modeling and Detection of Geospatial Objects Using Texture Motifs” 3706 IEEE Transactions on Geoscience and Remote Sensing. vol. 44, No. 12, Dec. 2006.
Conti et al., “DentroTrento—A virtual Walk Across history”, 2006, pp. 318-321.
European Examination Report for Application No. 09810353.4 dated Oct. 18, 2012.
European Office Action for Application No. 09810353 dated Oct. 9, 2013.
Gail Langran, Nicholas R. Chrisman: “A Framework for temporal Geographic Information”, University of Washington Cartographica, vol. 25, No. 3, Dec. 31, 1988 (Dec. 31, 1988), pp. 1-14, Retrieved from the Internet: URL:http://www.unigis.ac.at/fernstudien/unigis_professional/lehrgangs_cd_1.../module//modul2/Temporal%20Geographic%20Information.pdf.
Ghemawat, et al. “The Google File System”, 2003.
Haval, “Three-Dimensional Documentation of Complex Heritage Structures”, Interpretive Enviornments, Apr.-Jun. 2000, pp. 52-55.
http://ieeexplore.ieee.org/search retrieved from the Internet on Sep. 7, 2010.
International Search Report, PCT/US09/04817, dated Oct. 8, 2009.
Magnenat-Thalmann et al., “Real-Time Animation of Ancient Roman Sites”, 2006, pp. 19-30.
Nan L. et al., “A spatial-temporal system for dynamic cadastral management,” Journal of Environmental Management, Academic Press, London, GB, vol. 78, No. 4, Mar. 1, 2006 (Mar. 1, 2006), pp. 373-381, retrieved on Mar. 1, 2006.
Potmesil M., “Maps alive: Viewing geospacial information on the WWW”, Computer Systems and ISDN Systems, North Holland Publishing, Amsterdam, NL, vol. 29, No. 8-13, Sep. 1, 1997 (Sep. 1, 1997), pp. 1327-1342, XP004095328.
Rocchini D. et al., “Landscape change and the dynamics of open formations in a natural reserve,” Landscape and urban Planning, Elsevier, vol. 77, No. 1-2, Jun. 15, 2006 (Jun. 15, 2006), pp. 167-177, retrieved on Jun. 15, 2006.
Scranton et al., “Sky in Google Earth: The Next Frontier in Astronomical Data Discovery and Visualization”, http://earth.google.com/sky/, Sep. 10, 2007.
The extended European search report, Application No. EP 09 81 0353.4, PCT/US2009004817, dated, Dec. 5, 2011.
U.S. Appl. No. 11/415,960, Zelirilca et al., “Coverage Mask Generation for Large Images”, filed May 2, 2006.
U.S. Appl. No. 11/437,553, “Large-Scale Image Processing Using Mass Parallelizallon Techniques”, filed May 19, 2006.
U.S. Appl. No. 11/473,461, Kirmse et al, “Hierarchical Spatial Data Structure and 3D Index Data Verseoning for Generating Packet Data”, filed Jun. 22, 2006.
U.S. Appl. No. 13/854,314, filed Apr. 1, 2013.
U.S. Appl. No. 13/870,419, filed Apr. 25, 2013.
Vlahakis et al., “Archeoguide: An Augmented Reality Guide for Archaeological Sites”, IEEE Computer Graphics and Applications, Sep./Oct. 2002, pp. 52-60.
Wu, et al, “Automatic Alignment of Large-scale Aerial Rasters to Road-maps” Proceedings of the 15th international Symposium on Advances in Geographic information Systems, 2007.
International Preliminary Report on Patentability for PCT Application No. PCT/US2015/025551, dated Nov. 3, 2016.
Wikipedia, Google Street View, Sep. 3, 2014, wikipedia.com [online], [site visited Apr. 11, 2016]. Available from Internet: <https ://en.wikipedia.org/wiki/Google Street_View>.
Wikipedia, Google Maps Street View redesign, Jun. 10, 2014, wikipedia.com [online], [site visited Nov. 7, 2016]. Available from Internet: <https//en.wikipedia.org/wiki/Google_Maps>.
Snavely et al., “Photo Tourism: Exploring Photo Collections in 3D”, 2006, Particularly see: Figs. 1 (c), 5, Section 5.1, 12 pages.
First Office Action dated Mar. 20, 2018, for Chinese Patent Application No. 201580020984.2.
Related Publications (1)
Number Date Country
20150302633 A1 Oct 2015 US