在处理地理信息相关的数据时,常常需要处理一些单面和复合面的信息,将这些面数据存储到es的过程中需要使用geo_shape类型来存储,然而es在存储这类型的数据时,有非常强的限制性,即面信息不能出现不闭合的和自相交的情况;简单判断面是否闭合和相交,在给定的面信息的JSON点中,如果一个点在一个面里面出现三次以上,既可视为相交,如果第一个点与最后一点不同,即视为不闭合。这里给出的代码是将没有以上问题的面信息存入到es当中;
JSONArray da = new JSONArray();
JSONArray jsonArray1 = new JSONArray();
JSONArray jsonArray2 = new JSONArray();
//单面数据格式 coordinates:[[[经度,纬度],[经度,纬度]]]
if("Polygon".equals(geometry.getString("type"))){
for (Object o: rings) {
jsonArray1 = new JSONArray();
Double[][] b1 = new Double[1][2];
JSONArray arr1 = (JSONArray) o;
for (Object b: arr1) {
jsonArray2 = new JSONArray();
b1 = new Double[1][2];
String star = b.toString();
String replace = star.replace("[", " ").replace("]", " ");
String[] split = replace.split(",");
b1[0][0]= Double.parseDouble(split[0]);
b1[0][1]= Double.parseDouble(split[1]);
jsonArray2.add(b1[0][0]);
jsonArray2.add(b1[0][1]);
jsonArray1.add(jsonArray2);
}
da.add(jsonArray1);
}
//复合面数据格式 coordinates:[[[[经度,纬度],[经度,纬度]]],[[[经度,纬度],[经度,纬度]]]]
}else if("MultiPolygon".equals(geometry.getString("type"))){
JSONArray da2 = new JSONArray();
for (Object o: rings) {
jsonArray1 = new JSONArray();
Double[][] b1 = new Double[1][2];
JSONArray arr1 = (JSONArray) o;
for (Object c: arr1) {
jsonArray1 = new JSONArray();
JSONArray c1 = (JSONArray) c;
for (Object b: c1) {
jsonArray2 = new JSONArray();
b1 = new Double[1][2];
String star = b.toString();
String replace = star.replace("[", " ").replace("]", " ");
String[] split = replace.split(",");
b1[0][0]= Double.parseDouble(split[0]);
b1[0][1]= Double.parseDouble(split[1]);
jsonArray2.add(b1[0][0]);
jsonArray2.add(b1[0][1]);
jsonArray1.add(jsonArray2);
}
da2 = new JSONArray();
da2.add(jsonArray1);
}
da.add(da2);
}
}
//这里得到的JSON数组da即位满足需求的面数据数组
如果直接读取JSON文件,读取到的面数据将会被转成String存入到ES,这里就需要手动将其转换成Double类型再存入到ES才能生效;