V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
iOS 开发实用技术导航
NSHipster 中文版
http://nshipster.cn/
cocos2d 开源 2D 游戏引擎
http://www.cocos2d-iphone.org/
CocoaPods
http://cocoapods.org/
Google Analytics for Mobile 统计解决方案
http://code.google.com/mobile/analytics/
WWDC
https://developer.apple.com/wwdc/
Design Guides and Resources
https://developer.apple.com/design/
Transcripts of WWDC sessions
http://asciiwwdc.com
Cocoa with Love
http://cocoawithlove.com/
Cocoa Dev Central
http://cocoadevcentral.com/
NSHipster
http://nshipster.com/
Style Guides
Google Objective-C Style Guide
NYTimes Objective-C Style Guide
Useful Tools and Services
Charles Web Debugging Proxy
Smore
zieglar
V2EX  ›  iDev

iOS下周边POI获取方式?

  •  
  •   zieglar · 2012-10-06 22:59:11 +08:00 · 4893 次点击
    这是一个创建于 4191 天前的主题,其中的信息可能已经有所发展或是发生改变。
    接下来有个项目要开发个app来获取用户周边的特定POI信息,各POI坐标已经存入数据库
    现在的疑问就是譬如我拿到用户当前坐标,我是把用户的坐标传回服务器计算取得周边POI呢,还是其他方式实现?如果是将坐标传回服务器计算,那么服务器上用java来计算是不是更方便?NodeJS能做到么?不考虑ruby/python。。。
    近期写php写晕了,一下脑筋转不过弯来,所以请教一下大家。
    THX!
    2 条回复    1970-01-01 08:00:00 +08:00
    lnsoso
        1
    lnsoso  
       2012-10-08 22:47:34 +08:00   ❤️ 1
    1、要想取得周边的 POI 必须要在服务器端计算,你总不能把所有 POI 都放在 App 里吧?当然可以缓存少量重要 POI。
    2、服务器上有多种方式可以计算,既然你用 PHP 下面就给你一段 MySQL 的,当然实际为了效率线上不会用这个。

    latitude、longitude 为数据库字段;$lat、$lon 为 PHP 里用户当前坐标;{NUMBER OF KILOMETERS} 为周边范围(千米);数据表名 location_table。

    SELECT D.*, DEGREES(acos(cos(RADIANS(90-latitude))*cos(RADIANS(90-$lat))+sin(RADIANS(90-latitude))*sin(RADIANS(90-$lat))*cos(RADIANS(longitude-$lon))))/360*40074 AS distance FROM location_table as D HAVING distance <= {NUMBER OF KILOMETERS}
    zieglar
        2
    zieglar  
    OP
       2012-10-08 22:53:58 +08:00
    @lnsoso 神人啊,一下解决了我的大问题,太谢谢了!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   1724 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 16:40 · PVG 00:40 · LAX 09:40 · JFK 12:40
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.