地理定位字段类型 - 允许对地理位置进行计算

安装数1,285

依赖项: 1

建议者: 0

安全: 0

星标: 2

关注者: 2

分支: 2

开放问题: 3

类型:silverstripe-module

1.0.1 2016-02-29 13:11 UTC

This package is auto-updated.

Last update: 2024-08-29 04:37:30 UTC


README

维护者

  • Andre Lohmann(昵称:andrelohmann)

要求

Silverstripe 3.3.x

简介

地理定位字段类型 - 允许对地理位置进行计算。

安装

geolocation需要创建一个UDF(mysql用户自定义函数),可以手动使用以下SQL语句创建此函数(复制/粘贴到phpmyadmin):

DROP FUNCTION IF EXISTS geodistance;
delimiter //
CREATE FUNCTION geodistance (lat1 DOUBLE, lng1 DOUBLE, lat2 DOUBLE, lng2 DOUBLE) RETURNS DOUBLE NO SQL
BEGIN
DECLARE radius DOUBLE;
DECLARE distance DOUBLE;
DECLARE vara DOUBLE;
DECLARE varb DOUBLE;
DECLARE varc DOUBLE;
SET lat1 = RADIANS(lat1);
SET lng1 = RADIANS(lng1);
SET lat2 = RADIANS(lat2);
SET lng2 = RADIANS(lng2);
SET radius = 6371.0;
SET varb = SIN((lat2 - lat1) / 2.0);
SET varc = SIN((lng2 - lng1) / 2.0);
SET vara = SQRT((varb * varb) + (COS(lat1) * COS(lat2) * (varc * varc)));
SET distance = radius * (2.0 * ASIN(CASE WHEN 1.0 < vara THEN 1.0 ELSE vara END));
RETURN distance;
END;
//
delimiter ;

或者在每个/dev/build时,将以下行添加到您的 _ss_environment.php 中:

define('CREATE_GEODISTANCE_UDF', true);

如有必要,在 _ss_environment.php 中设置Google API密钥

define('GOOGLE_MAPS_API_KEY', '__YOUR_KEY__');