我希望能够轻松地在 Google map 上存储和重新显示 Google map 路线。假设从 A 点到 B 点,DirectionsResult来自 Google 的对象沿路线有 100 个点,我希望能够存储这条路线并保证下次我绘制它时方向将经过所有这些点。
我见过人们尝试这样做的方法是序列化整个 DirectionsResult 对象并将其存储在数据库中。然后,当我们想要重绘路线时,将字符串发回,JSON.Parse,然后尝试将其提供给 DirectionsRenderer。将在 map 上呈现方向的对象。这种方法存在三个问题:
1) 您在序列化过程中丢失了类型信息,并且由于 Google 缩小了对象,您无法使用类函数可靠地从对象中获取这些值。您需要在最初序列化对象时首先使用数据访问器函数构建“占位符”对象,然后在稍后解析序列化字符串时重建 Google Maps 对象。
2) 这在法律上是可疑的。 Google Maps TOS 表示您不应该永久存储数据,从其他帖子看来,这种方法似乎违反了它。
3) 对象可以很大,我序列化的一条路由超过了 64KB。
我还考虑过尝试存储路径中的几个点,然后使用 Waypoints 重建它。这种方法有效,但免费 API 最多只能有 8 个点,因此这不能保证超过这 8 个点的准确性。此外,它还会沿路线绘制航路点标记,我认为这可能会使用户感到困惑。
是否有一种公认的方法来存储来自 Google map 的准确路线,或者 API 和 TOS 是否有意设计来防止这种情况发生?感谢您的帮助。
最佳答案
我认为这在法律上是可疑的。事实上,它几乎肯定违反了 Terms of Service .正如您所指出的,它是用于提高性能以外目的的永久存储(与 10.1.3(b) 相反);但它也旨在显示方向而不通过 API 获取方向(与 10.1.1(a) 相反)。谷歌没有让它变得容易这一事实意味着他们没有授权这个用例。事实上,TOS 和 API 旨在使这样的存储变得困难,如果不是不可能的话。
当你想再次显示它时,存储起点和终点并让 API 计算出路线是否可以接受?
关于javascript - 存储完整的谷歌地图路线,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9296407/
我主要使用Ruby来执行此操作,但到目前为止我的攻击计划如下:使用gemsrdf、rdf-rdfa和rdf-microdata或mida来解析给定任何URI的数据。我认为最好映射到像schema.org这样的统一模式,例如使用这个yaml文件,它试图描述数据词汇表和opengraph到schema.org之间的转换:#SchemaXtoschema.orgconversion#data-vocabularyDV:name:namestreet-address:streetAddressregion:addressRegionlocality:addressLocalityphoto:i
我正在编写一个简单的静态Rack应用程序。查看下面的config.ru代码:useRack::Static,:urls=>["/elements","/img","/pages","/users","/css","/js"],:root=>"archive"map'/'dorunProc.new{|env|[200,{'Content-Type'=>'text/html','Cache-Control'=>'public,max-age=6400'},File.open('archive/splash.html',File::RDONLY)]}endmap'/pages/search.
我去了这个website查看Rails5.0.0和Rails5.1.1之间的区别为什么5.1.1不再包含:config/initializers/session_store.rb?谢谢 最佳答案 这是删除它的提交:Setupdefaultsessionstoreinternally,nolongerthroughanapplicationinitializer总而言之,新应用没有该初始化器,session存储默认设置为cookie存储。即与在该初始值设定项的生成版本中指定的值相同。 关于
我遇到了一个非常奇怪的问题,我很难解决。在我看来,我有一个与data-remote="true"和data-method="delete"的链接。当我单击该链接时,我可以看到对我的Rails服务器的DELETE请求。返回的JS代码会更改此链接的属性,其中包括href和data-method。再次单击此链接后,我的服务器收到了对新href的请求,但使用的是旧的data-method,即使我已将其从DELETE到POST(它仍然发送一个DELETE请求)。但是,如果我刷新页面,HTML与"new"HTML相同(随返回的JS发生变化),但它实际上发送了正确的请求类型。这就是这个问题令我困惑的
我正在关注Hartl的railstutorial.org并已到达11.4.4:Imageuploadinproduction.我做了什么:注册亚马逊网络服务在AmazonIdentityandAccessManagement中,我创建了一个用户。用户创建成功。在AmazonS3中,我创建了一个新存储桶。设置新存储桶的权限:权限:本教程指示“授予上一步创建的用户读写权限”。但是,在存储桶的“权限”下,未提及新用户名。我只能在每个人、经过身份验证的用户、日志传送、我和亚马逊似乎根据我的名字+数字创建的用户名之间进行选择。我已经通过选择经过身份验证的用户并选中了上传/删除和查看权限的框(而不
我正在使用mechanize登录网站,然后检索页面。我遇到了一些问题,我怀疑这是由于cookie中的某些值造成的。当Mechanize登录网站时,我假设它存储了cookie。如何通过Mechanize打印出存储在cookie中的所有数据? 最佳答案 代理有一个cookie方法。agent=Mechanize.newpage=agent.get("http://www.google.com/")agent.cookiesagent.cookies.to_scookie返回一个Mechanize::Cookiesobject
我以为它们存储在cookie中-但不,检查cookie没有任何结果。session也不存储它们。那么,我在哪里可以找到它们?我需要这个来直接设置它们(而不是通过flashhash)。 最佳答案 它们存储在inyoursessionstore.自rails2.0以来的默认设置是cookie存储,但请检查config/initializers/session_store.rb以检查您是否使用默认设置以外的东西。 关于ruby-on-rails-闪存消息存储在哪里?,我们在StackOverf
如何只加载map边界内的标记gmaps4rails?当然,在平移和/或缩放后加载新的。与此直接相关的是,如何获取map的当前边界和缩放级别? 最佳答案 我是这样做的,我只在用户完成平移或缩放后替换标记,如果您需要不同的行为,请使用不同的事件监听器:在你看来(index.html.erb):{"zoom"=>15,"auto_adjust"=>false,"detect_location"=>true,"center_on_user"=>true}},false,true)%>在View的底部添加:functiongmaps4rail
对于我正在编写的Rails3应用程序,我正在考虑从本地文件系统上的XML、YAML或JSON文件中读取一些配置数据。重点是:我应该把这些文件放在哪里?Rails应用程序中是否有用于存储此类内容的默认位置?附带说明一下,我的应用程序部署在Heroku上。 最佳答案 我经常做的是:如果文件是通用配置文件:我在目录/config中创建一个YAML文件,每个环境有一个上层key如果我为每个环境(大项目)创建一个文件:我为每个环境创建一个YAML并将它们存储在/config/environments/然后我在加载YAML的地方创建了一个初始化
我有这个:AccountSummary我想单击该链接,但在使用link_to时出现错误。我试过:bot.click(page.link_with(:href=>/menu_home/))bot.click(page.link_with(:class=>'top_level_active'))bot.click(page.link_with(:href=>/AccountSummary/))我得到的错误是:NoMethodError:nil:NilClass的未定义方法“[]” 最佳答案 那是一个javascript链接。Mechan