Routeboxer服务器端

时间:2013-12-25 13:59:00

标签: php android mysql google-maps

我正试图找到一种方法来获取谷歌的路由器到php的经度和经度范围,然后通过这些限制查询mysql。然后我将结果输出到json或xml以使用android maps api v2。我发现了这个http://luktek.com/Blog/2011-02-03-google-maps-routeboxer-in-php,但我认为这只能在地图上的两个点之间进行框,而不是路线本身周围的框,这使得它不够准确。使用javascript不是一个选项,因为我不能将它与google maps api一起使用或从我的数据库中获取结果。有没有办法通过使用一些服务器端代码(最好是PHP,但也可以使用任何其他适用于mysql的语言)来实现这一点,它可以获取边界,查询mysql并将数据输出到json或xml这样它可以被android解析吗?

2 个答案:

答案 0 :(得分:5)

我终于找到了一个我满意的解决方案。 我不会粘贴每一步,因为它会占用千条线,但简而言之: 1.从Google方向api json(https://developers.google.com/maps/documentation/directions/#JSON)解析此字段:" overview_polyline":{
2.使用以下方法将折线解码为纬度和经度点: http://unitstep.net/blog/2008/08/02/decoding-google-maps-encoded-polylines-using-php/
3.下载此https://github.com/bazo/route-boxer。我将GeoTools php文件中的所有代码堆积到一个文件中,但如果你知道如何使用它,则不是必要的。 4.以下是使用这些脚本获取这些框的示例:

...

$from = "(Startup point for example: "Turku,Finland")";
$to = "(Destination point fro example: "Porvoo,Finland")";

$json_string = file_get_contents("http://maps.googleapis.com/maps/api/directions/json?origin=$from&destination=$to&sensor=false");
$parsed_json = json_decode($json_string, true);

$polyline = $parsed_json['routes'][0]['overview_polyline']['points'];

$routepoints = decodePolylineToArray($polyline);

$collection = new LatLngCollection($routepoints);

$boxer = new RouteBoxer();

//calculate boxes with 10km distance from the line between points
$boxes = $boxer->box($collection, $distance = 10);

foreach($boxes as $row){

$southWestLtd = $row->southWest->latitude;
$southWestLng = $row->southWest->longitude;
$northEastLtd = $row->northEast->latitude;
$northEastLng = $row->northEast->longitude;

$query = "SELECT * FROM markers WHERE Latitude > $southWestLtd AND Latitude < $northEastLtd AND Longitude > $southEastLng AND Longitude < $norhtEastLng";

}

运行该查询,它只会为您提供这些框内的标记(或您正在查询的内容)。如果您需要更详细的说明,请发表评论。我非常乐意提供帮助,因为我花了很多夜时才想找到一个合理的解决方案。

答案 1 :(得分:2)

这里有很多问题,让我试着解决一些问题: 从routeboxer获取lat和long边界:    一旦你有了'盒子',你就可以循环并获得这些

var northeast = boxes[i].getNorthEast();
var southwest = boxes[i].getSouthWest();
var lat_north = northeast.lat();
var long_east = northeast.lng();

var lat_south = southwest.lat();
var long_west = southwest.lng();

&GT;在这里只能在地图上的两个点之间做框,而不是在路线本身周围的框,这使得它不够准确

我不知道Routeboxer的这个人的实现,但API v3的原始Google Routeboxer在整个路线周围创建了框。这是有记录的,我可以自信地说,它是如何工作的(我已经用过) http://google-maps-utility-library-v3.googlecode.com/svn/trunk/routeboxer/docs/examples.html

&GT;使用javascript不是一个选项,因为我不能将它与google maps api一起使用或从我的数据库中获取结果。

这一点对我来说没什么意义。您肯定可以使用带有Javascript的Google Maps API ,有一个专门针对此目的的Javascript库(已经是版本3)。如果这是一个浏览器应用程序,我强烈建议坚持使用它,至少在最初。

至于从DB获取结果,你可以使用AJAX调用(基本上只需通过AJAX调用你的php脚本,让它返回JSON数据,然后使用JAVASCRIPT将这些数据解析/填充到屏幕上用户...或者,它甚至不必是ajax,你可以使用routeboxer,然后在一些动作上,将它提交给你的数据库,然后让下一页返回结果呈现...但是AJAX确实是更优雅的方法(这种情况几乎是一个'理想的用例')

BTW:我没有看到像这个程序员那样把Routerbox放在“服务器端”的逻辑。他正确地指出这样一个事实:很长很复杂的路线需要时间,但我的想法是:“用户是否正在等待他的PC处理数据,或者他正在等待远程PC(服务器)到处理数据.......他所知道和关心的是他在等待,而不是后退方法!(除了可以访问一系列功能强大的服务器并且可以重写服务器端代码的例外情况利用并行运行等...)