2013-03-08 211 views
5

我正在使用GeoModel开发应用程序。我需要根据给定的经度和纬度在特定半径内执行搜索。我能够使用Objectify在数据存储区中生成GeoCell,但无法取回特定半径的结果。使用物体化的地理空间半径搜索

我在下面分享我的代码。

实体类

@Entity 
public class NewsFeed implements Serializable { 
private static final long serialVersionUID = 1L; 
@Id 
@Index 
private Long feedID; 
@Index 
private String topic; 
@Index 
private String title; 
private String description; 
@Index 
private Date createDate; 
private String imageOrVideo; 
private String imageUrl; 
private String blobKey; 
@Latitude 
private Double latitude; 
@Longitude 
private Double longitude; 
@Geocells 
private List<String> cells; 

    // getter and setters ... 
} 

定制GeocellQueryEngine类From This Source

public class ObjectifyGeocellQueryEngine implements GeocellQueryEngine { 
private String geocellsProperty; 
private Objectify ofy; 
public static final String DEFAULT_GEOCELLS_PROPERTY = "cells"; 

public ObjectifyGeocellQueryEngine(Objectify ofy) { 
    this(ofy, DEFAULT_GEOCELLS_PROPERTY); 
} 

public ObjectifyGeocellQueryEngine(Objectify ofy, String geocellsProperty) { 
    this.ofy = ofy; 
    this.geocellsProperty = geocellsProperty; 
} 

@Override 
public <T> List<T> query(GeocellQuery baseQuery, List<String> geocells, Class<T> entityClass) { 
    StringTokenizer st; 
    int tokenNo = 0; 
    Query<T> query = ofy.query(entityClass); 
    if (baseQuery != null) { 
     st = new StringTokenizer(baseQuery.getBaseQuery(), ","); 
     while (st.hasMoreTokens()) { 
      query.filter(st.nextToken(), baseQuery.getParameters().get(tokenNo++)); 
     } 
    } 
    return query.filter(geocellsProperty + " IN", geocells).list(); 
} 
} 

获取数据在这里

Point p = new Point(24.8993714, 79.5839124); 
    // Generates the list of GeoCells 
    List<String> cells = GeocellManager.generateGeoCell(p); 
    List<Object> params = new ArrayList<Object>(); 
    params.add("Movies"); 
    GeocellQuery baseQuery = new GeocellQuery("topic == topic", "String topic",params); 
    ObjectifyGeocellQueryEngine objectifyGeocellQueryEngine = new ObjectifyGeocellQueryEngine(ofy(), "cells"); 
    List<NewsFeed> list = objectifyGeocellQueryEngine.query(baseQuery, cells, NewsFeed.class); 
    List<NewsFeed> list2 = GeocellManager.proximitySearch(p, 10, 10000,NewsFeed.class, baseQuery, objectifyGeocellQueryEngine, GeocellManager.MAX_GEOCELL_RESOLUTION); 
    System.out.println(list+" : "+list2); 

现在的问题是我没有从这里得到任何结果。你能帮助我,因为我没有得到任何异常,只是得到空的名单。

+0

我不会相信自近期更新以来差不多两年的事情。从来没有玩过Java ..所以不要听我的:) – Lipis 2013-03-08 13:05:49

+0

它的一个很好的问题,但你可能会得到更多的帮助在Python(我自己说吧) – 2013-03-10 14:29:54

回答

-2

我已经为这种情况做了一个解决方法我添加了一个并行的JDO类来存储和检索地理空间结果。

+0

你可以请更新,你是如何做到这一点...这将从你身边得到很大的帮助。 – 2013-07-17 22:02:57

+0

我面临同样的问题,但你的“答案”没有提供任何解决方案。 – mdarwin 2014-03-12 05:31:11

+0

@mdarwin我已经解决了一个解决方案,我制作了一个JDO注释类,它具有经纬度,并使用JDO持久化它们,因为地理空间查询可以很好地与JDO一起工作,所以我得到了结果。 – 2014-03-12 11:06:02