US20150019625A1 - Providing indoor map data to a client computing device - Google Patents
Providing indoor map data to a client computing device Download PDFInfo
- Publication number
- US20150019625A1 US20150019625A1 US14/167,607 US201414167607A US2015019625A1 US 20150019625 A1 US20150019625 A1 US 20150019625A1 US 201414167607 A US201414167607 A US 201414167607A US 2015019625 A1 US2015019625 A1 US 2015019625A1
- Authority
- US
- United States
- Prior art keywords
- map
- indoor
- data
- indoor map
- client device
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Abandoned
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/01—Input arrangements or combined input and output arrangements for interaction between user and computer
- G06F3/048—Interaction techniques based on graphical user interfaces [GUI]
- G06F3/0484—Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
- G06F3/04847—Interaction techniques to control parameter settings, e.g. interaction with sliders or dials
-
- H04L67/18—
-
- G—PHYSICS
- G09—EDUCATION; CRYPTOGRAPHY; DISPLAY; ADVERTISING; SEALS
- G09B—EDUCATIONAL OR DEMONSTRATION APPLIANCES; APPLIANCES FOR TEACHING, OR COMMUNICATING WITH, THE BLIND, DEAF OR MUTE; MODELS; PLANETARIA; GLOBES; MAPS; DIAGRAMS
- G09B29/00—Maps; Plans; Charts; Diagrams, e.g. route diagram
- G09B29/10—Map spot or coordinate position indicators; Map reading aids
- G09B29/106—Map spot or coordinate position indicators; Map reading aids using electronic means
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C21/00—Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
- G01C21/20—Instruments for performing navigational calculations
- G01C21/206—Instruments for performing navigational calculations specially adapted for indoor navigation
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C21/00—Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
- G01C21/38—Electronic maps specially adapted for navigation; Updating thereof
- G01C21/3804—Creation or updating of map data
- G01C21/3807—Creation or updating of map data characterised by the type of data
- G01C21/383—Indoor data
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C21/00—Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
- G01C21/38—Electronic maps specially adapted for navigation; Updating thereof
- G01C21/3863—Structures of map data
- G01C21/3867—Geometry of map features, e.g. shape points, polygons or for simplified maps
-
- G—PHYSICS
- G01—MEASURING; TESTING
- G01C—MEASURING DISTANCES, LEVELS OR BEARINGS; SURVEYING; NAVIGATION; GYROSCOPIC INSTRUMENTS; PHOTOGRAMMETRY OR VIDEOGRAMMETRY
- G01C21/00—Navigation; Navigational instruments not provided for in groups G01C1/00 - G01C19/00
- G01C21/38—Electronic maps specially adapted for navigation; Updating thereof
- G01C21/3863—Structures of map data
- G01C21/387—Organisation of map data, e.g. version management or database structures
- G01C21/3881—Tile-based structures
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L67/00—Network arrangements or protocols for supporting network services or applications
- H04L67/50—Network services
- H04L67/52—Network services specially adapted for the location of the user terminal
Definitions
- the present disclosure relates to interactive digital maps and, more particularly, to efficiently providing indoor map data for multi-story buildings displayed as part of digital maps on a computing device.
- mapping applications may run on laptop and tablet computers, mobile phones, car navigation systems, hand-held global positioning system (GPS) units, etc. These mapping applications can display various types of geographic data including topographical data, street data, urban transit information, and traffic data, in a two-dimensional (2D) or three-dimensional (3D) format.
- 2D two-dimensional
- 3D three-dimensional
- digital maps usually depict “outdoor” map features such as buildings, roads, bodies of water, etc.
- indoor mapping is also becoming available.
- a digital map that depicts the footprint of an indoor shopping mall at certain zoom levels can also depict the floor plan of the shopping mall, icons for indoor facilities such as restrooms and elevators, and text labels for various businesses.
- indoor map data is stored in a separate database and provided to a client device as a separate layer of data that can be overlaid on a digital map.
- a mapping application executing on the client device renders a digital map with external features such as roads, parks, bodies of water, building footprints, etc. and, when the user zooms in on a building footprint, generates a separate request (possibly to a separate server) to retrieve indoor map data.
- the mapping application prior to receiving the requested indoor data, the mapping application cannot display any information or controls related to the indoor data. For example, the mapping application cannot display a widget for selecting a floor of a multi-floor building.
- a map data server may provide map data to a client device by generating a description of a geographic area that includes outdoor map features including a multi-story building.
- the multi-story building includes a “default” floor.
- the map data server may also provide data to the client device to graphically represent the indoor features of the default floor in the description of the geographic area.
- the indoor map features may be annotated to allow the client device to selectively activate or deactivate the display of the indoor map features.
- a method in a network server may provide map data including outdoor map features and indoor map features to a client device.
- the method may receive, from the client device, a request for map data for a specified geographic area and a specified zoom level and retrieve outdoor map features for the requested geographic area and the zoom level.
- the outdoor map features may correspond to externally visible physical entities.
- the method may also determine that the outdoor map features include a map feature corresponding to a multi-floor building and determine a default floor for the multi-floor building.
- the method may then retrieve indoor map features for the default floor.
- the indoor map features may correspond to physical entities that are disposed on the default floor of the multi-floor building and the indoor map features may each include an indoor map indicator.
- the method also provides the outdoor map features and the indoor map features for the default floor to the client device in response to the received request and selectively displays the indoor map features at the client device based on the indoor map indicator.
- a mapping system is configured to provide map data including outdoor map features and indoor map features to a client device.
- the system may comprise a remote mapping server including a processor and a memory, the memory including instructions executed on the processor.
- a first instruction may receive, from the client device, a request for map data for a specified geographic area and a specified zoom level.
- a second instruction may retrieve outdoor map features for the requested geographic area and the zoom level.
- the outdoor map features may correspond to externally visible physical entities.
- a third instruction may determine that the outdoor map features include a map feature corresponding to a multi-floor building.
- a fourth instruction may determine a default floor for the multi-floor building.
- a fifth instruction may retrieve indoor map features for the default floor.
- the indoor map features may correspond to physical entities, may be disposed on the default floor of the multi-floor building, and may each include an indoor map indicator.
- a sixth instruction may provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request.
- a tangible computer-readable medium may including non-transitory computer readable instructions stored thereon for providing map data including outdoor map features and indoor map features to a client device.
- a first instruction may receive, from the client device, a request for map data for a specified geographic area and a specified zoom level.
- a second instruction may retrieve outdoor map features for the requested geographic area and the zoom level.
- the outdoor map features may correspond to externally visible physical entities.
- a third instruction may determine that the outdoor map features include a map feature corresponding to a multi-floor building.
- a fourth instruction may determine a default floor for the multi-floor building.
- a fifth instruction may retrieve indoor map features for the default floor.
- the indoor map features may correspond to physical entities, may be disposed on the default floor of the multi-floor building, and may each include an indoor map indicator.
- a sixth instruction may provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request.
- a computer apparatus may provide map data including outdoor map features and indoor map features to a client device.
- the apparatus may include means to receive, from the client device, a request for map data for a specified geographic area and a specified zoom level and means to retrieve outdoor map features for the requested geographic area and the zoom level.
- the outdoor map features may correspond to externally visible physical entities.
- the apparatus may also include means to determine that the outdoor map features include a map feature corresponding to a multi-floor building and determine a default floor for the multi-floor building.
- the apparatus may further include means to retrieve indoor map features for the default floor.
- the indoor map features may correspond to physical entities that are disposed on the default floor of the multi-floor building and the indoor map features may each include an indoor map indicator.
- the apparatus may also include means to provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request, and means to selectively display the indoor map features at the client device based on the indoor map indicator.
- FIG. 1 is a block diagram of an example system in which techniques for providing indoor map data to a client device are implemented
- FIG. 2 is a block diagram of an example description of a map tile including multiple map features and metadata with indoor information for some of the map features, which a map data server can transmit to a client device;
- FIG. 3 schematically illustrates a map tile that includes both outdoor map features and indoor map features, which a map data server can transmit to a client device;
- FIG. 4 a is an exemplary flow diagram of a computer-implemented method for providing map data with an overview of available indoor map data to a client device;
- FIG. 4 b is an exemplary user interface for a mapping module executing on a client computing device displaying an overview of available indoor map data
- FIG. 5 is a flow diagram of an example method for providing indoor map data as part of a base map.
- a map data server provides certain information about the available indoor map data as metadata accompanying map data for drawing a base map (i.e., the foundational layer of a digital map for a given zoom level).
- map data can include vectors for drawing a footprint of a building
- the metadata can include an indication of how many floors the building has, and for how many of these floors detailed indoor map data is available.
- a mapping application running on the client can use this indication to properly display a floor picker (e.g., a widget that displays selectable floor numbers for activating a display of the corresponding floor).
- the metadata accompanying map data can include a bounding box, or a bounding polygon, for one or more floors.
- the mapping application can use these bounding shapes to properly reposition the viewport as map data for a new floor is being loaded, for example.
- the metadata can include names of floors to appear as floors listed in an elevator of the building, for example. More generally, the metadata can include information that helps the mapping application make transitions from an external view of a building to the indoor view of the building, as well as make transitions between floors more smooth.
- Metadata in some implementations accompanies particular map features.
- a building can be described as an individual map feature.
- the description of the map feature can include the external geometry of the building in a vector graphics format, textures to be applied to the building geometry, text labels, etc.
- Metadata accompanying this map feature can include an overview of the available indoor data discussed above.
- a mapping application of the present disclosure can receive indoor floor data for the default floor of a multi-floor building as part of a base map.
- the map data server in this case can annotate the indoor floor data to allow the mapping application on the client device to easily remove this indoor map data, apply a different style to the indoor map data, or other actions.
- the base map can include, among other map features, an external outline of a large indoor shopping mall.
- the indoor floor data can include outlines of stores, labels, icons indicating the locations of elevators and restrooms, and other indoor features.
- the server may specify that the feature is an indoor feature associated with a certain floor.
- FIG. 1 an example system in which a map data server can provide indoor map information to a client device is illustrated FIG. 1 , example formats and uses of this information are schematically illustrated in FIGS. 2 and 3 , and flow diagrams of example methods for exchanging indoor map information are illustrated in FIGS. 4 and 5 .
- a system 10 includes a computing device 12 coupled to a map server 14 via a communication network 16 .
- the computing device 12 can be, for example, a laptop computer, a tablet computer, a smartphone, etc.
- the computing device 12 includes a central processing unit (CPU) 20 , a graphics processing unit (GPU) 22 , a computer-readable memory 24 , a network interface 118 , and a user interface 120 including a touch interface.
- CPU central processing unit
- GPU graphics processing unit
- the touch interface can include a touchpad over which the user moves his or her fingers while looking at a separately provided screen, a touchscreen where the user places his or her fingers directly over the image being manipulated or over a displayed control being activated (e.g., a displayed keyboard), etc.
- the memory 24 is a computer-readable non-transitory storage device that may include both persistent (e.g., a hard disk) and non-persistent (e.g., RAM) memory components, and may store instructions executable on the CPU 20 and/or the GPU 22 that make up a mapping software module 40 and map data 42 on which the mapping module 40 operates.
- the mapping software module 40 includes an indoor data management module 44 that allows users to easily inspect internal features of multi-story buildings.
- the mapping software module 40 operates as a separately executable software application, a plugin that extends the functionality of another software application such as a web browser, an application programming interface (API) invokable by a software application, etc.
- the instructions that make up the mapping software module 40 may be compiled and executable on the CPU 20 and/or the GPU 22 directly, or not compiled and interpreted by the CPU 20 at runtime.
- the indoor data management module 44 may be provided as an integral part of the mapping software module 40 or as a separately installable and downloadable component.
- the map data 42 may be in a raster format, such as Portable Network Graphics (PNG), a vector graphics format (based on mathematical descriptions of geometric shapes), or any other suitable format.
- the map data 42 in some cases is divided into map tiles, or portions of a map image having a certain fixed size, such as 256 by 256 pixels.
- the mapping module 40 receives the map data 42 from the map server 14 , renders a map image based on the map data, and causes the map image to be displayed via the user interface 30 .
- the mapping module 40 renders the map image by selecting and combining the proper rasterized tiles.
- the mapping module 40 interprets the descriptions of various shapes to generate the corresponding raster images.
- the mapping module 40 also adjusts the displayed image and requests new map data, when necessary, in response to user input received via the user interface 30 . More specifically, the user may change the zoom level, pan across the map, select a different map type (e.g., traffic map, terrain map), and otherwise interact with the map.
- the map server 14 receives a request that specifies the geographic area, the zoom level, and the map type.
- the map server 14 retrieves outdoor map data and indoor map data from an outdoor map database 50 and an indoor map database 52 , respectively.
- the map server 14 then provides the outdoor map data, the indoor map data, and appropriate indications of how certain portions of the outdoor map data and the indoor map data are linked, to the computing device 12 as part of the map data 42 .
- indoor and outdoor map data can be stored in a single database and/or provided by a common server.
- outdoor map data may specify or define graphic representations of individual map elements representing such physical entities as roads, parks, bodies of water, external walls of buildings, and other natural and artificial objects visible outside, e.g., from above or at a street level.
- map elements typically are embedded into the same image.
- Outdoor map data also may include text-based data for displaying various labels such as street names or names of landmarks.
- outdoor map data may be used by a computing device 12 to generate 2D images or 3D images, and may include schematic data, photographic images, or both.
- Indoor map data may specify or define internal features of buildings such as the layout of internal walls or dividers, names of people, businesses, and organizations occupying different portions of a building, locations of elevators, escalators, restrooms, etc.
- the indoor map data may specify internal features on a per-floor basis.
- indoor map data may include both graphics content and non-graphics (e.g., text) content, and the graphics content may include schematic illustrations, photographic images, interactive and non-interactive icons, etc.
- Certain portions of the outdoor map data may be logically linked to respective portions of indoor map data.
- certain map elements displayed on a map may be linked to indoor data that typically is not displayed on the map without an additional user request.
- certain map elements may be associated with additional map data that is not part of the map image typically displayed for the specified geographic region, map type, and zoom level.
- the map server 14 can provide outdoor map data as a collection of separate data structures, each containing a vector-based description of a map element, text-based label data, and metadata that further contains a unique identifier of another data structure storing the corresponding indoor map data.
- the mapping software module 40 can display the outdoor map data and provide interactive controls for activating the display of relevant indoor map data.
- the map server 14 provides, as part of outdoor map data, external representations of buildings in the form of low-detail three-dimensional (3D) outlines.
- the mapping software module 40 superimposes these 3D outlines over the two-dimensional (2D) map.
- the map server 14 provides 3D mesh descriptions of buildings along with photographic imagery for texturing the corresponding 3D meshes. Using this type of map data, the mapping software module 40 can generate realistic, highly detailed external representations of buildings.
- the map server 14 provides merely 2D outlines, or “footprints” of buildings on a 2D map. A user can tap or click on these 2D or 3D external representations of buildings to instruct the mapping software module 40 to display the internal features of the buildings in an expanded format.
- the map server 14 may include a processor 60 and a memory 62 that stores a base map layer generator 63 and an indoor map data generator 64 made up of instructions executable on the processor 60 .
- the computing device 12 and the map server 14 may communicate in a client-server mode, where the computing device 12 sends requests for map data to the map server 14 , and the map server 14 provides map data in response to these requests.
- the base map layer generator 63 in operation causes instructions stored in a memory and executed on a processor to receive requests for map data from the computing device 12 , identify and retrieve the requisite map data from the outdoor map database 50 and/or the indoor map database 52 , format response messages that contain the map data, and cause the response messages to be transmitted to the computing device 12 via the network 16 .
- the network 16 may be a wide area network (WAN) such as the Internet, a local area network (LAN), or any other suitable type of a computer network.
- WAN wide area network
- LAN local area network
- the base map layer generator 63 includes map data for the default floor in the description of tiles that make a base map.
- the indoor map data generator 64 generates metadata including an overview of the available indoor map data for some of the map features.
- the map data server 14 can include one or both of the components 63 and 64 .
- FIG. 1 illustrates the map server 14 as only one instance of a server device.
- the map server 14 may include a group of one or more map server devices that are each equipped with one or more processors and capable of operating independently of the other map server devices.
- Map server devices operating in such a group can process requests from the computing device 12 individually (e.g., based on availability), in a distributed manner where one operation associated with processing a request is performed on one map server device while another operation associated with processing the same request is performed on another map server device, or according to any other suitable technique.
- the term “map server” may refer to an individual map server device or to a group of two or more map server devices.
- FIG. 2 is a block diagram of an example description of a map tile 100 that includes multiple map features 102 , 104 , etc.
- the map data server 14 transmits map data to the client device 12 for rendering a digital map using the map tile 100 as a communication unit.
- map data need not be divided into map tiles, and any other grouping of map data can be used.
- the map tile 100 includes metadata for some of the map features.
- metadata 106 accompanies the map feature 102 .
- the map feature 102 includes a description of geometry 110 (e.g., in a vector graphics format) and a style identifier 112 .
- the style identifier 112 can store an identifier of a style, the definition of which (line width, fill color, outline color, etc.) is provided elsewhere in the map tile 100 or even in a separate communication unit sent to the client device.
- the metadata 106 stores a number of floors indicator 120 (e.g., “6,” “25”), floor names 122 (e.g., “ground floor,” “first floor”), and bounding boxes 124 and 126 for floors N and M, respectively. More generally, the metadata 106 can include more or less information.
- FIG. 3 schematically illustrates a map tile 150 that includes both outdoor map features 160 and indoor map features 170 which the map data server 14 can transmit to the client device 12 and which the client device 12 can subsequently render.
- the map data server 14 can provide the outdoor map features 160 (i.e., buildings 160 A, 160 B, 160 C, 160 D, 160 E) and the indoor map features 170 (i.e., stores, floors, internal building structures, or other indoor features 170 A, 170 B, and 170 C) as part of a base map tile.
- the client device 12 can overlay traffic, weather, transit, and other types of data on the base map tile 150 .
- the technique of FIG. 3 can be implemented in a communication system together with the technique of FIG. 2 , or these two techniques can be implemented independently in respective different embodiments of a communication system.
- Each of the indoor map features 170 can be provided in a vector graphics format, similar to the outdoor map features 160 .
- the map tile 150 can include labels 180 for indoor map features.
- labels 190 and 192 identify street-level features. More generally, the map tile 150 can include various types of data for rendering an indoor digital map.
- the map data server 14 can select the indoor map features 170 based on the default configuration of the building with the footprint represented by the map feature 160 A.
- the building represented by the map feature 160 A can be a four-story shopping mall, with separate sets of map features defined for each floor.
- the indoor map database 52 (see FIG. 1 ) can store an indication that the default floor for this building is the second floor, for example.
- the default floor of a building need not be the ground floor as the ground floor may be occupied by a garage that is relatively uninteresting to users.
- the map data server 14 can (i) query the indoor map database 52 to determine that the ground floor is the default floor, (ii) query the indoor map database 52 to retrieve indoor map features specific to the ground floor of the building (in this case, the indoor map features 170 and the label 180 ), and (iii) incorporate the indoor map features 170 and the label 180 into the base map that also includes the outdoor map features 160 .
- a server (which may be the map data server 14 or another server) can combine outdoor map data with default-floor indoor map data ahead of time, for each map tile.
- map tiles are pre-computed to enable the map data server 14 to more quickly provide map tiles to clients upon request.
- the mapping module 40 can send the corresponding request for floor data for another floor that is not the default floor to the map data server 14 .
- the server may then retrieve the indoor map features for the new floor.
- the indoor data management module 44 can overlay the new floor data over the base map or remove and replace the individual map features 170 .
- indoor map features 170 A, 170 B, and 170 C and labels 180 are provided with indoor map data indicators 194 .
- the indoor data management module 44 can use the indicator 194 to manage indoor map features separately and render these features in a different style, highlight indoor map features without highlighting other map features in response to a user request or an automated event (e.g., a search query), apply other visual effects, etc.
- the indoor map indicators 194 may also correspond to each floor of a building (i.e., per floor) or to the building itself (i.e., per building) so that indoor data for one building may be highlighted or replaced with a different floor independent of indoor data for other nearby buildings.
- the map data server 14 on the one hand allows the mapping module 40 to immediately display richer content on the client device 12 and, on the other hand, allows the mapping module 40 to easily turn off the display of indoor map data, highlight the indoor map data, transition from one floor to another, etc.
- FIG. 4 a is a flow diagram of an example method 200 for providing map data with an overview of available indoor map data to a client device.
- the method 200 can be implemented as a set of instructions stored on a computer-readable memory and executable on one or more processors.
- the method 200 can be implemented in the indoor map data generator 64 .
- the method 200 is executed in response to receiving a request for map data corresponding to a specified geographic area and a specified zoom level.
- map features that belong to a map tile are identified. This step can be implemented in a batch process, if desired.
- the map features identified at block 202 are outdoor map features representing physical entities visible from a street or otherwise from the outside.
- the identified map features are included in a description of a map tile at block 204 .
- the vector graphics format can be used, for example.
- an overview of the available indoor map data for one or more features identified at block 202 is generated.
- the overview can include an indication of the number of floors, a description of a bounding box for one or more floors, names of the floors, etc.
- the overview of the available indoor map data is included in the metadata accompanying map features.
- the map data and the metadata then are provided to a client device at block 210 .
- FIG. 4 b is an example of a user interface 220 for the mapping module 40 as displayed by a client device 12 after being provided to the client device at block 210 .
- the user interface may display both the map data (e.g., map tile 150 ) and the metadata 106 .
- the mapping module 40 may cause the metadata 106 to be displayed as the overview or “widget” 222 including indications of which floors 224 of a selected building (e.g., building 160 A which includes indoor map features) are available for viewing as a map.
- the widget 222 may also include an indication of a default floor 226 as indicated in the metadata 106 provided with the map data at block 210 .
- the widget 222 may include a slider bar or other scrolling feature for a user to manipulate and display other available floor or indoor feature selections 224 .
- FIG. 5 depicts a flow diagram of an example method 250 for providing indoor map data as part of a base map.
- the method 250 in whole or in part, can be stored as tangible computer-executable instructions of the base map layer generator 63 within the memory 62 of the map data server 14 and executed by the processor 60 , for example.
- the method 250 in whole or in part, can be stored as tangible computer-executable instructions of the mapping module 40 within the memory 24 of the client device 12 and executed by the CPU 20 or GPU 22 , for example.
- the method 250 can be stored as a combination of tangible computer-executable instructions within the memory 62 of the map data server 14 and/or the client device 12 and respectively executed by the processor 60 , the CPU 20 , and/or the GPU 22 .
- the method 250 also can be implemented as a set of instructions stored on a computer-readable memory and executable on one or more processors.
- the method 250 begins at block 252 , where outdoor map features 170 , indoor map features 160 , and metadata 106 for a geographic area are included in a base map for a certain map tile 150 ( FIG. 4 b ) and received and displayed at a client device.
- the method 250 identifies a multi-floor building 160 A or other outdoor feature in a geographic region corresponding to the map tile 150 .
- the method 250 uses the received metadata 106 to determine the default floor 226 of the structure 160 A.
- a base map includes a map tile 150 and building 160 A.
- the metadata 106 may indicate that the first floor of the building 160 A is the default floor and the method 250 may cause the indication for the default floor 226 to appear in the widget 222 .
- the method 250 may retrieve indoor map data for the default floor 226 from a database (block 258 ) and included in the map tile ( 260 ). Blocks 254 - 260 can be executed multiple times if the map tile includes multiple multi-floor structures for which indoor map data is available.
- Modules may constitute either software modules (e.g., code stored on a machine-readable medium) or hardware modules.
- a hardware module is tangible unit capable of performing certain operations and may be configured or arranged in a certain manner.
- one or more computer systems e.g., a standalone, client or server computer system
- one or more hardware modules of a computer system e.g., a processor or a group of processors
- software e.g., an application or application portion
- a hardware module may be implemented mechanically or electronically.
- a hardware module may comprise dedicated circuitry or logic that is permanently configured (e.g., as a special-purpose processor, such as a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC)) to perform certain operations.
- a hardware module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software to perform certain operations. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
- the term hardware should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein.
- hardware modules are temporarily configured (e.g., programmed)
- each of the hardware modules need not be configured or instantiated at any one instance in time.
- the hardware modules comprise a general-purpose processor configured using software
- the general-purpose processor may be configured as respective different hardware modules at different times.
- Software may accordingly configure a processor, for example, to constitute a particular hardware module at one instance of time and to constitute a different hardware module at a different instance of time.
- Hardware and software modules can provide information to, and receive information from, other hardware and/or software modules. Accordingly, the described hardware modules may be regarded as being communicatively coupled. Where multiple of such hardware or software modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the hardware or software modules. In embodiments in which multiple hardware modules or software are configured or instantiated at different times, communications between such hardware or software modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple hardware or software modules have access. For example, one hardware or software module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further hardware or software module may then, at a later time, access the memory device to retrieve and process the stored output. Hardware and software modules may also initiate communications with input or output devices, and can operate on a resource (e.g., a collection of information).
- a resource e.g., a collection of information
- processors may be temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions.
- the modules referred to herein may, in some example embodiments, comprise processor-implemented modules.
- the methods or routines described herein may be at least partially processor-implemented. For example, at least some of the operations of a method may be performed by one or processors or processor-implemented hardware modules. The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the processor or processors may be located in a single location (e.g., within a home environment, an office environment or as a server farm), while in other embodiments the processors may be distributed across a number of locations.
- the one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as an SaaS. For example, at least some of the operations may be performed by a group of computers (as examples of machines including processors), these operations being accessible via a network (e.g., the Internet) and via one or more appropriate interfaces (e.g., application program interfaces (APIs).)
- a network e.g., the Internet
- APIs application program interfaces
- the performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines.
- the one or more processors or processor-implemented modules may be located in a single geographic location (e.g., within a home environment, an office environment, or a server farm). In other example embodiments, the one or more processors or processor-implemented modules may be distributed across a number of geographic locations.
- an “algorithm” or a “routine” is a self-consistent sequence of operations or similar processing leading to a desired result.
- algorithms, routines and operations involve physical manipulation of physical quantities. Typically, but not necessarily, such quantities may take the form of electrical, magnetic, or optical signals capable of being stored, accessed, transferred, combined, compared, or otherwise manipulated by a machine.
- any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment.
- the appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
- Coupled and “connected” along with their derivatives.
- some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact.
- the term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other.
- the embodiments are not limited in this context.
- the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion.
- a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus.
- “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
Landscapes
- Engineering & Computer Science (AREA)
- Radar, Positioning & Navigation (AREA)
- Remote Sensing (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Automation & Control Theory (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Educational Administration (AREA)
- Educational Technology (AREA)
- Business, Economics & Management (AREA)
- Mathematical Physics (AREA)
- Signal Processing (AREA)
- Computer Networks & Wireless Communication (AREA)
- Databases & Information Systems (AREA)
- Geometry (AREA)
- Human Computer Interaction (AREA)
- Navigation (AREA)
- Instructional Devices (AREA)
- Processing Or Creating Images (AREA)
Abstract
A map data server may provide map data to a client device by generating a description of a geographic area that includes outdoor map features including a multi-story building. The multi-story building includes a “default” floor. The map data server may also provide data to the client device to graphically represent the indoor features of the default floor in the description of the geographic area. The indoor map features may be annotated to allow the client device to selectively activate or deactivate the display of the indoor map features.
Description
- This application claims the benefit of U.S. Provisional Patent Application No. 61/844,300 that was filed on Jul. 9, 2013 the disclosure of which is hereby incorporated herein by reference in its entirety for all purposes.
- The present disclosure relates to interactive digital maps and, more particularly, to efficiently providing indoor map data for multi-story buildings displayed as part of digital maps on a computing device.
- The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
- A wide variety of computing devices, including many portable devices, support software applications that display interactive digital maps (“mapping applications”). For example, mapping applications may run on laptop and tablet computers, mobile phones, car navigation systems, hand-held global positioning system (GPS) units, etc. These mapping applications can display various types of geographic data including topographical data, street data, urban transit information, and traffic data, in a two-dimensional (2D) or three-dimensional (3D) format.
- Although digital maps usually depict “outdoor” map features such as buildings, roads, bodies of water, etc., indoor mapping is also becoming available. For example, a digital map that depicts the footprint of an indoor shopping mall at certain zoom levels can also depict the floor plan of the shopping mall, icons for indoor facilities such as restrooms and elevators, and text labels for various businesses.
- In a typical system, indoor map data is stored in a separate database and provided to a client device as a separate layer of data that can be overlaid on a digital map. A mapping application executing on the client device renders a digital map with external features such as roads, parks, bodies of water, building footprints, etc. and, when the user zooms in on a building footprint, generates a separate request (possibly to a separate server) to retrieve indoor map data. As a result, prior to receiving the requested indoor data, the mapping application cannot display any information or controls related to the indoor data. For example, the mapping application cannot display a widget for selecting a floor of a multi-floor building.
- The features and advantages described in this summary and the following detailed description are not all-inclusive. Many additional features and advantages will be apparent to one of ordinary skill in the art in view of the drawings, specification, and claims hereof. Additionally, other embodiments may omit one or more (or all) of the features and advantages described in this summary.
- A map data server may provide map data to a client device by generating a description of a geographic area that includes outdoor map features including a multi-story building. The multi-story building includes a “default” floor. The map data server may also provide data to the client device to graphically represent the indoor features of the default floor in the description of the geographic area. The indoor map features may be annotated to allow the client device to selectively activate or deactivate the display of the indoor map features.
- In a first embodiment, a method in a network server may provide map data including outdoor map features and indoor map features to a client device. The method may receive, from the client device, a request for map data for a specified geographic area and a specified zoom level and retrieve outdoor map features for the requested geographic area and the zoom level. The outdoor map features may correspond to externally visible physical entities. The method may also determine that the outdoor map features include a map feature corresponding to a multi-floor building and determine a default floor for the multi-floor building. The method may then retrieve indoor map features for the default floor. The indoor map features may correspond to physical entities that are disposed on the default floor of the multi-floor building and the indoor map features may each include an indoor map indicator. The method also provides the outdoor map features and the indoor map features for the default floor to the client device in response to the received request and selectively displays the indoor map features at the client device based on the indoor map indicator.
- In a second embodiment, a mapping system is configured to provide map data including outdoor map features and indoor map features to a client device. The system may comprise a remote mapping server including a processor and a memory, the memory including instructions executed on the processor. A first instruction may receive, from the client device, a request for map data for a specified geographic area and a specified zoom level. A second instruction may retrieve outdoor map features for the requested geographic area and the zoom level. The outdoor map features may correspond to externally visible physical entities. A third instruction may determine that the outdoor map features include a map feature corresponding to a multi-floor building. A fourth instruction may determine a default floor for the multi-floor building. A fifth instruction may retrieve indoor map features for the default floor. The indoor map features may correspond to physical entities, may be disposed on the default floor of the multi-floor building, and may each include an indoor map indicator. A sixth instruction may provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request.
- In a third embodiment, a tangible computer-readable medium may including non-transitory computer readable instructions stored thereon for providing map data including outdoor map features and indoor map features to a client device. A first instruction may receive, from the client device, a request for map data for a specified geographic area and a specified zoom level. A second instruction may retrieve outdoor map features for the requested geographic area and the zoom level. The outdoor map features may correspond to externally visible physical entities. A third instruction may determine that the outdoor map features include a map feature corresponding to a multi-floor building. A fourth instruction may determine a default floor for the multi-floor building. A fifth instruction may retrieve indoor map features for the default floor. The indoor map features may correspond to physical entities, may be disposed on the default floor of the multi-floor building, and may each include an indoor map indicator. A sixth instruction may provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request.
- In a fourth embodiment, a computer apparatus may provide map data including outdoor map features and indoor map features to a client device. The apparatus may include means to receive, from the client device, a request for map data for a specified geographic area and a specified zoom level and means to retrieve outdoor map features for the requested geographic area and the zoom level. The outdoor map features may correspond to externally visible physical entities. The apparatus may also include means to determine that the outdoor map features include a map feature corresponding to a multi-floor building and determine a default floor for the multi-floor building. The apparatus may further include means to retrieve indoor map features for the default floor. The indoor map features may correspond to physical entities that are disposed on the default floor of the multi-floor building and the indoor map features may each include an indoor map indicator. The apparatus may also include means to provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request, and means to selectively display the indoor map features at the client device based on the indoor map indicator.
-
FIG. 1 is a block diagram of an example system in which techniques for providing indoor map data to a client device are implemented; -
FIG. 2 is a block diagram of an example description of a map tile including multiple map features and metadata with indoor information for some of the map features, which a map data server can transmit to a client device; -
FIG. 3 schematically illustrates a map tile that includes both outdoor map features and indoor map features, which a map data server can transmit to a client device; -
FIG. 4 a is an exemplary flow diagram of a computer-implemented method for providing map data with an overview of available indoor map data to a client device; -
FIG. 4 b is an exemplary user interface for a mapping module executing on a client computing device displaying an overview of available indoor map data; and -
FIG. 5 is a flow diagram of an example method for providing indoor map data as part of a base map. - The figures depict embodiments of the present invention for purposes of illustration only. One skilled in the art will readily recognize from the following discussion that alternate embodiments of the structures and methods illustrated herein may be employed without departing from the principles of the invention described herein.
- A map data server provides certain information about the available indoor map data as metadata accompanying map data for drawing a base map (i.e., the foundational layer of a digital map for a given zoom level). For example, map data can include vectors for drawing a footprint of a building, and the metadata can include an indication of how many floors the building has, and for how many of these floors detailed indoor map data is available. A mapping application running on the client can use this indication to properly display a floor picker (e.g., a widget that displays selectable floor numbers for activating a display of the corresponding floor). Further, the metadata accompanying map data can include a bounding box, or a bounding polygon, for one or more floors. The mapping application can use these bounding shapes to properly reposition the viewport as map data for a new floor is being loaded, for example. Still further, the metadata can include names of floors to appear as floors listed in an elevator of the building, for example. More generally, the metadata can include information that helps the mapping application make transitions from an external view of a building to the indoor view of the building, as well as make transitions between floors more smooth.
- As discussed in more detail below, metadata in some implementations accompanies particular map features. Thus, for example, a building can be described as an individual map feature. The description of the map feature can include the external geometry of the building in a vector graphics format, textures to be applied to the building geometry, text labels, etc. Metadata accompanying this map feature can include an overview of the available indoor data discussed above.
- Additionally, a mapping application of the present disclosure can receive indoor floor data for the default floor of a multi-floor building as part of a base map. The map data server in this case can annotate the indoor floor data to allow the mapping application on the client device to easily remove this indoor map data, apply a different style to the indoor map data, or other actions. For example, the base map can include, among other map features, an external outline of a large indoor shopping mall. The indoor floor data can include outlines of stores, labels, icons indicating the locations of elevators and restrooms, and other indoor features. For each indoor feature, the server may specify that the feature is an indoor feature associated with a certain floor.
- These techniques are discussed in more detail below with reference to
FIGS. 1-5 . In particular, an example system in which a map data server can provide indoor map information to a client device is illustratedFIG. 1 , example formats and uses of this information are schematically illustrated inFIGS. 2 and 3 , and flow diagrams of example methods for exchanging indoor map information are illustrated inFIGS. 4 and 5 . - Referring first to
FIG. 1 , asystem 10 includes acomputing device 12 coupled to amap server 14 via acommunication network 16. Thecomputing device 12 can be, for example, a laptop computer, a tablet computer, a smartphone, etc. In the embodiment illustrated inFIG. 1 , thecomputing device 12 includes a central processing unit (CPU) 20, a graphics processing unit (GPU) 22, a computer-readable memory 24, anetwork interface 118, and auser interface 120 including a touch interface. In various implementations, the touch interface can include a touchpad over which the user moves his or her fingers while looking at a separately provided screen, a touchscreen where the user places his or her fingers directly over the image being manipulated or over a displayed control being activated (e.g., a displayed keyboard), etc. Thememory 24 is a computer-readable non-transitory storage device that may include both persistent (e.g., a hard disk) and non-persistent (e.g., RAM) memory components, and may store instructions executable on theCPU 20 and/or theGPU 22 that make up amapping software module 40 andmap data 42 on which themapping module 40 operates. Themapping software module 40 includes an indoordata management module 44 that allows users to easily inspect internal features of multi-story buildings. - The
mapping software module 40 according to various implementations operates as a separately executable software application, a plugin that extends the functionality of another software application such as a web browser, an application programming interface (API) invokable by a software application, etc. The instructions that make up themapping software module 40 may be compiled and executable on theCPU 20 and/or theGPU 22 directly, or not compiled and interpreted by theCPU 20 at runtime. Further, the indoordata management module 44 may be provided as an integral part of themapping software module 40 or as a separately installable and downloadable component. - Depending on the implementation, the
map data 42 may be in a raster format, such as Portable Network Graphics (PNG), a vector graphics format (based on mathematical descriptions of geometric shapes), or any other suitable format. Themap data 42 in some cases is divided into map tiles, or portions of a map image having a certain fixed size, such as 256 by 256 pixels. In operation, themapping module 40 receives themap data 42 from themap server 14, renders a map image based on the map data, and causes the map image to be displayed via the user interface 30. When themobile device 12 receives themap data 42 already rasterized, themapping module 40 renders the map image by selecting and combining the proper rasterized tiles. However, if themap data 42 is in a vector graphics format, themapping module 40 interprets the descriptions of various shapes to generate the corresponding raster images. Themapping module 40 also adjusts the displayed image and requests new map data, when necessary, in response to user input received via the user interface 30. More specifically, the user may change the zoom level, pan across the map, select a different map type (e.g., traffic map, terrain map), and otherwise interact with the map. - In an example scenario, the
map server 14 receives a request that specifies the geographic area, the zoom level, and the map type. In response to the received request, themap server 14 retrieves outdoor map data and indoor map data from anoutdoor map database 50 and anindoor map database 52, respectively. Themap server 14 then provides the outdoor map data, the indoor map data, and appropriate indications of how certain portions of the outdoor map data and the indoor map data are linked, to thecomputing device 12 as part of themap data 42. In another implementation, however, indoor and outdoor map data can be stored in a single database and/or provided by a common server. - When provided in a vector graphics format, outdoor map data may specify or define graphic representations of individual map elements representing such physical entities as roads, parks, bodies of water, external walls of buildings, and other natural and artificial objects visible outside, e.g., from above or at a street level. In a raster format, map elements typically are embedded into the same image. Outdoor map data also may include text-based data for displaying various labels such as street names or names of landmarks. In general, outdoor map data may be used by a
computing device 12 to generate 2D images or 3D images, and may include schematic data, photographic images, or both. - Indoor map data may specify or define internal features of buildings such as the layout of internal walls or dividers, names of people, businesses, and organizations occupying different portions of a building, locations of elevators, escalators, restrooms, etc. For multi-story buildings, the indoor map data may specify internal features on a per-floor basis. Similar to outdoor map data, indoor map data may include both graphics content and non-graphics (e.g., text) content, and the graphics content may include schematic illustrations, photographic images, interactive and non-interactive icons, etc.
- Certain portions of the outdoor map data may be logically linked to respective portions of indoor map data. In particular, certain map elements displayed on a map may be linked to indoor data that typically is not displayed on the map without an additional user request. In other words, certain map elements may be associated with additional map data that is not part of the map image typically displayed for the specified geographic region, map type, and zoom level. Referring to the
map data 42, themap server 14 can provide outdoor map data as a collection of separate data structures, each containing a vector-based description of a map element, text-based label data, and metadata that further contains a unique identifier of another data structure storing the corresponding indoor map data. If the outdoor map data included in themap data 42 is rasterized, the unique identifier of a data structure storing indoor map data can be provided for a particular set of coordinates in the raster image. In either case, themapping software module 40 can display the outdoor map data and provide interactive controls for activating the display of relevant indoor map data. - As a more specific example, according to one implementation, the
map server 14 provides, as part of outdoor map data, external representations of buildings in the form of low-detail three-dimensional (3D) outlines. Themapping software module 40 superimposes these 3D outlines over the two-dimensional (2D) map. In another implementation, themap server 14 provides 3D mesh descriptions of buildings along with photographic imagery for texturing the corresponding 3D meshes. Using this type of map data, themapping software module 40 can generate realistic, highly detailed external representations of buildings. In yet another implementation, themap server 14 provides merely 2D outlines, or “footprints” of buildings on a 2D map. A user can tap or click on these 2D or 3D external representations of buildings to instruct themapping software module 40 to display the internal features of the buildings in an expanded format. - With continued reference to
FIG. 1 , themap server 14 may include aprocessor 60 and amemory 62 that stores a basemap layer generator 63 and an indoormap data generator 64 made up of instructions executable on theprocessor 60. Thecomputing device 12 and themap server 14 may communicate in a client-server mode, where thecomputing device 12 sends requests for map data to themap server 14, and themap server 14 provides map data in response to these requests. More particularly, the basemap layer generator 63 in operation causes instructions stored in a memory and executed on a processor to receive requests for map data from thecomputing device 12, identify and retrieve the requisite map data from theoutdoor map database 50 and/or theindoor map database 52, format response messages that contain the map data, and cause the response messages to be transmitted to thecomputing device 12 via thenetwork 16. Thenetwork 16 may be a wide area network (WAN) such as the Internet, a local area network (LAN), or any other suitable type of a computer network. - According to the implementations discussed below, the base
map layer generator 63 includes map data for the default floor in the description of tiles that make a base map. The indoormap data generator 64 generates metadata including an overview of the available indoor map data for some of the map features. Depending on the implementation, themap data server 14 can include one or both of thecomponents - For simplicity,
FIG. 1 illustrates themap server 14 as only one instance of a server device. However, according to some implementations, themap server 14 may include a group of one or more map server devices that are each equipped with one or more processors and capable of operating independently of the other map server devices. Map server devices operating in such a group can process requests from thecomputing device 12 individually (e.g., based on availability), in a distributed manner where one operation associated with processing a request is performed on one map server device while another operation associated with processing the same request is performed on another map server device, or according to any other suitable technique. For the purposes of this discussion, the term “map server” may refer to an individual map server device or to a group of two or more map server devices. -
FIG. 2 is a block diagram of an example description of amap tile 100 that includes multiple map features 102, 104, etc. In an example scenario, themap data server 14 transmits map data to theclient device 12 for rendering a digital map using themap tile 100 as a communication unit. In general, however, map data need not be divided into map tiles, and any other grouping of map data can be used. - The
map tile 100 includes metadata for some of the map features. In the illustrated example,metadata 106 accompanies themap feature 102. Themap feature 102 includes a description of geometry 110 (e.g., in a vector graphics format) and astyle identifier 112. For example, thestyle identifier 112 can store an identifier of a style, the definition of which (line width, fill color, outline color, etc.) is provided elsewhere in themap tile 100 or even in a separate communication unit sent to the client device. Themetadata 106 stores a number of floors indicator 120 (e.g., “6,” “25”), floor names 122 (e.g., “ground floor,” “first floor”), and boundingboxes metadata 106 can include more or less information. - Next,
FIG. 3 schematically illustrates amap tile 150 that includes both outdoor map features 160 and indoor map features 170 which themap data server 14 can transmit to theclient device 12 and which theclient device 12 can subsequently render. More specifically, themap data server 14 can provide the outdoor map features 160 (i.e.,buildings indoor features client device 12 can overlay traffic, weather, transit, and other types of data on thebase map tile 150. It is noted that the technique ofFIG. 3 can be implemented in a communication system together with the technique ofFIG. 2 , or these two techniques can be implemented independently in respective different embodiments of a communication system. - Each of the indoor map features 170 can be provided in a vector graphics format, similar to the outdoor map features 160. In addition to shapes representing internal hallways, wall dividers, rooms, etc., the
map tile 150 can includelabels 180 for indoor map features. By contrast, labels 190 and 192 identify street-level features. More generally, themap tile 150 can include various types of data for rendering an indoor digital map. - The
map data server 14 can select the indoor map features 170 based on the default configuration of the building with the footprint represented by themap feature 160A. For example, the building represented by themap feature 160A can be a four-story shopping mall, with separate sets of map features defined for each floor. The indoor map database 52 (seeFIG. 1 ) can store an indication that the default floor for this building is the second floor, for example. The default floor of a building need not be the ground floor as the ground floor may be occupied by a garage that is relatively uninteresting to users. Themap data server 14 can (i) query theindoor map database 52 to determine that the ground floor is the default floor, (ii) query theindoor map database 52 to retrieve indoor map features specific to the ground floor of the building (in this case, the indoor map features 170 and the label 180), and (iii) incorporate the indoor map features 170 and thelabel 180 into the base map that also includes the outdoor map features 160. - In another implementation, a server (which may be the
map data server 14 or another server) can combine outdoor map data with default-floor indoor map data ahead of time, for each map tile. In other words, map tiles are pre-computed to enable themap data server 14 to more quickly provide map tiles to clients upon request. - When the user wishes to view a different floor of the building, the
mapping module 40 can send the corresponding request for floor data for another floor that is not the default floor to themap data server 14. The server may then retrieve the indoor map features for the new floor. Depending on the implementation, the indoordata management module 44 can overlay the new floor data over the base map or remove and replace the individual map features 170. - As further illustrated in
FIG. 3 , to enable theclient device 14 to selectively operate on the indoor map data, indoor map features 170A, 170B, and 170C andlabels 180 are provided with indoormap data indicators 194. The indoordata management module 44 can use theindicator 194 to manage indoor map features separately and render these features in a different style, highlight indoor map features without highlighting other map features in response to a user request or an automated event (e.g., a search query), apply other visual effects, etc. Theindoor map indicators 194 may also correspond to each floor of a building (i.e., per floor) or to the building itself (i.e., per building) so that indoor data for one building may be highlighted or replaced with a different floor independent of indoor data for other nearby buildings. - In short, by providing indoor map features for the default floor in a base map tile in the manner discussed above, the
map data server 14 on the one hand allows themapping module 40 to immediately display richer content on theclient device 12 and, on the other hand, allows themapping module 40 to easily turn off the display of indoor map data, highlight the indoor map data, transition from one floor to another, etc. -
FIG. 4 a is a flow diagram of anexample method 200 for providing map data with an overview of available indoor map data to a client device. Themethod 200 can be implemented as a set of instructions stored on a computer-readable memory and executable on one or more processors. For example, themethod 200 can be implemented in the indoormap data generator 64. In an example implementation, themethod 200 is executed in response to receiving a request for map data corresponding to a specified geographic area and a specified zoom level. - At
block 202, map features that belong to a map tile are identified. This step can be implemented in a batch process, if desired. The map features identified atblock 202 are outdoor map features representing physical entities visible from a street or otherwise from the outside. The identified map features are included in a description of a map tile atblock 204. To this end, the vector graphics format can be used, for example. - Next, at
block 206, an overview of the available indoor map data for one or more features identified atblock 202 is generated. The overview can include an indication of the number of floors, a description of a bounding box for one or more floors, names of the floors, etc. Atblock 208, the overview of the available indoor map data is included in the metadata accompanying map features. The map data and the metadata then are provided to a client device atblock 210. -
FIG. 4 b is an example of auser interface 220 for themapping module 40 as displayed by aclient device 12 after being provided to the client device atblock 210. The user interface may display both the map data (e.g., map tile 150) and themetadata 106. For example, themapping module 40 may cause themetadata 106 to be displayed as the overview or “widget” 222 including indications of whichfloors 224 of a selected building (e.g., building 160A which includes indoor map features) are available for viewing as a map. In some embodiments, thewidget 222 may also include an indication of adefault floor 226 as indicated in themetadata 106 provided with the map data atblock 210. In still further embodiments, thewidget 222 may include a slider bar or other scrolling feature for a user to manipulate and display other available floor orindoor feature selections 224. - Next,
FIG. 5 depicts a flow diagram of anexample method 250 for providing indoor map data as part of a base map. In some embodiments, themethod 250, in whole or in part, can be stored as tangible computer-executable instructions of the basemap layer generator 63 within thememory 62 of themap data server 14 and executed by theprocessor 60, for example. In other embodiments, themethod 250, in whole or in part, can be stored as tangible computer-executable instructions of themapping module 40 within thememory 24 of theclient device 12 and executed by theCPU 20 orGPU 22, for example. In still further embodiments, themethod 250 can be stored as a combination of tangible computer-executable instructions within thememory 62 of themap data server 14 and/or theclient device 12 and respectively executed by theprocessor 60, theCPU 20, and/or theGPU 22. Themethod 250 also can be implemented as a set of instructions stored on a computer-readable memory and executable on one or more processors. - The
method 250 begins atblock 252, where outdoor map features 170, indoor map features 160, andmetadata 106 for a geographic area are included in a base map for a certain map tile 150 (FIG. 4 b) and received and displayed at a client device. Atblock 254, themethod 250 identifies amulti-floor building 160A or other outdoor feature in a geographic region corresponding to themap tile 150. Atblock 256, themethod 250 uses the receivedmetadata 106 to determine thedefault floor 226 of thestructure 160A. For example, with reference toFIG. 4 b, a base map includes amap tile 150 andbuilding 160A. Themetadata 106 may indicate that the first floor of thebuilding 160A is the default floor and themethod 250 may cause the indication for thedefault floor 226 to appear in thewidget 222. Next, themethod 250 may retrieve indoor map data for thedefault floor 226 from a database (block 258) and included in the map tile (260). Blocks 254-260 can be executed multiple times if the map tile includes multiple multi-floor structures for which indoor map data is available. - The following additional considerations apply to the foregoing discussion. Throughout this specification, plural instances may implement components, operations, or structures described as a single instance. Although individual operations of one or more methods are illustrated and described as separate operations, one or more of the individual operations may be performed concurrently, and nothing requires that the operations be performed in the order illustrated. Structures and functionality presented as separate components in example configurations may be implemented as a combined structure or component. Similarly, structures and functionality presented as a single component may be implemented as separate components. These and other variations, modifications, additions, and improvements fall within the scope of the subject matter of the present disclosure.
- Additionally, certain embodiments are described herein as including logic or a number of components, modules, or mechanisms. Modules may constitute either software modules (e.g., code stored on a machine-readable medium) or hardware modules. A hardware module is tangible unit capable of performing certain operations and may be configured or arranged in a certain manner. In example embodiments, one or more computer systems (e.g., a standalone, client or server computer system) or one or more hardware modules of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) as a hardware module that operates to perform certain operations as described herein.
- In various embodiments, a hardware module may be implemented mechanically or electronically. For example, a hardware module may comprise dedicated circuitry or logic that is permanently configured (e.g., as a special-purpose processor, such as a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC)) to perform certain operations. A hardware module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software to perform certain operations. It will be appreciated that the decision to implement a hardware module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
- Accordingly, the term hardware should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. Considering embodiments in which hardware modules are temporarily configured (e.g., programmed), each of the hardware modules need not be configured or instantiated at any one instance in time. For example, where the hardware modules comprise a general-purpose processor configured using software, the general-purpose processor may be configured as respective different hardware modules at different times. Software may accordingly configure a processor, for example, to constitute a particular hardware module at one instance of time and to constitute a different hardware module at a different instance of time.
- Hardware and software modules can provide information to, and receive information from, other hardware and/or software modules. Accordingly, the described hardware modules may be regarded as being communicatively coupled. Where multiple of such hardware or software modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the hardware or software modules. In embodiments in which multiple hardware modules or software are configured or instantiated at different times, communications between such hardware or software modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple hardware or software modules have access. For example, one hardware or software module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further hardware or software module may then, at a later time, access the memory device to retrieve and process the stored output. Hardware and software modules may also initiate communications with input or output devices, and can operate on a resource (e.g., a collection of information).
- The various operations of example methods described herein may be performed, at least partially, by one or more processors that are temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions. The modules referred to herein may, in some example embodiments, comprise processor-implemented modules.
- Similarly, the methods or routines described herein may be at least partially processor-implemented. For example, at least some of the operations of a method may be performed by one or processors or processor-implemented hardware modules. The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the processor or processors may be located in a single location (e.g., within a home environment, an office environment or as a server farm), while in other embodiments the processors may be distributed across a number of locations.
- The one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as an SaaS. For example, at least some of the operations may be performed by a group of computers (as examples of machines including processors), these operations being accessible via a network (e.g., the Internet) and via one or more appropriate interfaces (e.g., application program interfaces (APIs).)
- The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the one or more processors or processor-implemented modules may be located in a single geographic location (e.g., within a home environment, an office environment, or a server farm). In other example embodiments, the one or more processors or processor-implemented modules may be distributed across a number of geographic locations.
- Some portions of this specification are presented in terms of algorithms or symbolic representations of operations on data stored as bits or binary digital signals within a machine memory (e.g., a computer memory). These algorithms or symbolic representations are examples of techniques used by those of ordinary skill in the data processing arts to convey the substance of their work to others skilled in the art. As used herein, an “algorithm” or a “routine” is a self-consistent sequence of operations or similar processing leading to a desired result. In this context, algorithms, routines and operations involve physical manipulation of physical quantities. Typically, but not necessarily, such quantities may take the form of electrical, magnetic, or optical signals capable of being stored, accessed, transferred, combined, compared, or otherwise manipulated by a machine. It is convenient at times, principally for reasons of common usage, to refer to such signals using words such as “data,” “content,” “bits,” “values,” “elements,” “symbols,” “characters,” “terms,” “numbers,” “numerals,” or the like. These words, however, are merely convenient labels and are to be associated with appropriate physical quantities.
- Unless specifically stated otherwise, discussions herein using words such as “processing,” “computing,” “calculating,” “determining,” “presenting,” “displaying,” or the like may refer to actions or processes of a machine (e.g., a computer) that manipulates or transforms data represented as physical (e.g., electronic, magnetic, or optical) quantities within one or more memories (e.g., volatile memory, non-volatile memory, or a combination thereof), registers, or other machine components that receive, store, transmit, or display information.
- As used herein any reference to “one embodiment” or “an embodiment” means that a particular element, feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment. The appearances of the phrase “in one embodiment” in various places in the specification are not necessarily all referring to the same embodiment.
- Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. For example, some embodiments may be described using the term “coupled” to indicate that two or more elements are in direct physical or electrical contact. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other. The embodiments are not limited in this context.
- As used herein, the terms “comprises,” “comprising,” “includes,” “including,” “has,” “having” or any other variation thereof, are intended to cover a non-exclusive inclusion. For example, a process, method, article, or apparatus that comprises a list of elements is not necessarily limited to only those elements but may include other elements not expressly listed or inherent to such process, method, article, or apparatus. Further, unless expressly stated to the contrary, “or” refers to an inclusive or and not to an exclusive or. For example, a condition A or B is satisfied by any one of the following: A is true (or present) and B is false (or not present), A is false (or not present) and B is true (or present), and both A and B are true (or present).
- In addition, use of the “a” or “an” are employed to describe elements and components of the embodiments herein. This is done merely for convenience and to give a general sense of the description. This description should be read to include one or at least one and the singular also includes the plural unless it is obvious that it is meant otherwise.
- Upon reading this disclosure, those of skill in the art will appreciate still additional alternative structural and functional designs for providing indoor map data to a client device through the disclosed principles herein. Thus, while particular embodiments and applications have been illustrated and described, it is to be understood that the disclosed embodiments are not limited to the precise construction and components disclosed herein. Various modifications, changes and variations, which will be apparent to those skilled in the art, may be made in the arrangement, operation and details of the method and apparatus disclosed herein without departing from the spirit and scope defined in the appended claims.
Claims (20)
1. A method in a network server for providing map data including outdoor map features and indoor map features to a client device, the method comprising:
receiving, from the client device, a request for map data for a specified geographic area and a specified zoom level;
retrieving outdoor map features for the requested geographic area and the zoom level, wherein the outdoor map features correspond to externally visible physical entities;
determining that the outdoor map features include a map feature corresponding to a multi-floor building;
determining a default floor for the multi-floor building;
retrieving indoor map features for the default floor, wherein the indoor map features correspond to physical entities, are disposed on the default floor of the multi-floor building, and each include an indoor map indicator; and
providing the outdoor map features and the indoor map features for the default floor to the client device in response to the received request;
wherein the client device is configured to selectively display the indoor map features based on the indoor map indicator.
2. The method of claim 1 , further comprising the network server modifying the indoor map indicator in vector data including the indoor map features, the vector data provided to the client device in response to the received request.
3. The method of claim 2 , wherein the client device includes an indoor data management module configured to process the indoor map indicator of the vector data provided to the client device in response to the received request.
4. The method of claim 1 , wherein the client device is further configured to display selectable option at the client device to display or not display the provided indoor map features according to the indoor map indicator.
5. The method of claim 1 , wherein the provided outdoor map data further includes a collection of separate outdoor data structures that each include one or more of a vector-based description of an externally-visible physical entity, text-based label data, and metadata, the metadata including a unique identifier of an indoor data structure storing the indoor map data.
6. The method of claim 1 , wherein the provided outdoor map data further includes a rasterized description of an externally-visible physical entity and metadata, the metadata including coordinates for a location within the rasterized description of the externally-visible physical entity, the location corresponding to a graphical representation of the indoor map data.
7. The method of claim 1 , wherein the provided outdoor map data includes a logical link to the indoor map data.
8. A mapping system configured to provide map data including outdoor map features and indoor map features to a client device, the system comprising:
a remote mapping server including a processor and a memory, the memory including instructions executed on the processor to:
receive, from the client device, a request for map data for a specified geographic area and a specified zoom level;
retrieve outdoor map features for the requested geographic area and the zoom level, wherein the outdoor map features correspond to externally visible physical entities;
determine that the outdoor map features include a map feature corresponding to a multi-floor building;
determine a default floor for the multi-floor building;
retrieve indoor map features for the default floor, wherein the indoor map features correspond to physical entities, are disposed on the default floor of the multi-floor building, and each include an indoor map indicator; and
provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request.
9. The system of claim 8 , wherein the memory includes a further instruction executed on the processor to modify the indoor map indicator in vector data including the indoor map features, the vector data provided to the client device in response to the received request.
10. The system of claim 9 , wherein the memory includes a further instruction executed on the processor to process the indoor map indicator of the vector data provided to the client device in response to the received request.
11. The system of claim 10 , wherein the further instruction executed on the processor to process the indoor map indicator of the vector data provided to the client device in response to the received request includes a further instruction executed on a processor of the client device to display a selectable option at the client device to display or not display the provided indoor map features according to the indoor map indicator.
12. The system of claim 8 , wherein the provided outdoor map data further includes a collection of separate outdoor data structures that each include one or more of a vector-based description of an externally-visible physical entity, text-based label data, and metadata, the metadata including a unique identifier of an indoor data structure storing the indoor map data.
13. The system of claim 8 , wherein the provided outdoor map data further includes a rasterized description of an externally-visible physical entity and metadata, the metadata including coordinates for a location within the rasterized description of the externally-visible physical entity, the location corresponding to a graphical representation of the indoor map data.
14. The system of claim 8 , wherein the provided outdoor map data includes a logical link to the indoor map data.
15. A tangible computer-readable medium including non-transitory computer readable instructions stored thereon for providing map data including outdoor map features and indoor map features to a client device, the instructions to:
receive, from the client device, a request for map data for a specified geographic area and a specified zoom level;
retrieve outdoor map features for the requested geographic area and the zoom level, wherein the outdoor map features correspond to externally visible physical entities;
determine that the outdoor map features include a map feature corresponding to a multi-floor building;
determine a default floor for the multi-floor building;
retrieve indoor map features for the default floor, wherein the indoor map features correspond to physical entities, are disposed on the default floor of the multi-floor building, and each include an indoor map indicator; and
provide the outdoor map features and the indoor map features for the default floor to the client device in response to the received request.
16. The tangible computer readable medium of claim 15 , further comprising an instruction to modify the indoor map indicator in vector data including the indoor map features, the vector data provided to the client device in response to the received request.
17. The tangible computer readable medium of claim 16 , further comprising instructions to:
process the indoor map indicator of the vector data provided to the client device in response to the received request; and
display a selectable option at the client device to display or not display the provided indoor map features according to the indoor map indicator.
18. The tangible computer readable medium of claim 15 , wherein the provided outdoor map data further includes a collection of separate outdoor data structures that each include one or more of a vector-based description of an externally-visible physical entity, text-based label data, and metadata, the metadata including a unique identifier of an indoor data structure storing the indoor map data.
19. The tangible computer readable medium of claim 16 , wherein the provided outdoor map data further includes a rasterized description of an externally-visible physical entity and metadata, the metadata including coordinates for a location within the rasterized description of the externally-visible physical entity, the location corresponding to a graphical representation of the indoor map data.
20. The tangible computer readable medium of claim 15 , wherein the provided outdoor map data includes a logical link to the indoor map data.
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/167,607 US20150019625A1 (en) | 2013-07-09 | 2014-01-29 | Providing indoor map data to a client computing device |
PCT/US2014/045558 WO2015006205A2 (en) | 2013-07-09 | 2014-07-07 | Providing indoor map data to a client computing device |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US201361844300P | 2013-07-09 | 2013-07-09 | |
US14/167,607 US20150019625A1 (en) | 2013-07-09 | 2014-01-29 | Providing indoor map data to a client computing device |
Publications (1)
Publication Number | Publication Date |
---|---|
US20150019625A1 true US20150019625A1 (en) | 2015-01-15 |
Family
ID=52278028
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/167,607 Abandoned US20150019625A1 (en) | 2013-07-09 | 2014-01-29 | Providing indoor map data to a client computing device |
US14/167,496 Active 2034-07-24 US9417777B2 (en) | 2013-07-09 | 2014-01-29 | Enabling quick display transitions between indoor and outdoor map data |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/167,496 Active 2034-07-24 US9417777B2 (en) | 2013-07-09 | 2014-01-29 | Enabling quick display transitions between indoor and outdoor map data |
Country Status (2)
Country | Link |
---|---|
US (2) | US20150019625A1 (en) |
WO (1) | WO2015006205A2 (en) |
Cited By (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20170220754A1 (en) * | 2016-01-29 | 2017-08-03 | Boston Scientific Scimed, Inc. | Medical user interfaces and related methods of use |
WO2018222510A3 (en) * | 2017-06-02 | 2019-01-17 | Apple Inc. | Venues map application and system |
EP3754303A1 (en) * | 2019-06-19 | 2020-12-23 | HERE Global B.V. | Floor levels of a venue |
WO2021167422A1 (en) * | 2020-02-20 | 2021-08-26 | 주식회사 에스360브이알 | Digital map-based online platform |
KR20210106390A (en) * | 2020-02-20 | 2021-08-30 | 주식회사 에스360브이알 | Digital map based online platform |
US11105635B2 (en) * | 2013-04-16 | 2021-08-31 | Apple Inc. | Seamless transition from outdoor to indoor mapping |
WO2022005574A1 (en) * | 2020-06-30 | 2022-01-06 | Microsoft Technology Licensing, Llc | Client-renderable element for indoor building map |
KR102447172B1 (en) | 2021-06-08 | 2022-09-26 | 주식회사 에스360브이알 | Method of customizing a place shown in an initial screen of digital map and digital map system using the same |
WO2023018314A1 (en) * | 2021-08-13 | 2023-02-16 | 주식회사 에스360브이알 | Digital map-based virtual reality and metaverse online platform |
KR20230025646A (en) * | 2021-08-13 | 2023-02-22 | 주식회사 케이와이엠 | Digital map based virtual reality and metaverse online platform |
US11593535B2 (en) | 2019-11-01 | 2023-02-28 | Microsoft Technology Licensing, Llc | Geospatially referenced building floorplan data |
WO2023167454A1 (en) * | 2022-03-02 | 2023-09-07 | 주식회사 에스360브이알 | Indoor map using actual-measurement-based floor plan, and generation method therefor |
Families Citing this family (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20150019625A1 (en) * | 2013-07-09 | 2015-01-15 | Google Inc. | Providing indoor map data to a client computing device |
US9488481B2 (en) * | 2014-10-14 | 2016-11-08 | General Electric Company | Map presentation for multi-floor buildings |
CN107289923A (en) * | 2016-04-01 | 2017-10-24 | 奥的斯电梯公司 | Boarding navigation terminal, system and method in building |
US9874450B2 (en) * | 2016-04-28 | 2018-01-23 | Here Global B.V. | Referencing closed area geometry |
CN107818069B (en) * | 2016-09-12 | 2021-10-01 | 阿里巴巴集团控股有限公司 | Data processing method and system |
US20180143998A1 (en) * | 2016-11-21 | 2018-05-24 | Google Inc. | Electronic map interfaces |
US11029810B2 (en) | 2018-05-07 | 2021-06-08 | Otis Elevator Company | Equipment service graphical interface |
CN111127648B (en) * | 2019-12-30 | 2023-07-21 | 杭州网易再顾科技有限公司 | Indoor plane map generation method and device and cleaning map generation method |
Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070050129A1 (en) * | 2005-08-31 | 2007-03-01 | Microsoft Corporation | Location signposting and orientation |
US20070219708A1 (en) * | 2006-03-15 | 2007-09-20 | Microsoft Corporation | Location-based caching for mobile devices |
US20110172906A1 (en) * | 2010-01-14 | 2011-07-14 | Qualcomm Incorporated | Scalable Routing For Mobile Station Navigation With Location Context Identifier |
US20120029817A1 (en) * | 2010-01-22 | 2012-02-02 | Qualcomm Incorporated | Map handling for location based services in conjunction with localized environments |
US20130047120A1 (en) * | 2011-08-19 | 2013-02-21 | James Albright | Systems and methods for providing information pertaining to physical infrastructure of a building or property |
US20130144525A1 (en) * | 2011-12-02 | 2013-06-06 | Hyundai Mnsoft, Inc. | Method and system for creating indoor and outdoor linked path |
US20130332064A1 (en) * | 2012-06-12 | 2013-12-12 | Trx Systems, Inc. | System and method for localizing a trackee at a location and mapping the location using inertial sensor information |
US20140137017A1 (en) * | 2012-11-14 | 2014-05-15 | Qualcomm Incorporated | Region marking for an indoor map |
US20140253582A1 (en) * | 2013-03-11 | 2014-09-11 | Qualcomm Incorporated | Methods, apparatuses, and devices for rendering indoor maps on a display |
US20140278060A1 (en) * | 2007-05-31 | 2014-09-18 | Trx Systems, Inc. | Collaborative creation of indoor maps |
US20140310630A1 (en) * | 2013-04-12 | 2014-10-16 | Navteq B.V. | Method and apparatus for providing interactive three-dimensional indoor environments |
US20140372031A1 (en) * | 2013-06-17 | 2014-12-18 | Rivendell Technologies, LLC | Systems, methods and computer-readable media for generating digital wayfinding maps |
Family Cites Families (35)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
AU2002951345A0 (en) * | 2002-08-15 | 2002-09-26 | Hanika Pty Ltd, | Interactive property tour |
JP2005201919A (en) * | 2004-01-13 | 2005-07-28 | Nec Toshiba Space Systems Ltd | Building information guide and method for the same |
US7567844B2 (en) * | 2006-03-17 | 2009-07-28 | Honeywell International Inc. | Building management system |
US8893224B2 (en) * | 2006-08-29 | 2014-11-18 | Microsoft Corporation | Zone policy administration for entity tracking and privacy assurance |
US20080267145A1 (en) * | 2007-04-27 | 2008-10-30 | Symbol Technologies, Inc. | Methods and Apparatus for Managing Wireless Networks Using Geographical-Level and Site-Level Visualization |
US8359343B2 (en) * | 2007-12-12 | 2013-01-22 | Verizon Patent And Licensing Inc. | System and method for identifying threat locations |
US8490025B2 (en) * | 2008-02-01 | 2013-07-16 | Gabriel Jakobson | Displaying content associated with electronic mapping systems |
US8250157B2 (en) * | 2008-06-20 | 2012-08-21 | Oracle International Corporation | Presence mapping |
US20110096091A1 (en) * | 2008-06-24 | 2011-04-28 | Monmouth University | System and method for viewing and marking maps |
US8259692B2 (en) * | 2008-07-11 | 2012-09-04 | Nokia Corporation | Method providing positioning and navigation inside large buildings |
US8885047B2 (en) * | 2008-07-16 | 2014-11-11 | Verint Systems Inc. | System and method for capturing, storing, analyzing and displaying data relating to the movements of objects |
KR101143503B1 (en) * | 2010-02-22 | 2012-05-09 | 현대엠엔소프트 주식회사 | Method and apparatus for providing path using map information indoor |
US20120050332A1 (en) * | 2010-08-25 | 2012-03-01 | Nokia Corporation | Methods and apparatuses for facilitating content navigation |
EP3996029B1 (en) * | 2011-04-12 | 2024-04-10 | Google LLC | Integrating maps and street views |
US8825392B2 (en) * | 2011-06-30 | 2014-09-02 | Navteq B.V. | Map view |
US9291460B2 (en) * | 2011-07-22 | 2016-03-22 | Google Inc. | Map processing for indoor navigation guidance |
US8621394B2 (en) * | 2011-08-26 | 2013-12-31 | Nokia Corporation | Method, apparatus and computer program product for displaying items on multiple floors in multi-level maps |
KR101269733B1 (en) * | 2011-12-02 | 2013-05-30 | 인하대학교 산학협력단 | Apparatus and method for providing indoor route with outdoor route |
US9170113B2 (en) * | 2012-02-24 | 2015-10-27 | Google Inc. | System and method for mapping an indoor environment |
US9201815B2 (en) * | 2012-06-27 | 2015-12-01 | Ubiquiti Networks, Inc. | Method and apparatus for maintaining network connections between devices |
US8464181B1 (en) * | 2012-07-03 | 2013-06-11 | Google Inc. | Floor selection on an interactive digital map |
US9357346B2 (en) * | 2012-07-16 | 2016-05-31 | Aisle411, Inc. | System and method for indoor location mapping and tracking |
US20140128093A1 (en) * | 2012-11-06 | 2014-05-08 | Qualcomm Incorporated | Portal transition parameters for use in mobile device positioning |
US9020191B2 (en) * | 2012-11-30 | 2015-04-28 | Qualcomm Incorporated | Image-based indoor position determination |
US9066207B2 (en) * | 2012-12-14 | 2015-06-23 | Apple Inc. | Managing states of location determination |
US20140237076A1 (en) * | 2013-02-21 | 2014-08-21 | On Location Engagements, Inc. | Content Management And Delivery of On Location Engagements |
US8928657B2 (en) * | 2013-03-07 | 2015-01-06 | Google Inc. | Progressive disclosure of indoor maps |
US20150019625A1 (en) * | 2013-07-09 | 2015-01-15 | Google Inc. | Providing indoor map data to a client computing device |
US20150095350A1 (en) * | 2013-09-30 | 2015-04-02 | Qualcomm Incorporated | Methods, apparatuses, and devices for generating maps on a mobile device |
US8823734B1 (en) * | 2013-10-14 | 2014-09-02 | Google Inc. | Indicating availability of indoor content on a digital map |
US9582516B2 (en) * | 2013-10-17 | 2017-02-28 | Nant Holdings Ip, Llc | Wide area augmented reality location-based services |
US9354067B2 (en) * | 2013-12-18 | 2016-05-31 | Qualcomm Incorporated | System, method and/or devices for aligning a movement path with an indoor routing graph |
US9442911B2 (en) * | 2014-01-09 | 2016-09-13 | Ricoh Company, Ltd. | Adding annotations to a map |
US20150237164A1 (en) * | 2014-02-18 | 2015-08-20 | Qualcomm Incorporated | Improving or optimizing a radio heatmap via feedback to agents |
US9293023B2 (en) * | 2014-03-18 | 2016-03-22 | Jack Ke Zhang | Techniques for emergency detection and emergency alert messaging |
-
2014
- 2014-01-29 US US14/167,607 patent/US20150019625A1/en not_active Abandoned
- 2014-01-29 US US14/167,496 patent/US9417777B2/en active Active
- 2014-07-07 WO PCT/US2014/045558 patent/WO2015006205A2/en active Application Filing
Patent Citations (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20070050129A1 (en) * | 2005-08-31 | 2007-03-01 | Microsoft Corporation | Location signposting and orientation |
US20070219708A1 (en) * | 2006-03-15 | 2007-09-20 | Microsoft Corporation | Location-based caching for mobile devices |
US20140278060A1 (en) * | 2007-05-31 | 2014-09-18 | Trx Systems, Inc. | Collaborative creation of indoor maps |
US20110172906A1 (en) * | 2010-01-14 | 2011-07-14 | Qualcomm Incorporated | Scalable Routing For Mobile Station Navigation With Location Context Identifier |
US20120029817A1 (en) * | 2010-01-22 | 2012-02-02 | Qualcomm Incorporated | Map handling for location based services in conjunction with localized environments |
US20130047120A1 (en) * | 2011-08-19 | 2013-02-21 | James Albright | Systems and methods for providing information pertaining to physical infrastructure of a building or property |
US20130144525A1 (en) * | 2011-12-02 | 2013-06-06 | Hyundai Mnsoft, Inc. | Method and system for creating indoor and outdoor linked path |
US20130332064A1 (en) * | 2012-06-12 | 2013-12-12 | Trx Systems, Inc. | System and method for localizing a trackee at a location and mapping the location using inertial sensor information |
US20140137017A1 (en) * | 2012-11-14 | 2014-05-15 | Qualcomm Incorporated | Region marking for an indoor map |
US20140253582A1 (en) * | 2013-03-11 | 2014-09-11 | Qualcomm Incorporated | Methods, apparatuses, and devices for rendering indoor maps on a display |
US20140310630A1 (en) * | 2013-04-12 | 2014-10-16 | Navteq B.V. | Method and apparatus for providing interactive three-dimensional indoor environments |
US20140372031A1 (en) * | 2013-06-17 | 2014-12-18 | Rivendell Technologies, LLC | Systems, methods and computer-readable media for generating digital wayfinding maps |
Cited By (25)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11105635B2 (en) * | 2013-04-16 | 2021-08-31 | Apple Inc. | Seamless transition from outdoor to indoor mapping |
US20170220754A1 (en) * | 2016-01-29 | 2017-08-03 | Boston Scientific Scimed, Inc. | Medical user interfaces and related methods of use |
US11193788B2 (en) | 2017-06-02 | 2021-12-07 | Apple Inc. | Venues map application and system providing a venue directory |
US11029173B2 (en) | 2017-06-02 | 2021-06-08 | Apple Inc. | Venues map application and system |
US11085790B2 (en) | 2017-06-02 | 2021-08-10 | Apple Inc. | Venues map application and system providing indoor routing |
US10753762B2 (en) | 2017-06-02 | 2020-08-25 | Apple Inc. | Application and system providing indoor searching of a venue |
US12085406B2 (en) | 2017-06-02 | 2024-09-10 | Apple Inc. | Venues map application and system |
WO2018222510A3 (en) * | 2017-06-02 | 2019-01-17 | Apple Inc. | Venues map application and system |
US11536585B2 (en) | 2017-06-02 | 2022-12-27 | Apple Inc. | Venues map application and system |
US11680815B2 (en) | 2017-06-02 | 2023-06-20 | Apple Inc. | Venues map application and system providing a venue directory |
US11635303B2 (en) | 2017-06-02 | 2023-04-25 | Apple Inc. | Application and system providing indoor searching of a venue |
EP3754303A1 (en) * | 2019-06-19 | 2020-12-23 | HERE Global B.V. | Floor levels of a venue |
US11226391B2 (en) | 2019-06-19 | 2022-01-18 | Here Global B.V. | Floor levels of a venue |
US11593535B2 (en) | 2019-11-01 | 2023-02-28 | Microsoft Technology Licensing, Llc | Geospatially referenced building floorplan data |
WO2021167422A1 (en) * | 2020-02-20 | 2021-08-26 | 주식회사 에스360브이알 | Digital map-based online platform |
KR102344087B1 (en) | 2020-02-20 | 2021-12-29 | 주식회사 에스360브이알 | Digital map based online platform |
US11886527B2 (en) | 2020-02-20 | 2024-01-30 | S360Vr Co., Ltd. | Digital map based online platform |
KR20210106390A (en) * | 2020-02-20 | 2021-08-30 | 주식회사 에스360브이알 | Digital map based online platform |
US11310629B2 (en) * | 2020-06-30 | 2022-04-19 | Microsoft Technology Licensing, Llc | Client-renderable element for indoor building map |
WO2022005574A1 (en) * | 2020-06-30 | 2022-01-06 | Microsoft Technology Licensing, Llc | Client-renderable element for indoor building map |
KR102447172B1 (en) | 2021-06-08 | 2022-09-26 | 주식회사 에스360브이알 | Method of customizing a place shown in an initial screen of digital map and digital map system using the same |
WO2023018314A1 (en) * | 2021-08-13 | 2023-02-16 | 주식회사 에스360브이알 | Digital map-based virtual reality and metaverse online platform |
KR20230025646A (en) * | 2021-08-13 | 2023-02-22 | 주식회사 케이와이엠 | Digital map based virtual reality and metaverse online platform |
KR102497681B1 (en) * | 2021-08-13 | 2023-02-24 | 주식회사 케이와이엠 | Digital map based virtual reality and metaverse online platform |
WO2023167454A1 (en) * | 2022-03-02 | 2023-09-07 | 주식회사 에스360브이알 | Indoor map using actual-measurement-based floor plan, and generation method therefor |
Also Published As
Publication number | Publication date |
---|---|
WO2015006205A3 (en) | 2015-04-30 |
US9417777B2 (en) | 2016-08-16 |
WO2015006205A2 (en) | 2015-01-15 |
US20150020008A1 (en) | 2015-01-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US9417777B2 (en) | Enabling quick display transitions between indoor and outdoor map data | |
US8928657B2 (en) | Progressive disclosure of indoor maps | |
US9652115B2 (en) | Vertical floor expansion on an interactive digital map | |
US9134886B2 (en) | Providing indoor facility information on a digital map | |
US8464181B1 (en) | Floor selection on an interactive digital map | |
US9110573B2 (en) | Personalized viewports for interactive digital maps | |
JP6099665B2 (en) | Prefetch map tile data along the route | |
US9488481B2 (en) | Map presentation for multi-floor buildings | |
US8698824B1 (en) | Computing systems, devices and methods for rendering maps remote from a host application | |
US9684947B2 (en) | Indicating availability of indoor content on a digital map | |
US11442596B1 (en) | Interactive digital map including context-based photographic imagery | |
US20150062114A1 (en) | Displaying textual information related to geolocated images | |
US8730264B1 (en) | Determining when image elements intersect | |
CN109416258B (en) | Method, apparatus and computer program product for adaptive site scaling in a digital map interface | |
US9721363B2 (en) | Encoding polygon data for fast retrieval and rendering | |
JP7186864B2 (en) | Selection of points of interest for display on personalized digital maps | |
US20150130845A1 (en) | Out-of-viewpoint indicators for relevant map features | |
JP7086180B2 (en) | Dynamic styling of digital maps |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: GOOGLE INC., CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:PENSACK-RINEHART, SEAN J.;REANEY, GAVIN;LEE, NICHOLAS J.;AND OTHERS;SIGNING DATES FROM 20140124 TO 20160507;REEL/FRAME:038861/0939 |
|
AS | Assignment |
Owner name: GOOGLE LLC, CALIFORNIA Free format text: CHANGE OF NAME;ASSIGNOR:GOOGLE INC.;REEL/FRAME:044129/0001 Effective date: 20170929 |
|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |