CN107231817A - 降低地图界面中的时延 - Google Patents
降低地图界面中的时延 Download PDFInfo
- Publication number
- CN107231817A CN107231817A CN201680003888.1A CN201680003888A CN107231817A CN 107231817 A CN107231817 A CN 107231817A CN 201680003888 A CN201680003888 A CN 201680003888A CN 107231817 A CN107231817 A CN 107231817A
- Authority
- CN
- China
- Prior art keywords
- map
- image
- data
- subregion
- 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.)
- Pending
Links
- 230000002452 interceptive effect Effects 0.000 claims abstract description 53
- 238000000034 method Methods 0.000 claims abstract description 34
- 230000000007 visual effect Effects 0.000 claims abstract description 34
- 238000004590 computer program Methods 0.000 claims abstract description 14
- 230000004044 response Effects 0.000 claims description 20
- 238000012545 processing Methods 0.000 claims description 16
- 238000009877 rendering Methods 0.000 claims description 15
- 238000010422 painting Methods 0.000 claims description 11
- 238000004891 communication Methods 0.000 claims description 7
- 230000006835 compression Effects 0.000 claims description 6
- 238000007906 compression Methods 0.000 claims description 6
- 238000005516 engineering process Methods 0.000 claims description 6
- 230000003993 interaction Effects 0.000 claims description 5
- 230000005611 electricity Effects 0.000 claims description 4
- 230000003287 optical effect Effects 0.000 claims description 4
- 230000004438 eyesight Effects 0.000 claims description 2
- 238000013515 script Methods 0.000 description 16
- 238000013523 data management Methods 0.000 description 13
- 239000011248 coating agent Substances 0.000 description 12
- 238000000576 coating method Methods 0.000 description 12
- 230000000694 effects Effects 0.000 description 10
- 238000006243 chemical reaction Methods 0.000 description 8
- 230000008569 process Effects 0.000 description 8
- 239000003086 colorant Substances 0.000 description 6
- 230000005540 biological transmission Effects 0.000 description 5
- 230000008859 change Effects 0.000 description 5
- 238000013500 data storage Methods 0.000 description 5
- 238000012384 transportation and delivery Methods 0.000 description 5
- 230000009471 action Effects 0.000 description 4
- 238000001514 detection method Methods 0.000 description 4
- 238000007726 management method Methods 0.000 description 4
- 238000000429 assembly Methods 0.000 description 2
- 230000000712 assembly Effects 0.000 description 2
- 230000009286 beneficial effect Effects 0.000 description 2
- 230000008901 benefit Effects 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 239000003638 chemical reducing agent Substances 0.000 description 2
- 238000010295 mobile communication Methods 0.000 description 2
- 238000000926 separation method Methods 0.000 description 2
- 238000012360 testing method Methods 0.000 description 2
- PLXMOAALOJOTIY-FPTXNFDTSA-N Aesculin Natural products OC[C@@H]1[C@@H](O)[C@H](O)[C@@H](O)[C@H](O)[C@H]1Oc2cc3C=CC(=O)Oc3cc2O PLXMOAALOJOTIY-FPTXNFDTSA-N 0.000 description 1
- 241001269238 Data Species 0.000 description 1
- 238000000151 deposition Methods 0.000 description 1
- 238000010586 diagram Methods 0.000 description 1
- 239000004744 fabric Substances 0.000 description 1
- 230000006872 improvement Effects 0.000 description 1
- 238000007689 inspection Methods 0.000 description 1
- 239000004973 liquid crystal related substance Substances 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 230000004048 modification Effects 0.000 description 1
- 238000012986 modification Methods 0.000 description 1
- 230000006855 networking Effects 0.000 description 1
- 230000011218 segmentation Effects 0.000 description 1
- 239000004065 semiconductor Substances 0.000 description 1
- 230000001953 sensory effect Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 238000012358 sourcing Methods 0.000 description 1
- 241000894007 species Species 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/20—Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
- G06F16/29—Geographical information databases
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/50—Information retrieval; Database structures therefor; File system structures therefor of still image data
- G06F16/51—Indexing; Data structures therefor; Storage structures
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/60—Information retrieval; Database structures therefor; File system structures therefor of audio data
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/60—Information retrieval; Database structures therefor; File system structures therefor of audio data
- G06F16/63—Querying
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/20—Processor architectures; Processor configuration, e.g. pipelining
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T1/00—General purpose image data processing
- G06T1/60—Memory management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/001—Texturing; Colouring; Generation of texture or colour
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/20—Drawing from basic elements, e.g. lines or circles
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T11/00—2D [Two Dimensional] image generation
- G06T11/40—Filling a planar surface by adding surface attributes, e.g. colour or texture
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T3/00—Geometric image transformations in the plane of the image
- G06T3/40—Scaling of whole images or parts thereof, e.g. expanding or contracting
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T7/00—Image analysis
- G06T7/10—Segmentation; Edge detection
- G06T7/11—Region-based segmentation
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T9/00—Image coding
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2203/00—Indexing scheme relating to G06F3/00 - G06F3/048
- G06F2203/048—Indexing scheme relating to G06F3/048
- G06F2203/04806—Zoom, i.e. interaction techniques or interactors for controlling the zooming operation
-
- 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/04842—Selection of displayed objects or displayed text elements
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2200/00—Indexing scheme for image data processing or generation, in general
- G06T2200/16—Indexing scheme for image data processing or generation, in general involving adaptation to the client's capabilities
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T2207/00—Indexing scheme for image analysis or image enhancement
- G06T2207/20—Special algorithmic details
- G06T2207/20092—Interactive image processing based on input by user
- G06T2207/20104—Interactive definition of region of interest [ROI]
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- General Engineering & Computer Science (AREA)
- Data Mining & Analysis (AREA)
- Multimedia (AREA)
- Software Systems (AREA)
- Remote Sensing (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Human Computer Interaction (AREA)
- User Interface Of Digital Computer (AREA)
- Information Transfer Between Computers (AREA)
- Processing Or Creating Images (AREA)
- Image Generation (AREA)
- Instructional Devices (AREA)
- Controls And Circuits For Display Device (AREA)
Abstract
本发明提供了用于降低在传送和呈现地图用户界面中的时延的方法、系统、和装置,其包括在计算机存储介质上编码的计算机程序。在一个方面中,一种方法包括:从客户端设备接收对呈现交互式地图用户界面的请求,所述交互式地图用户界面描绘(i)区域和(ii)与所述区域的子区域的账户有关的数据。一个或者多个服务器对所述区域的地图进行渲染。所述服务器生成表示所渲染的地图的图像的图像文件。为每个不同的子区域指派不同的视觉特性。所述服务器配置所述客户端设备的用户界面以:(i)呈现所述图像,其中所述不同子区域中的每个不同子区域根据所述不同视觉特性来呈现;以及(ii)当所述客户端设备检测到与所述子区域的用户交互时,呈现与所述子区域有关的账户数据。
Description
背景技术
互联网促进全球用户之间的信息交换和交易。这种信息交换使得数据提供者能够将数据提供至各种用户。互联网上所提供的信息的示例是交互式地图,该交互式地图使得用户能够搜索和查看特定地区的地图。由于这些地图用户界面可以包括大量信息并且可以通过使用许多不同的脚本、画布、和图形来生成,所以对地图进行渲染可能占用大量资源并且需要一些时间来在客户端设备处进行渲染。
发明内容
本说明书描述了与降低在传送和呈现地图用户界面中的时延有关的技术。
一般而言,本说明书所描述的主题的一个创新方面可以实施为方法,该方法包括以下动作:从客户端设备接收对呈现交互式地图用户界面的请求,该交互式地图用户界面描绘(i)特定地理区域和(ii)与特定区域的多个不同子区域的在线账户有关的数据;由一个或者多个服务器使用地图服务对特定区域的地图进行渲染,该渲染包括生成特定区域的画布并且加载用于生成地图的多个编程元素和图形元素;由一个或者多个服务器基于渲染的地图来生成表示渲染的地图的图像的图像文件;至少基于图像所描绘的视觉边界来检测在图像内的一个或者多个子区域;为图像内的每个不同的子区域指派不同的视觉特性;生成电子索引,该电子索引将图像内的每个位置映射到包括该位置的对应子区域;以及由一个或者多个服务器配置客户端设备的用户界面以:(i)呈现图像,其中不同子区域中的每个不同子区域根据与该不同子区域相对应的不同视觉特性来呈现;以及(ii)当客户端设备检测到与图像的至少一个给定子区域的用户交互时,呈现与该给定子区域有关的账户数据。该方面的其它实施例包括被配置为执行编码在计算机存储设备上的该方法的动作的对应的系统、装置、和计算机程序。
这些实施例和其它实施例均可以可选地包括以下特征中的一个或者多个。在一些方面中,每个子区域的视觉特性包括指派给子区域并且被呈现在图像中的子区域内的特定颜色。
图像文件可以通过使用比生成画布所需的计算资源少的计算资源来进行渲染。一些方面可以包括:通过使用压缩技术来减小图像文件的数据大小,该压缩技术包括:为图像的每个子区域指派特定红、绿、蓝(RGB)颜色,该图像的子区域以特定红、绿、蓝(RGB)颜色来呈现;以及在所述图像文件中针对每个特定子区域存储子区域的RGB颜色和指定特定子区域在图像内的位置的数据。
一些方面可以包括:在一个或者多个服务器处从客户端设备接收指定对图像内的特定位置的选择的数据。响应于选择,可以生成经更新的图像,该经更新的图像描绘与选择的位置相对应的特定子区域的地图。该生成可以包括通过使用地图服务对特定子区域的地图进行渲染以及生成渲染的地图的图像。可以将表示经更新的图像的图像文件提供至客户端设备。一些方面可以包括:从客户端设备接收指定在选择时图像的缩放级别的数据。基于缩放级别来确定选择的粒度级别。可以基于选择的粒度级别来确定与选择的位置相对应的特定子区域。
在一些方面中,图像文件包括便携式网络图形(PNG)文件格式。一些方面可以包括:由一个或者多个服务器响应于请求并且在接收到对一个或者多个附加图像文件的请求之前将一个或者多个附加图像文件提供至客户端设备,所述一个或多个附加图像文件各自表示所述子区域中的至少一个子区域的地图。
本说明书所描述的主题的特定实施例可以被实现从而达到以下优点中的一个或者多个。通过将具有索引的压缩图像文件提供至可以响应于用户交互而呈现的数据而不是通过将脚本、画布、图形、文档对象模型(DOM)元素和其它数据加载到客户端设备,来降低在客户端设备处提供和呈现交互式地图用户界面中的时延。例如,通过互联网提供图像文件(例如,压缩图像文件)所需的联网资源量可能大大少于提供用于在客户端设备处生成地图的脚本、画布和DOM元素所需的联网资源量。
类似地,由于客户端设备的处理器不必加载脚本或者DOM元素或者生成画布,所以可以通过使用压缩图像文件来减少对客户端设备的计算资源的需求。另外,可以通过使用图像文件来减少用于呈现交互式地图用户界面的客户端设备的内存量(例如,RAM),这会释放内存以供其它应用并且提高客户端设备处理数据的速度。通过为地图图像的每个整体子区域指派特定颜色,可以减小(例如,压缩)存储图像的图像文件的大小,导致设备之间的传输时间更快并且用于传送图像文件的所消耗网络带宽更少。因此,实施例可以解决与交互式地图数据的传递和显示相关联的问题。
本说明书所描述的主题的一个或者多个实施例的细节在附图和下面的描述中阐述。本主题的其它特征、方面、和优点将根据说明书、附图、和权利要求书而变得显而易见。
附图说明
图1是数据管理系统提供交互式地图用户界面的环境。
图2是示例交互式地图用户界面的屏幕截图。
图3是提供交互式地图用户界面的示例过程的流程图。
图4是压缩图像文件的示例过程的流程图。
在各个附图中,相似的附图标记和名称指示相似的元件。
具体实施方式
系统可以降低在提供和呈现交互式地图用户界面中的时延。例如,系统可以生成由地图服务生成的地图的图像。该图像可以描绘特定区域及其子区域的地图。系统也可以生成电子索引,该电子索引将图像内的位置(例如,图像的x-y坐标)映射到图像的子区域并且将电子索引和图像提供至客户端设备。电子索引也可以将子区域映射到子区域的数据。以这种方式,例如,当用户通过悬停在与子区域相对应的位置上或者选择该位置来与在与特定子区域相对应的位置处的地图的图像交互时,可以按照交互式方式向用户呈现该子区域的数据。
例如,通过互联网将图像提供至客户端设备可能比在客户端设备处使用地图服务来生成地图需要更少的计算资源和网络资源。这也提高了向用户呈现地图用户界面的速度。通过压缩图像,可以进一步减少计算资源和将资源联网的量,并且进一步提高速度。在一些实施方式中,可以通过为图像的每个子区域指派特定颜色来压缩图像。例如,可以将整个子区域描绘成指派给子区域的特定颜色,而不是描绘成道路、地形等的不同颜色。以这种方式,可以减小图像文件的大小,允许网络上的传输更快和通过网络传输图像的网络带宽更少。例如,因为给定子区域的所有地区是相同的颜色,所以仅仅需要发送针对表示子区域的图像的整个地区的单一颜色代码(例如,RGB值),而不是发送针对子区域的多个不同部分的不同颜色代码。另外,客户端设备可以通过使用压缩图像渲染技术——例如由图形处理单元(GPU)实现——来更快速地呈现压缩图像。
为了进一步降低在呈现交互式用户界面中的时延,可以在请求地图之前提供地图的附加图像。如果用户请求地图,则可以将附加地图图像存储在客户端设备处——例如在高速缓存中,使得更快速地呈现地图。例如,在用户选择了更详细的视图的子区域中的一个的情况下,系统可以提供响应于该请求而生成的图像中所描绘的每个子区域的更详细的地图。
图1是数据管理系统110提供交互式地图用户界面的示例环境100。例如,响应于从客户端设备接收到的请求,数据管理系统110可以将交互式地图用户界面提供至客户端设备,例如,客户端设备150。数据管理系统110可以通过数据通信网络130发送交互式地图用户界面,数据通信网络13例如局域网(LAN)、广域网(WAN)、移动通信网络、互联网、或者其组合。网络130可以包括服务器、集线器、路由器、交换机、接口设备、传输介质、以及使得设备能够将数据发送至其它设备并且从其它设备接收数据的其它联网组件。
客户端设备150是电子设备,该电子设备能够通过网络130来请求和接收电子资源和其它数据。示例客户端设备150包括个人计算机、移动通信设备(例如,智能电话、平板计算设备、和/或智能手表)、以及可以通过网络130发送和接收数据的其它设备。客户端设备150通常包括促进通过网络130发送和接收数据的用户应用,诸如web浏览器。Web浏览器可以使得用户能够与文本、图像、视频、音乐、和通常位于网站处的网页上的其它信息交互。
客户端设备150可以包括其它应用,例如,为特定类型的设备或者为特定平台开发的本原应用(native application)。例如,客户端设备150包括地图查看器155,该地图查看器155向客户端设备150的用户呈现交互式地图用户界面157。地图查看器150可以实现在web浏览器、本原应用、或者另一种类型的应用程序中。
交互式地图用户界面157呈现特定区域的地图。例如,交互式地图用户界面157可以呈现由从客户端设备150接收到的请求指定的特定区域的地图。交互式地图用户界面157也可以呈现与包括在地图中的特定区域和/或该区域的子区域有关的数据。如下面所描述的,呈现的数据可以包括与客户端设备150的用户被授权访问的在线账户有关的账户数据。该数据可以响应于与地图的用户交互来呈现。例如,如果客户端设备150的用户将光标或者其它指针悬停在与特定子区域相对应的位置上,则可以向用户呈现该子区域的数据。在图2中图示了示例交互式地图用户界面并且在下面更详细地描述了该示例交互式地图用户界面。
数据管理系统110可以管理用户和/或组织的数据并且提供该数据以用于呈现给用户,例如,在数据管理系统110所生成的用户界面中。例如,数据管理系统110可以管理多个不同账户持有者的多个不同账户的在线账户数据。在特定示例中,数据管理系统110可以管理多个不同组织的内容递送账户数据。下面所描述的系统和技术也可以应用于各种其它类型的数据。
账户管理系统110所管理的账户数据可以包括与账户有关的任何数据,诸如内容项的效能数据(例如,闪现(impression)、点进率、转化率等)、账户持有者的预算信息、和/或内容项分发准则。每个账户持有者的账户数据存储在账户数据存储设备115中,该账户数据存储设备115可以包括位于一个或者多个数据中心中的多个数据存储设备。每个账户持有者的账户数据可以单独地并且安全地被存储,使得不会将一个账户持有者的账户数据提供至不同账户持有者的用户。
账户数据的至少一部分可以与用于识别数据的对应地理位置的数据存储在一起。例如,内容递送活动的数据可以包括指定以下的数据:内容项的闪现次数、对内容项的选择次数、由内容项的呈现造成的转化次数、和/或其它适当的活动数据。每个事件(例如,闪现、选择、转化等)的数据可以包括事件发生的地理位置的名称。例如,如果内容项被呈现在位于西雅图的客户端设备上,则闪现的数据可以指示发生在西雅图的闪现。以这种方式,可以基于位置来过滤数据并且可以确定与每个位置相关联的度量。
数据管理系统10包括一个或者多个前端服务器111、数据选择器113、和地图用户界面生成器120。数据选择器113和地图用户界面生成器120也可以实现在一个或者多个服务器中。例如,前端服务器111、数据选择器113、和地图用户界面生成器120可以实现在位于一个或者多个位置(例如,数据中心)中的一个或者多个服务器中。前端服务器111、数据选择器113、和地图用户界面生成器120可以例如通过网络来在彼此之间传输数据。
前端服务器111从客户端设备接收对数据的请求并且将请求的数据提供至客户端设备。前端服务器111可以充当客户端设备与数据选择器113和地图用户界面生成器120之间的接口。例如,前端服务器111可以将对数据的请求转发至数据选择器113。进而,数据选择器113可以从账户数据存储设备115获得适当的数据并且将该数据提供至前端服务器111。然后,前端服务器111可以将数据提供至提交该请求的客户端设备。
前端服务器111也可以确定接收到的请求是否正在请求地图用户界面。例如,该请求可以指定其正在请求描绘了特定区域的账户数据的地图用户界面。在另一示例中,客户端设备的用户可以按照触发对另一地图用户界面的请求的方式来与地图用户界面交互。例如,用户可以放大或者缩小地图用户界面以查看不同区域或者子区域的更详细的视图。在该示例中,该请求可以指定要包括在地图用户界面中的区域。
如果前端服务器111确定请求正在请求地图用户界面,则前端服务器111可以向地图用户界面生成器120请求地图用户界面。地图用户界面生成器120可以针对请求的区域生成交互式地图用户界面并且将该交互式地图用户界面提供至前端服务器111。进而,前端服务器111将交互式地图用户界面提供至客户端设备。
在一些实施方式中,数据选择器113可以确定是否将地图用户界面提供至客户端设备150。例如,数据选择器113可以基于正被提供至客户端设备150的数据来确定是否提供地图用户界面。如果数据包括特点于多个不同地理位置的数据,则数据选择器113可以确定要提供地图用户界面。例如,针对多个不同地理位置中的每一个,数据可以包括在内容项已经在该地理位置中被提供时的该内容项的转化率。在该示例中,数据选择器113可以确定要提供地图用户界面,该地图用户界面在其位于地图上的适当位置处呈现转化率。
地图用户界面生成器120生成交互式地图用户界面,该交互式地图用户界面呈现地图中所描绘的地理位置的数据。例如,地图用户界面生成器120可以生成交互式地图用户界面,该交互式地图用户界面描绘了由从客户端设备接收到的请求指定的特定区域的地图。地图用户界面生成器120所生成的交互式地图用户界面可以包括更复杂的地图的图像和与该图像所描绘的地理位置相对应的数据索引。以这种方式,与通过使用从地图服务获得的代码(例如脚本)、DOM元素、和其它数据在客户端设备150处生成地图相比较,可以降低在对客户端设备150处的交互式地图用户界面进行渲染中的时延。另外,可以减少对用于对交互式地图用户界面进行渲染的客户端设备150的计算资源的需求,从而提高客户端设备150的效能。
地图用户界面生成器120包括一个或者多个地图渲染服务器121。地图渲染服务器121可以使用地图服务122和地图客户端123来对地理区域的地图进行渲染。地图服务122可以包括web地图服务,该web地图服务响应于对地图的请求而将地图或者地图的部分提供至地图客户端123。例如,地图服务122可以基于对特定区域的地图的请求来选择地图图块(tile)、覆盖层、和其它地图数据以提供至地图客户端123。地图服务122可以从地图数据存储设备124选择地图图块、覆盖层、和其它地图数据。
地图客户端123可以从地图服务122请求地图,组织从地图服务接收到的地图数据,并且对地图进行渲染。在一些实施方式中,地图客户端123使用多个脚本来生成地图画布、在该画布上组织地图图块,将覆盖层布置在该地图图块上,将其它地图数据定位在地图上,并且对地图进行渲染,例如,在显示器处或者在存储器中。为了对地图进行渲染,地图客户端123也可以加载脚本用来对地图进行渲染的多个DOM元素。
地图客户端123可以与地图服务122交互以对例如客户端设备150的客户端设备所请求的地图进行渲染。通过对处于地图渲染服务器121处而不是处于客户端设备150处的地图进行渲染,当地图渲染服务器具有用来对地图进行渲染的更强大并且更多数目的计算资源时,可以更快速地对地图进行渲染。另外,地图客户端123可以在没有通过互联网提交请求的情况下与地图服务122交互,进一步减少对地图进行渲染所需的时间量。
地图用户界面生成器120还包括地图图像文件生成器125、索引生成器128、和文件压缩器129。地图图像文件生成器125可以生成由地图客户端123渲染的地图的图像并且生成表示该图像的图像文件。例如,地图图像文件生成器125可以捕获渲染的地图的屏幕截图并且生成表示捕获的图像的图像文件。图像文件可以是便携式网络图形(PNG)文件、图形交换格式(GIF)文件、联合图像专家组(JPEG)文件、或者另一适当类型的图像文件。
地图图像文件生成器125包括边界检测器126和视觉特性选择器127。边界检测器126可以检测在地图图像文件生成器125所生成的地图的图像内的视觉边界。例如,图像可以描绘包括由边界限定的子区域的特定区域。在特定示例中,区域可以是美国并且子区域可以是各个州。边界检测器126可以使用例如边缘检测的边界检测技术来检测子区域之间的边界。
在一些实施方式中,边界检测器126也可以基于边界和/或基于指定图像所描绘的区域的数据来识别图像所描绘的子区域。例如,通过了解图像内的区域和子区域,边界检测器126可以确定图像的哪些有边界区域与每个子区域相对应。边界检测器126可以通过比较由图像中的边界限定的形状和每个子区域的已知形状来确定子区域。
视觉特性选择器127可以选择视觉特性以与地图的图像中所描绘的每个子区域相关联。例如,视觉特性可以是颜色(例如,基于RGB颜色模型或者红色、绿色、蓝色、Alpha(RGBA颜色模型))、加明暗、加影线、颜色强度、或者一些其它适当的视觉特性。在一些实施方式中,视觉特性选择器127基于每个子区域的数据来选择每个子区域的视觉特性。例如,当内容项被呈现在位于子区域中的客户端设备处时,可以生成交互性地图用户界面以呈现内容项的效能。在该示例中,视觉特性选择器127可以基于每个子区域的效能指标来选择每个子区域的视觉特性。内容项具有更好效能的子区域可以以比内容项具有较差效能的子区域更亮的颜色来呈现。
在另一示例中,虽然颜色的明暗或者亮度是基于子区域的数据来变化的,但是可以以相同的颜色来描绘每个子区域。例如,可以以颜色蓝色描绘每个子区域。视觉特性选择器127可以基于每个子区域的数据来为每个子区域选择蓝色的亮度或者明暗。在又一示例中,可以随机地或者伪随机地选择每个子区域的视觉特性以区分不同子区域。
索引生成器128可以生成电子索引,该电子索引将图像内的位置映射到该图像中所描绘的子区域。例如,电子索引可以将图像的每个x-y坐标映射到其对应子区域。电子索引也可以将每个子区域的数据映射到地图的图像所描绘的子区域。例如,索引生成器128可以从数据选择器113获得子区域的数据。在一些实施方式中,电子索引将子区域的数据映射到指派给子区域的唯一视觉特性(例如,唯一RGB或者RGBA值)。以这种方式,当用户与在子区域处——例如在子区域的x-y坐标中的一个坐标处的图像或者唯一视觉特性交互时,子区域的数据可以从索引中获得并且被呈现给用户。
文件压缩器129可以压缩表示地图的图像的图像文件,以用于通过网络130的更快速的传递以及向客户端设备150的用户的更快速的渲染。在一些实施方式中,文件压缩器129通过使用为图像中描绘的每个子区域选择的唯一视觉特性来压缩图像文件。例如,每个子区域的唯一视觉特性可以是指派给每个子区域的唯一颜色。在该示例中,文件压缩器129可以通过将该子区域的唯一颜色指派给每个特定子区域的图像区来压缩图像文件。以这种方式,图像文件仅仅只需针对每个子区域存储与该子区域相对应的x-y坐标和该子区域的RGB颜色值。客户端设备150的应用(例如,web浏览器)可以使用每个子区域的x-y坐标和每个子区域的唯一RGB颜色来对客户端设备150处的地图的图像进行渲染。
文件压缩器129将压缩的图像文件和由索引生成器128生成的电子索引提供至前端服务器。进而,前端服务器将图像文件和索引提供至客户端设备150。然后,客户端设备150的地图查看器155可以对由交互式地图用户界面中的图像文件表示的地图的图像进行渲染。
前端服务器111也可以将代码、例程、或者脚本提供至客户端设备150,该客户端设备150使得客户端设备150响应于与地图的图像的某些用户交互来执行某些操作。例如,响应于用户将指针(例如,鼠标光标)悬停在与特定子区域相对应的图像的位置上,脚本可以使得客户端设备150访问电子索引以获得和呈现与特定子区域有关的数据。例如,如果用户将指针悬停在特定子区域上,则客户端设备150可以从电子索引获得特定子区域的数据并且将该数据呈现给客户端设备150的用户。客户端设备150可以基于用户交互相对于地图的图像的位置来识别要获得其数据的子区域。例如,客户端设备150可以在悬停事件(例如,指针保持在相同位置中至少阈值时间量)期间检测指针的x-y坐标并且从与检测到的x-y坐标相对应的电子索引中获得数据。在另一示例中,客户端设备150可以确定悬停事件期间在指针的位置处的图像的颜色并且从与该颜色相对应的电子索引中获得数据。
在一些实施方式中,地图用户界面生成器120生成地图的两个图像。第一图像可以是由地图渲染服务器渲染的地图的图像。例如,第一图像可以描绘具有任何道路、水体、地形类型的颜色等的所渲染的地图。第二图像可以是针对特定子区域具有特定RGB颜色的图像。在该示例中,第二图像可以是第一图像上的覆盖层,但是对客户端设备150的用户不可见。作为替代,第二图像可以用于将用户交互的位置映射到图像中所描绘的子区域,如上所述。以这种方式,呈现给用户的地图可能看起来与通常由地图服务122提供的地图相同,同时仍然实现了渲染速度和网络带宽消耗的改进。
在一些实施方式中,地图用户界面生成器120生成地图的附加图像和索引,并且响应于对交互式地图用户界面的请求而将附加图像和索引中的每一个提供至客户端设备150。例如,请求可以指定包括多个子区域的特定区域。在该示例中,地图用户界面生成器120可以生成每个子区域的地图的图像和每个子区域的电子索引。特定子区域的图像可以描绘特定子区域的子区域。类似地,特定子区域的电子索引可以包括特定子区域的每个子区域的数据。
地图用户界面生成器120可以将附加图像和电子索引与响应于请求生成的原始图像一起或者在原始图像已经被传送至客户端设备150之后传送至客户端设备150。客户端设备150可以将附加图像和电子索引存储在客户端设备150的高速缓存中。客户端设备150可以响应于与包括原始图像(或者另一图像)的交互式地图用户界面的用户交互来呈现附加图像。例如,用户可以选择原始图像所描绘的特定子区域。作为响应,客户端设备150可以从高速缓存中获得选择的子区域的图像并且在没有从数据管理系统110请求新的交互式地图用户界面的情况下呈现该图像。以这种方式,可以对子区域的详细地图进行更加快速的渲染并且可以减少网络流量。
图2是示例交互式地图用户界面210的屏幕截图200。在该示例中,交互式地图用户界面210被呈现在web浏览器中。在一些实施方式中,交互式地图用户界面210由另一应用程序呈现,例如本原应用。
示例交互式地图用户界面210包括特定区域的地图的图像220。在该示例中,地图的图像220描绘了若干东南部州。每个州是东南部区域的子区域。虽然未在图2中示出,但是每个州可以包括特定于该州的视觉特性。例如,视觉特性可以是颜色(例如,基于RGB颜色模型)、加明暗、加影线、颜色强度、或者区别于不同州的一些其它适当的视觉特性。在特定示例中,乔治亚(Georgia)州可以是绿色的,而阿拉巴马(Alabama)州可以是蓝色的。在另一示例中,每个州可以是相同的基础颜色。然而,每个州可以是该颜色的不同强度、明暗、或者亮度。例如,每个州可以是不同明暗的蓝色。
每个州的视觉特性可以基于与每个州相对应的数据。例如,交互式地图用户界面210可以针对每个州呈现由于呈现该州中的特定内容项而造成的转化次数。在该示例中,每个州的区以相同的颜色来呈现,其中,该颜色的明暗基于每个州的转化次数。例如,具有最多转化的州可以是最暗的,而具有最少转化的州可以是最亮的。
每个州的数据可以被存储在将数据和视觉特性映射到每个州的电子索引中。当用户例如通过将光标悬停在州上或者选择该州来与该州交互时,可以呈现该州的数据。例如,光标230悬停在乔治亚州上。作为响应,正在覆盖层240中呈现由于正在位于乔治亚州的设备上呈现内容项而发生的内容项的转化次数。在图像220上呈现覆盖层240。具体地,在图像220中的乔治亚州上呈现覆盖层240。
在一些实施方式中,第一种类型的用户交互可以使得数据呈现在图像220上,并且第二种类型的用户交互可以使得不同地图呈现在交互式地图用户界面210中。例如,在某个州上的悬停可以使得该州的数据呈现在该州上的覆盖层中。另外,例如通过点击该州来对该州进行的选择可以使得该州的详细地图被呈现。例如,如果选择了乔治亚州,则可以呈现描绘了乔治亚的子区域的乔治亚的地图。州视图的子区域可以是县、城市、电话区号、zip编码、或者分割较大区域的其它方式。
在一些实施方式中,选择的粒度级别可以基于在选择了该州时交互式地图用户界面的缩放级别。例如,如果缩放级别大于阈值——例如大于100%,则选择可以被视为属于在与发生选择的图像中的位置相对应的州内的县、城市、邮政编码、或者区号。在该示例中,可以将交互式地图用户界面210更新为呈现选择的县、城市、邮政编码、或者区号的地图的图像。如果缩放级别小于阈值——例如小于100%,则选择可以被视为是整个州。在该示例中,可以将交互式地图用户界面210更新为呈现选择的州的地图的图像。
在一些实施方式中,对州的选择(或者另一种类型的用户交互)使得用户界面被呈现,这使得用户能够输入或者修改数据。例如,对州的选择可以使得覆盖层被呈现,这使得用户能够修改或者输入对内容项的竞价,选择针对其来分发内容项的关键词,或者输入另一适当的参数。输入至覆盖层的数据可以应用于选择的州。例如,如果用户在选择乔治亚之后修改竞价,则该竞价可以用于确定是否将内容项呈现在位于乔治亚的客户端设备上。
在一些实施方式中,在正在为特定活动呈现州(或者其它子区域)时对该州的选择导致活动的有效状态与无效状态之间的切换。例如,如果州对于活动是无效的(例如,活动的内容项不适格被提供至位于州中的客户端设备),则对州的选择可以将州的状态切换为活动的有效状态(例如,内容项适格被提供至位于该州中的客户端设备)。在该示例中,响应于选择,客户端设备会将指定州已经针对活动被切换的数据提供至数据管理系统110。作为响应,数据管理系统110可以基于州状态的变化来更新活动的分发准则。
图3是提供交互式地图用户界面的示例过程300的流程图。过程300的操作可以例如由诸如图1的数据管理系统110的一个或者多个数据处理装置实现。过程300也可以由存储在计算机存储介质上的指令实现,其中,数据处理装置对指令的执行使得数据处理装置执行过程300的操作。
接收对呈现交互式地图用户界面的请求(302)。例如,客户端设备可以提交对描绘了特定地理区域的交互式地图用户界面的请求。该请求也可以指定与客户端设备的用户想要查看的特定地理区域有关的数据。例如,请求可以指定南美洲的地理位置和在将内容项呈现在位于南美洲的设备处时特定内容项的选择数据。
通过使用地图服务对特定区域的地图进行渲染(304)。例如,如上所述,地图客户端可以与地图服务交互以生成地图画布、在画布上组织地图图块、将覆盖层定位在地图图块上、将其它地图数据定位在地图上、以及对地图进行渲染,例如,在显示器处或者在存储器中。渲染可以包括生成特定区域的画布并且加载用于生成地图的编程元素(例如,脚本)和图形元素(例如,地图图块、覆盖层等)。
生成表示渲染的地图的图像的图像文件(306)。例如,可以通过截取正在呈现渲染的地图的显示器的屏幕截图来捕获渲染的地图的图像。然后,可以生成表示捕获的图像的图像文件。图像文件可以是PNG、GIF、JPEG、或者其它适当的图像文件格式。
检测图像内的一个或者多个子区域(308)。例如,可以通过使用边界检测技术来检测图像内的边界。然后,可以将边界之间的形状与特定地理区域的已知子区域的形状进行比较来识别子区域。
将不同的视觉特性指派给每个子区域(310)。例如,可以将不同颜色指派给每个子区域。颜色可以基于RGB模型或者另一适当的计算机可读颜色模型。在另一示例中,视觉特性可以是不同的加明暗、加影线、颜色强度、或者一些其它适当的视觉特性。
生成电子索引(312)。电子索引可以将图像内的每个位置映射到包括该位置的对应子区域。电子索引也可以将每个子区域映射到与该子区域有关的数据。例如,可以请求交互式地图用户界面呈现与子区域有关的特定数据。可以将每个子区域的特定数据包括在电子索引中。
在一些实施方式中,电子索引将每个位置的x-y坐标映射到其对应子区域。在一些实施方式中,电子索引将视觉特性映射到子区域。例如,电子索引将每个子区域映射到其唯一RGB颜色。
将客户端设备的用户界面配置为呈现图像(314)。例如,可以将致使呈现图像的数据提供至客户端设备。该数据可以包括表示图像的图像文件、电子索引、和代码(例如例程或者脚本),其使得客户端设备呈现图像。该数据可以使得图像被呈现,其中,根据与不同子区域相对应的不同视觉特性来呈现不同子区域中的每一个。例如,可以将每个子区域以其RGB颜色来呈现。在一些实施方式中,可以在将表示图像的图像文件传送至客户端设备之前压缩该图像文件。在图4中图示压缩图像文件的示例过程并且在下面对其进行描述。
客户端设备可以响应于与图像的用户交互来访问电子索引。例如,如果用户将指针悬停在特定子区域的位置上,则客户端设备可以检测到图像内的悬停的位置(例如,x-y坐标)。然后,客户端设备可以访问电子索引以确定正在被悬停的子区域并且从电子索引检索子区域的数据。然后,客户端设备可以在用户界面中——例如在接收到用户交互的子区域上呈现检索到的数据。
提供至客户端设备的数据可以使得客户端设备响应于某些用户交互来执行其它操作。例如,客户端设备可以响应于对特定子区域处的图像的选择来切换特定子区域的活动的有效/无效状态。在该示例中,脚本可以使得客户端设备将指定特定子区域的有效/无效状态的切换的数据传送至内容递送系统。
在另一示例中,对特定子区域的选择可以使得客户端设备请求特定子区域的地图。在该示例中,脚本可以使得客户端设备访问其高速缓存以确定表示特定子区域的图像的图像文件是否被存储在高速缓存中。如果表示特定子区域的图像的图像文件被存储在高速缓存中,则客户端设备可以从高速缓存中获得该图像文件并且在用户界面中呈现该特定子区域的图像。如果表示特定子区域的图像的图像文件未被存储在高速缓存中,则脚本可以使得客户端设备请求该特定子区域的地图的图像。
图4是压缩图像的示例过程400的流程图。过程400的操作可以例如由诸如图1的文件压缩器129的一个或者多个数据处理装置实现。过程400也可以由存储在计算机存储介质上的指令实现,其中,数据处理装置对指令的执行使得数据处理装置执行过程400的操作。
接收图像文件(402)。图像文件可以表示特定区域的图像并且可以描绘特定区域的子区域。图像文件可以是PNG、GIF、JPEG、或者其它适当的图像文件格式。
接收指定多个不同子区域中的每一个的图像内的位置的数据(404)。例如,数据可以为每个子区域指定在图像内的与每个子区域相对应的x-y坐标(或者x-y坐标的范围)。
为每个子区域识别不同颜色(406)。例如,可以为每个子区域指派基于RGB颜色模型的不同颜色。
压缩图像文件(408)。可以基于每个子区域的位置和指派给每个子区域的颜色来压缩图像文件。例如,图像文件可以针对每个子区域存储指派给该子区域的颜色和其对应位置。因为可以在图像文件中使用比多色子区域更少的数据来表示每个子区域,所以当图像包括单色子区域时,以这种方式压缩图像可以导致每像素低得多的成本(例如,根据每显示像素图像的数据大小)。
通过以这种方式压缩图像,可以通过网络并且通过使用比非压缩图像文件少的带宽来更加快速地传送图像文件。另外,客户端设备的GPU可以比其可以呈现包括图像内的每个位置的详细数据的非压缩图像文件更快速地呈现压缩图像文件。
在一般地参照内容递送管理系统的地图界面描述实施例的同时,要了解,本主题可应用于替选系统,其中,数据被提供至用户并且不限于内容递送管理。
在本说明书中描述的主题和操作的实施例可以以数字电子电路系统,或者以计算机软件、固件、或者硬件,包括在本说明书中公开的结构以及其结构等同物,或者在它们中的一个或者多个的组合来实现。在本说明书中描述的主题的实施例可以实现为一个或者多个计算机程序,即,编码在计算机存储介质上以用于由数据处理装置执行或者控制数据处理装置的操作的计算机程序指令的一个或者多个模块。替选地或者另外,程序指令可以编码在人工生成的传播信号上,例如,机器生成的电、光或者电磁信号,其被生成以编码用于传输到合适的接收器装置的信息以供数据处理装置执行。计算机存储介质可以是或者被包括在计算机可读存储设备、计算机可读存储基底、随机或者串行存取存储器阵列或者设备、或者它们中的一个或者多个的组合中。此外,虽然计算机存储介质不是传播信号,但是计算机存储介质可以是编码在人工生成的传播信号中的计算机程序指令的源或者目的地。计算机存储介质也可以是或者被包括在一个或者多个单独物理组件或者介质(例如,多个CD、磁盘、或者其它存储设备)中。
在本说明书中描述的操作可以实现为由数据处理装置对存储在一个或者多个计算机可读存储设备上或者从其它源接收到的数据执行的操作。
术语“数据处理装置”包含用于处理数据的所有种类的装置、设备、和机器,包括:例如,可编程处理器、计算机、片上系统、或者上述中的多种、或者上述的组合。装置可以包括专用逻辑电路系统,例如,FPGA(现场可编程门阵列)或者ASIC(专用集成电路)。除了硬件之外,装置也可以包括为所讨论的计算机程序创建执行环境的代码,例如,构成处理器固件、协议栈、数据库管理系统、操作系统、跨平台运行时环境、虚拟机、或者它们中的一个或者多个的组合的代码。设备和执行环境可以实现各种不同的计算模型基础架构,诸如web服务、分布式计算和网格计算基础架构。
计算机程序(也称为程序、软件、软件应用、脚本或者代码)可以以任何形式的编码语言编写,包括编译或者解释语言、声明式或者过程式语言,并且其可以以任何形式部署,包括作为独立程序或者作为适合在计算环境中使用的模块、组件、子例程、对象或者其它单元。计算机程序可以但并非必须与文件系统中的文件相对应。程序可以存储在保持其它程序或者数据(例如,存储在标记语言文档中的一个或者多个脚本)的文件的一部分中,或者在专用于所讨论的程序的单个文件中,或者在多个协同文件(例如,存储一个或者多个模块、子程序、或者代码的部分的文件)中。计算机程序可以部署成在一个计算机上或者在位于一个站点或者跨多个站点分布并且通过通信网络互连的多个计算机上执行。
在本说明书中描述的过程和逻辑流可以由执行一个或者多个计算机程序的一个或者多个可编程处理器执行以通过操作输入数据并且生成输出来执行动作。过程和逻辑流还可以由专用逻辑电路系统执行,例如,FPGA(现场可编程门阵列)或者ASIC(专用集成电路),并且设备还可以实现为专用逻辑电路系统。
适合执行计算机程序的处理器包括:例如,通用微处理器、专用微处理器、以及任何种类的数字计算机的任何一个或者多个处理器。一般而言,处理器将接收来自只读存储器或者随机存取存储器或者两者的指令和数据。计算机的必要元件是用于根据指令来执行动作的处理器和用于存储指令和数据的一个或者多个存储器设备。一般而言,计算机还包括用于存储数据的一个或者多个大容量存储设备——例如磁盘、磁光盘、或者光盘,或者可以操作地耦合至其以接收来自其的数据或者将数据传输至其,或者进行这两者。然而,计算机无需具有这样的设备。此外,计算机可以嵌入另一设备中,例如,移动电话、个人数字助理(PDA)、移动音频或者视频播放器、游戏控制台、全球定位系统(GPS)接收器、或者便携式存储设备(例如,通用串行总线(USB)闪存驱动器),仅举几例。适于存储计算机程序指令和数据的设备包括所有形式的非易失性存储器、介质和存储器设备,包括:例如半导体存储器设备——例如EPROM、EEPROM和闪速存储器设备);磁盘——例如内部硬盘或者可移动盘;磁光盘;CD-ROM盘和DVD-ROM盘。处理器和存储器可以由专用逻辑电路系统补充或者可以并入该专用逻辑电路系统中。
为了提供与用户的交互,在本说明书中描述的主题的实施例可以实现在具有以下的计算机上:用于向用户显示信息的显示设备,例如,CRT(阴极射线管)或者LCD(液晶显示器)监视器;以及键盘和指示设备,例如,鼠标或者轨迹球,通过该键盘和该指示设备用户可以向计算机提供输入。也可以使用其它种类的设备来提供与用户的交互;例如,向用户提供的反馈可以是任何形式的感官反馈,例如,视觉反馈、听觉反馈、或者触觉反馈;并且可以以任何形式接收来自用户的输入,该形式包括声音、语音、或者触觉输入。另外,计算机可以响应于从web浏览器接收到的请求,通过将文档发送至用户所使用的设备并且从该设备接收文档——例如通过将网页发送至用户的客户端设备上的web浏览器来与用户交互。
在本说明书中描述的主题的实施例可以实现在计算系统中,该计算系统包括例如作为数据服务器的后端组件,或者包括例如应用服务器的中间件组件,或者包括例如具有用户通过其可以与在本说明书中描述的主题的实施方式交互的图形用户界面或者web浏览器的客户端计算机、或者一个或者多个这样的后端、中间件、或者前端组件的任何组合。系统的组件可以通过例如通信网络的任何形式或者介质的数字数据通信互连。通信网络的示例包括局域网(“LAN”)和广域网(“WAN”)、互连网络(例如,互联网)、和点对点网络(例如,adhoc点对点网络)。
计算系统可以包括客户端和服务器。客户端和服务器一般彼此远离并且通常通过通信网络交互。客户端和服务器的关系依靠在每个计算机上运行并且彼此具有客户端-服务器关系的计算机程序产生。在一些实施例中,服务器将数据(例如,HTML页面)传送至客户端设备(例如,为了向与客户端设备交互的用户显示数据并且从该用户接收用户输入)。可以从服务器处的客户端设备接收在客户端设备处生成的数据(例如,用户交互的结果)。
虽然本说明书包含许多具体的实施方式细节,但是这些细节不应当被解释为对可以要求保护的权利要求的范围的限制,而是应当被解释为对特定实施例特有的特征的描述。本说明书在单独实施例的场境(context)下所描述的某些特征也可以在单个实施例中以组合的方式实现。相反,在单个实施例的场境下描述的各种特征也可以单独地在多个实施例中或者以任何合适的子组合实现。此外,虽然特征可能在上面被描述为在某些组合中起作用,并且甚至最初被如此要求保护,但是来自所要求保护的组合中的一个或者多个特征在一些情况下可以从组合删去,以及所要求保护的组合可以涉及子组合或者子组合的变体。
类似地,虽然操作在附图中以特定的顺序描述,但是这不应当被理解为要求以示出的特定顺序或者以相继顺序来执行这样的操作,或者需要所有图示的操作被执行来获得期望结果。在某些情况下,多任务处理和并行处理可能是有益的。此外,在上面所描述的实施例中的各个系统组件的分离不应当被理解为在所有的实施例中都要求这样的分离,并且应当理解所描述的程序组件和系统通常可以被一起整合在单个软件产品中或者封装到多个软件产品中。
因此,已经描述了主题的特定实施例。其它实施例在所附权利要求书的范围内。在某些情况下,在权利要求书中记载的动作可以按照不同的顺序来执行并且仍然获得期望的结果。另外,在附图中描绘的过程不必要求所示的特定顺序或者相继顺序来获得期望的结果。在某些实施方式中,多任务处理和并行处理可能是有益的。
Claims (15)
1.一种方法,包括:
从客户端设备接收对呈现交互式地图用户界面的请求,所述交互式地图用户界面描绘(i)特定地理区域和(ii)与所述特定区域的多个不同的子区域的在线账户有关的数据;
由一个或多个服务器使用地图服务对所述特定区域的地图进行渲染,所述渲染包括生成所述特定区域的画布并且加载用于生成所述地图的多个编程元素和图形元素;
由所述一个或多个服务器基于所渲染的地图来生成表示所渲染的地图的图像的图像文件;
至少基于所述图像所描绘的视觉边界来检测在所述图像内的一个或多个子区域;
为所述图像内的每个不同的子区域指派不同的视觉特性;
生成电子索引,所述电子索引将所述图像内的每个位置映射到包括该位置的对应子区域;以及
由所述一个或者多个服务器配置所述客户端设备的用户界面以:(i)呈现所述图像,其中所述不同的子区域中的每个不同的子区域根据与该不同的子区域相对应的不同的视觉特性来呈现;以及(ii)当所述客户端设备检测到与所述图像的至少一个给定子区域的用户交互时,呈现与所述给定子区域有关的账户数据。
2.根据权利要求1所述的方法,其中,每个子区域的视觉特性包括指派给该子区域并且被呈现在所述图像中的该子区域内的特定颜色。
3.根据权利要求1或2所述的方法,进一步包括使用压缩技术来减小所述图像文件的数据大小,所述压缩技术包括:
为所述图像的每个子区域指派特定红、绿、蓝(RGB)颜色,所述图像的该子区域以所述特定红、绿、蓝(RGB)颜色来呈现;以及
在所述图像文件中针对每个特定子区域存储该子区域的RGB颜色和指定该特定子区域在所述图像内的位置的数据。
4.根据任何前述权利要求所述的方法,进一步包括:
在所述一个或者多个服务器处从所述客户端设备接收指定对所述图像内的特定位置的选择的数据;
响应于所述选择而生成经更新的图像,所述经更新的图像描绘与所选择的位置相对应的特定子区域的地图,所述生成包括使用所述地图服务对所述特定子区域的地图进行渲染以及生成所渲染的地图的图像;以及
将表示所述经更新的图像的图像文件提供至所述客户端设备。
5.根据权利要求4所述的方法,进一步包括:
从所述客户端设备接收指定在所述选择时所述图像的缩放级别的数据;
基于所述缩放级别来确定所述选择的粒度级别;以及
基于所述选择的所述粒度级别来确定与所选择的位置相对应的特定子区域。
6.根据任何前述权利要求所述的方法,其中,所述图像文件包括便携式网络图形(PNG)文件格式。
7.根据任何前述权利要求所述的方法,进一步包括:由所述一个或多个服务器响应于所述请求并且在接收到对一个或多个附加图像文件的请求之前将所述一个或多个附加图像文件提供至所述客户端设备,所述一个或多个附加图像文件各自表示所述子区域中的至少一个子区域的地图。
8.一种系统,包括:
第一前端服务器,所述第一前端服务器从客户端设备接收对呈现交互式地图用户界面的请求,所述交互式地图用户界面描绘(i)特定地理区域和(ii)与所述特定区域的多个不同的子区域的在线账户有关的数据;
地图渲染服务器,所述地图渲染服务器与所述前端服务器数据通信,以及通过生成所述特定区域的画布并且加载用于生成所述地图的多个编程元素和图形元素来使用地图服务对所述特定区域的地图进行渲染;
地图图像文件生成器,所述地图图像文件生成器基于所渲染的地图来生成表示所渲染的地图的图像的图像文件;
至少基于所述图像所描绘的视觉边界来检测在所述图像内的一个或多个子区域;以及
为所述图像内的每个不同的子区域指派不同的视觉特性;以及生成电子索引,所述电子索引将所述图像内的每个位置映射到包括该位置的对应子区域;以及
第二前端服务器,所述第二前端服务器配置所述客户端设备的用户界面以:(i)呈现所述图像,其中所述不同的区域中的每个不同的区域根据与该不同的区域相对应的不同的视觉特性来呈现;以及(ii)当所述客户端设备检测到与所述图像的至少一个给定子区域的用户交互时,呈现与所述给定子区域有关的账户数据。
9.根据权利要求8所述的系统,进一步包括文件压缩器,所述文件压缩器通过使用压缩技术对存储所述图像的图像文件的数据大小进行压缩,所述压缩技术包括:
为所述图像的每个子区域指派特定红、绿、蓝(RGB)颜色,所述图像的该子区域以所述特定红、绿、蓝(RGB)颜色来呈现;以及
在所述图像文件中针对每个特定子区域存储该子区域的RGB颜色和指定该特定子区域在所述图像内的位置的数据。
10.根据权利要求8或9所述的系统,其中,每个子区域的视觉特性包括指派给该子区域并且被呈现在所述图像中的该子区域内的特定颜色。
11.根据权利要求8至10中的任一项所述的系统,其中:
所述第一前端服务器从所述客户端设备接收指定对所述图像内的特定位置的选择的数据;
所述地图图像文件生成器响应于所述选择而生成经更新的图像,所述经更新的图像描绘与所选择的位置相对应的特定子区域的地图,所述生成包括使用所述地图服务对所述特定子区域的地图进行渲染以及生成所渲染的地图的图像;以及
所述第二前端服务器将表示所述经更新的图像的图像文件提供至所述客户端设备。
12.根据权利要求11所述的系统,其中:
所述第一前端服务器从所述客户端设备接收指定在所述选择时所述图像的缩放级别的数据;
所述地图渲染服务器基于所述缩放级别来确定所述选择的粒度级别;以及
所述地图渲染服务器基于所述选择的所述粒度级别来确定与所选择的位置相对应的特定子区域。
13.根据权利要求8至12中的任一项所述的系统,其中,所述图像文件包括便携式网络图形(PNG)文件格式。
14.根据权利要求8至13中的任一项所述的系统,其中,所述第二前端服务器响应于所述请求并且在接收到对一个或多个附加图像文件的请求之前,将所述一个或多个附加图像文件提供至所述客户端设备,所述一个或多个附加图像文件各自表示所述子区域中的至少一个子区域的地图。
15.一种编码有计算机程序的非暂时性计算机存储介质,所述程序包括指令,所述指令在由一个或多个数据处理装置执行时使所述数据处理装置执行包括根据权利要求1至7中的任一项所述的方法的操作。
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US15/005,820 | 2016-01-25 | ||
US15/005,820 US9922426B2 (en) | 2016-01-25 | 2016-01-25 | Reducing latency in presenting map interfaces at client devices |
PCT/US2016/064399 WO2017131858A1 (en) | 2016-01-25 | 2016-12-01 | Reducing latency in map interfaces |
Publications (1)
Publication Number | Publication Date |
---|---|
CN107231817A true CN107231817A (zh) | 2017-10-03 |
Family
ID=57796962
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
CN201680003888.1A Pending CN107231817A (zh) | 2016-01-25 | 2016-12-01 | 降低地图界面中的时延 |
Country Status (7)
Country | Link |
---|---|
US (3) | US9922426B2 (zh) |
EP (1) | EP3408833A1 (zh) |
JP (2) | JP6648285B2 (zh) |
KR (2) | KR102366752B1 (zh) |
CN (1) | CN107231817A (zh) |
AU (3) | AU2016389048B2 (zh) |
WO (1) | WO2017131858A1 (zh) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112074813A (zh) * | 2018-03-30 | 2020-12-11 | 完整故事有限公司 | 捕获并处理与原生应用的用户界面的交互 |
CN112433651A (zh) * | 2020-11-13 | 2021-03-02 | 北京鸿腾智能科技有限公司 | 区域识别方法、设备、存储介质及装置 |
CN116774900A (zh) * | 2023-08-24 | 2023-09-19 | 中招国际招标有限公司 | 一种工程项目管理系统的电子地图的交互方法 |
Families Citing this family (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR102181345B1 (ko) * | 2018-02-20 | 2020-11-20 | 한국전자통신연구원 | 이미지 타일 가시화 정보의 계층적 표현을 이용한 이미지 표현 방법, 이를 이용하는 디바이스 및 시스템 |
CN108671541B (zh) * | 2018-04-27 | 2021-09-28 | 腾讯科技(深圳)有限公司 | 一种数据存储方法和装置以及存储介质 |
US11145092B2 (en) * | 2018-08-08 | 2021-10-12 | Adobe Inc. | Graphical element color diffusion techniques |
CN109542987B (zh) * | 2018-10-09 | 2021-10-22 | 中国电子科技集团公司第二十八研究所 | 一种基于Canvas的在线地图保存方法 |
KR20210037774A (ko) | 2019-09-27 | 2021-04-07 | 주식회사 현대제이콤 | 지도를 위한 파일 관리 방법 |
CN112115224B (zh) * | 2020-09-24 | 2024-03-08 | 北京百度网讯科技有限公司 | 地图数据的辅助质检方法、装置、电子设备及存储介质 |
US20230118450A1 (en) | 2021-10-15 | 2023-04-20 | Lognovations Holdings, Llc | Encoding / Decoding System and Method |
CN115272945B (zh) * | 2022-09-27 | 2023-01-03 | 江苏衣升元气服饰科技有限公司 | 适用于服装的数据处理方法及装置 |
CN117332102B (zh) * | 2023-11-30 | 2024-02-06 | 陕西建一建设有限公司 | 一种基于bim的建筑数据优化存储方法 |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN101477559A (zh) * | 2009-01-20 | 2009-07-08 | 华南理工大学 | 基于区域着色的地理信息感知方法 |
CN101957839A (zh) * | 2010-09-15 | 2011-01-26 | 苏州恩巨网络有限公司 | 一种地图文件格式 |
CN102067155A (zh) * | 2008-04-25 | 2011-05-18 | 普得有限公司 | 一种用于收集和处理零售店库存数据的方法和系统 |
US20130101214A1 (en) * | 2011-10-25 | 2013-04-25 | John T. Sample | System and method for converting source image data to tile data |
US20130328941A1 (en) * | 2012-06-10 | 2013-12-12 | Apple Inc. | Scalable Processing for Associating Geometries with Map Tiles |
US20140173520A1 (en) * | 2010-05-21 | 2014-06-19 | Telecommunication Systems, Inc. | Personal Wireless Navigation System |
CN104685533A (zh) * | 2012-07-03 | 2015-06-03 | 优步科技公司 | 用于提供按需服务的动态供应定位的系统和方法 |
US20160018951A1 (en) * | 2014-07-17 | 2016-01-21 | Microsoft Corporation | Contextual view portals |
Family Cites Families (37)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP3882569B2 (ja) * | 1996-01-11 | 2007-02-21 | ソニー株式会社 | 情報処理方法及び装置、情報提供方法及び装置 |
JP3503397B2 (ja) | 1997-02-25 | 2004-03-02 | Kddi株式会社 | 地図表示システム |
GB2346786A (en) | 1999-02-09 | 2000-08-16 | Ibm | Image maps |
US7447509B2 (en) * | 1999-12-22 | 2008-11-04 | Celeritasworks, Llc | Geographic management system |
KR20010088887A (ko) * | 2001-02-02 | 2001-09-29 | 유명순 | 지도 인터페이스를 이용한 생활 정보 제공 방법 |
CA2335445A1 (en) * | 2001-02-09 | 2002-08-09 | Lasoo Inc. | Internet search tool using geographically selective features |
US7120293B2 (en) | 2001-11-30 | 2006-10-10 | Microsoft Corporation | Interactive images |
AU2003228329A1 (en) | 2002-03-15 | 2003-09-29 | Summus, Inc. | Methods and systems for downloading and viewing maps |
US20060058953A1 (en) | 2004-09-07 | 2006-03-16 | Cooper Clive W | System and method of wireless downloads of map and geographic based data to portable computing devices |
US20060058951A1 (en) | 2004-09-07 | 2006-03-16 | Cooper Clive W | System and method of wireless downloads of map and geographic based data to portable computing devices |
US7746343B1 (en) * | 2005-06-27 | 2010-06-29 | Google Inc. | Streaming and interactive visualization of filled polygon data in a geographic information system |
JP4812661B2 (ja) * | 2006-03-27 | 2011-11-09 | 株式会社デンソーアイティーラボラトリ | 地図表示システムおよび地図表示方法 |
US7707379B2 (en) | 2006-07-13 | 2010-04-27 | International Business Machines Corporation | Dynamic latency map for memory optimization |
KR20080018405A (ko) * | 2006-08-24 | 2008-02-28 | 한국문화콘텐츠진흥원 | 3차원 지형의 제작을 제공하는 지형 제작 프로그램을기록한 컴퓨터 판독가능 기록매체 |
US8368695B2 (en) * | 2007-02-08 | 2013-02-05 | Microsoft Corporation | Transforming offline maps into interactive online maps |
US8739123B2 (en) | 2007-05-28 | 2014-05-27 | Google Inc. | Incorporating gadget functionality on webpages |
US8190585B2 (en) * | 2010-02-17 | 2012-05-29 | Lockheed Martin Corporation | Supporting multiple different applications having different data needs using a voxel database |
US9183221B2 (en) | 2010-08-11 | 2015-11-10 | Root Wireless, Inc. | Component and method for overlying information bearing hexagons on a map display |
US9535537B2 (en) | 2010-11-18 | 2017-01-03 | Microsoft Technology Licensing, Llc | Hover detection in an interactive display device |
US20120213416A1 (en) * | 2011-02-23 | 2012-08-23 | Google Inc. | Methods and systems for browsing heterogeneous map data |
TW201303624A (zh) * | 2011-07-05 | 2013-01-16 | Hon Hai Prec Ind Co Ltd | 書籍資訊查閱系統及方法 |
US8560600B2 (en) | 2011-09-26 | 2013-10-15 | Google Inc. | Managing map elements using aggregate feature identifiers |
US8803920B2 (en) | 2011-12-12 | 2014-08-12 | Google Inc. | Pre-fetching map tile data along a route |
US20130325343A1 (en) * | 2012-06-05 | 2013-12-05 | Apple Inc. | Mapping application with novel search field |
US20130321400A1 (en) * | 2012-06-05 | 2013-12-05 | Apple Inc. | 3D Map Views for 3D Maps |
US8781735B2 (en) * | 2012-06-25 | 2014-07-15 | Google Inc. | Adaptive clustering of locations |
JP2012248204A (ja) * | 2012-07-19 | 2012-12-13 | Zenrin Datacom Co Ltd | 案内情報送信装置 |
US9691128B2 (en) * | 2012-09-20 | 2017-06-27 | Facebook, Inc. | Aggregating and displaying social networking system user information via a map interface |
US8520018B1 (en) | 2013-01-12 | 2013-08-27 | Hooked Digital Media | Media distribution system |
SE539172C2 (sv) * | 2013-03-13 | 2017-05-02 | Smart Climate Scandinavian Ab | Klimatanläggning avsedd att temporärt anslutas till minst ett flygplan |
US9208170B1 (en) | 2013-03-15 | 2015-12-08 | Google Inc. | Classifying natural mapping features |
US9471959B2 (en) | 2013-05-15 | 2016-10-18 | Google Inc. | Water color gradients on a digital map |
US9710882B2 (en) * | 2013-06-25 | 2017-07-18 | Iteris Inc. | Data overlay for animated map weather display and method of rapidly loading animated raster data |
US9905043B2 (en) * | 2013-09-10 | 2018-02-27 | Microsoft Technology Licensing, Llc | Techniques to generate digital maps |
CA2932747C (en) * | 2013-12-04 | 2023-04-11 | Urthecast Corp. | Systems and methods for processing distributing earth observation images |
US9495767B2 (en) | 2014-05-15 | 2016-11-15 | Google Inc. | Indexed uniform styles for stroke rendering |
US9600146B2 (en) * | 2015-08-17 | 2017-03-21 | Palantir Technologies Inc. | Interactive geospatial map |
-
2016
- 2016-01-25 US US15/005,820 patent/US9922426B2/en active Active
- 2016-12-01 WO PCT/US2016/064399 patent/WO2017131858A1/en active Application Filing
- 2016-12-01 JP JP2018538767A patent/JP6648285B2/ja active Active
- 2016-12-01 KR KR1020207008831A patent/KR102366752B1/ko active IP Right Grant
- 2016-12-01 EP EP16826210.3A patent/EP3408833A1/en active Pending
- 2016-12-01 AU AU2016389048A patent/AU2016389048B2/en active Active
- 2016-12-01 KR KR1020187022781A patent/KR102096497B1/ko active IP Right Grant
- 2016-12-01 CN CN201680003888.1A patent/CN107231817A/zh active Pending
- 2016-12-14 US US15/379,167 patent/US10311572B2/en active Active
- 2016-12-19 US US15/383,902 patent/US10176584B2/en active Active
-
2019
- 2019-05-30 AU AU2019203802A patent/AU2019203802B2/en active Active
-
2020
- 2020-01-14 JP JP2020003689A patent/JP6853391B2/ja active Active
- 2020-03-06 AU AU2020201699A patent/AU2020201699B2/en active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN102067155A (zh) * | 2008-04-25 | 2011-05-18 | 普得有限公司 | 一种用于收集和处理零售店库存数据的方法和系统 |
CN101477559A (zh) * | 2009-01-20 | 2009-07-08 | 华南理工大学 | 基于区域着色的地理信息感知方法 |
US20140173520A1 (en) * | 2010-05-21 | 2014-06-19 | Telecommunication Systems, Inc. | Personal Wireless Navigation System |
CN101957839A (zh) * | 2010-09-15 | 2011-01-26 | 苏州恩巨网络有限公司 | 一种地图文件格式 |
US20130101214A1 (en) * | 2011-10-25 | 2013-04-25 | John T. Sample | System and method for converting source image data to tile data |
US20130328941A1 (en) * | 2012-06-10 | 2013-12-12 | Apple Inc. | Scalable Processing for Associating Geometries with Map Tiles |
CN104685533A (zh) * | 2012-07-03 | 2015-06-03 | 优步科技公司 | 用于提供按需服务的动态供应定位的系统和方法 |
US20160018951A1 (en) * | 2014-07-17 | 2016-01-21 | Microsoft Corporation | Contextual view portals |
Non-Patent Citations (1)
Title |
---|
CHARLES R. SCHMIDT ET AL.: ""Working Paper 2008-13 A Scalable Tile Map Service for Distributing Dynamic Choropleth Maps"", 《GEODA CENTER FOR GEOSPATIAL ANALYSIS AND COMPUTATION》 * |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
CN112074813A (zh) * | 2018-03-30 | 2020-12-11 | 完整故事有限公司 | 捕获并处理与原生应用的用户界面的交互 |
CN112433651A (zh) * | 2020-11-13 | 2021-03-02 | 北京鸿腾智能科技有限公司 | 区域识别方法、设备、存储介质及装置 |
CN116774900A (zh) * | 2023-08-24 | 2023-09-19 | 中招国际招标有限公司 | 一种工程项目管理系统的电子地图的交互方法 |
CN116774900B (zh) * | 2023-08-24 | 2023-12-12 | 中招国际招标有限公司 | 一种工程项目管理系统的电子地图的交互方法 |
Also Published As
Publication number | Publication date |
---|---|
US20170213362A1 (en) | 2017-07-27 |
US9922426B2 (en) | 2018-03-20 |
US20170213348A1 (en) | 2017-07-27 |
AU2020201699A1 (en) | 2020-03-26 |
US20170212909A1 (en) | 2017-07-27 |
AU2019203802A1 (en) | 2019-06-20 |
US10176584B2 (en) | 2019-01-08 |
AU2016389048B2 (en) | 2019-05-16 |
KR20180101477A (ko) | 2018-09-12 |
AU2019203802B2 (en) | 2020-02-27 |
AU2020201699B2 (en) | 2020-04-16 |
JP2019510292A (ja) | 2019-04-11 |
AU2016389048A1 (en) | 2018-08-16 |
JP6853391B2 (ja) | 2021-03-31 |
EP3408833A1 (en) | 2018-12-05 |
JP2020074155A (ja) | 2020-05-14 |
KR102096497B1 (ko) | 2020-04-02 |
KR20200035491A (ko) | 2020-04-03 |
WO2017131858A1 (en) | 2017-08-03 |
US10311572B2 (en) | 2019-06-04 |
JP6648285B2 (ja) | 2020-02-14 |
KR102366752B1 (ko) | 2022-02-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
CN107231817A (zh) | 降低地图界面中的时延 | |
CN111754614B (zh) | 基于vr视频渲染方法、装置、电子设备及存储介质 | |
WO2012071147A1 (en) | Selection of foreground characteristics based on background | |
TW201108152A (en) | Displaying a visual representation of performance metrics for rendered graphics elements | |
CN114669047B (zh) | 一种图像处理方法、电子设备及存储介质 | |
CN115170390B (zh) | 一种文件风格化方法、装置、设备及存储介质 | |
CN116091329B (zh) | 图像处理方法、装置、设备及存储介质 | |
CN118172229A (zh) | 图像渲染方法、装置、电子设备和可读存储介质 | |
CN117707676A (zh) | 窗口渲染方法、装置、设备、存储介质及程序产品 | |
US20180276878A1 (en) | System and method for rendering shadows for a virtual environment | |
CN106802856A (zh) | 游戏应用程序的性能测试方法、服务器和游戏应用客户端 | |
CN111402348B (zh) | 光照效果的形成方法、装置和渲染引擎 | |
CN112486993A (zh) | 空气质量可视化显示方法及空气质量可视化显示系统 | |
CN108335362A (zh) | 虚拟场景中的光线控制方法、装置及vr设备 | |
US11356547B2 (en) | Background display method and apparatus during call, and storage medium | |
CN118134812A (zh) | 一种图像显示切换方法、装置、电子设备及存储介质 | |
CN116966588A (zh) | 材质管理的方法、装置、电子设备及存储介质 | |
CN117710180A (zh) | 图像渲染方法及相关设备 | |
CN118245208A (zh) | 一种数字孪生体的显示方法及终端设备 | |
CN115006848A (zh) | 云游戏资源分配方法、装置、计算机设备和存储介质 | |
CN117435100A (zh) | 元素展示的方法、装置、计算机设备和存储介质 | |
CN107273480A (zh) | 新闻模板的管理方法及装置 |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PB01 | Publication | ||
PB01 | Publication | ||
SE01 | Entry into force of request for substantive examination | ||
SE01 | Entry into force of request for substantive examination | ||
CB02 | Change of applicant information | ||
CB02 | Change of applicant information |
Address after: American California Applicant after: Google limited liability company Address before: American California Applicant before: Google Inc. |