From 0359860dbc5de19f3d099ff549af0b4c48a08221 Mon Sep 17 00:00:00 2001 From: lizijie <lzjiiie@163.com> Date: Fri, 10 Dec 2021 14:31:27 +0800 Subject: [PATCH] 经纬度实体类,计算中心点工具类,修改热力图接口经纬度顺序 --- screen-api/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java | 45 ++++++++++----- screen-api/src/main/java/com/moral/api/utils/GetCenterPointFromListOfCoordinates.java | 80 ++++++++++++++++++++++++++ screen-api/src/main/java/com/moral/api/entity/GeoCoordinate.java | 38 ++++++++++++ 3 files changed, 148 insertions(+), 15 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/entity/GeoCoordinate.java b/screen-api/src/main/java/com/moral/api/entity/GeoCoordinate.java new file mode 100644 index 0000000..876a068 --- /dev/null +++ b/screen-api/src/main/java/com/moral/api/entity/GeoCoordinate.java @@ -0,0 +1,38 @@ +package com.moral.api.entity; + +/** + * @program: screen + * @description: ������������������ + * @author: lizijie + * @create: 2021-12-09 16:40 + **/ +public class GeoCoordinate { + + private double latitude; + private double longitude; + + public GeoCoordinate() { + } + + public GeoCoordinate(double latitude, double longitude) { + this.latitude = latitude; + this.longitude = longitude; + } + + public double getLatitude() { + return latitude; + } + + public void setLatitude(double latitude) { + this.latitude = latitude; + } + + public double getLongitude() { + return longitude; + } + + public void setLongitude(double longitude) { + this.longitude = longitude; + } +} + diff --git a/screen-api/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java index 48d1dcf..0b837c6 100644 --- a/screen-api/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java +++ b/screen-api/src/main/java/com/moral/api/service/impl/HistoryHourlyServiceImpl.java @@ -3,14 +3,12 @@ import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.moral.api.config.mybatis.MybatisPlusConfig; -import com.moral.api.entity.Device; -import com.moral.api.entity.HistoryFiveMinutely; -import com.moral.api.entity.HistoryHourly; -import com.moral.api.entity.Organization; +import com.moral.api.entity.*; import com.moral.api.mapper.DeviceMapper; import com.moral.api.mapper.HistoryHourlyMapper; import com.moral.api.service.HistoryHourlyService; import com.moral.api.service.OrganizationService; +import com.moral.api.utils.GetCenterPointFromListOfCoordinates; import com.moral.constant.Constants; import com.moral.constant.SeparateTableType; import com.moral.pojo.AQI; @@ -135,8 +133,8 @@ JSONObject value = JSONObject.parseObject(historyHourlyData.get("value").toString()); double num = Double.parseDouble(value.get(parameters.get("sensor_code")).toString()); int level = PollutantUtils.pollutantLevel(num, (parameters.get("sensor_code")).toString()); - list1.add(latitude); list1.add(longitude); + list1.add(latitude); list1.add(level); list.add(list1); } @@ -145,24 +143,41 @@ double latitudeMax = Collections.max(latitudeList)+0.0018; double longitudeMin = Collections.min(longitudeList)-0.2/(111*Math.cos(latitudeMin)); double longitudeMax = Collections.max(longitudeList)+0.2/(111*Math.cos(latitudeMin)); - List<Object> bound = new ArrayList<>(); - List<Object> left_up = new ArrayList<>(); + List<Double> bound = new ArrayList<>(); + bound.add(latitudeMax); + bound.add(longitudeMax); + bound.add(latitudeMin); + bound.add(longitudeMin); + resultMap.put("bound",bound); + List<List> bound1 = new ArrayList<>(); + List<Double> left_up = new ArrayList<>(); left_up.add(latitudeMax); left_up.add(longitudeMin); - List<Object> right_up = new ArrayList<>(); + List<Double> right_up = new ArrayList<>(); right_up.add(latitudeMax); right_up.add(longitudeMax); - List<Object> left_down = new ArrayList<>(); + List<Double> left_down = new ArrayList<>(); left_down.add(latitudeMin); left_down.add(longitudeMin); - List<Object> right_down = new ArrayList<>(); + List<Double> right_down = new ArrayList<>(); right_down.add(latitudeMin); right_down.add(longitudeMax); - bound.add(left_up); - bound.add(right_up); - bound.add(right_down); - bound.add(left_down); - resultMap.put("bound",bound); + bound1.add(left_up); + bound1.add(right_up); + bound1.add(right_down); + bound1.add(left_down); + List<GeoCoordinate> geoCoordinates = new ArrayList<>(); + for (List bo:bound1) { + GeoCoordinate g = new GeoCoordinate(); + g.setLatitude(Double.parseDouble(bo.get(0).toString())); + g.setLongitude(Double.parseDouble(bo.get(1).toString())); + geoCoordinates.add(g); + } + GeoCoordinate centerPoint400 = GetCenterPointFromListOfCoordinates.getCenterPoint400(geoCoordinates); + List centerPoint = new ArrayList(); + centerPoint.add(centerPoint400.getLongitude()); + centerPoint.add(centerPoint400.getLatitude()); + resultMap.put("centerPoint",centerPoint); return resultMap; } diff --git a/screen-api/src/main/java/com/moral/api/utils/GetCenterPointFromListOfCoordinates.java b/screen-api/src/main/java/com/moral/api/utils/GetCenterPointFromListOfCoordinates.java new file mode 100644 index 0000000..0d845cc --- /dev/null +++ b/screen-api/src/main/java/com/moral/api/utils/GetCenterPointFromListOfCoordinates.java @@ -0,0 +1,80 @@ +package com.moral.api.utils; + +import com.moral.api.entity.GeoCoordinate; + +import java.util.ArrayList; +import java.util.List; + +/** + * @program: screen + * @description: ������������������������������ + * @author: lizijie + * @create: 2021-12-09 16:37 + **/ +public class GetCenterPointFromListOfCoordinates { + + /** + * ������������������������������������������ + * @param geoCoordinateList + * @return + */ + public static GeoCoordinate getCenterPoint(List<GeoCoordinate> geoCoordinateList) { + int total = geoCoordinateList.size(); + double X = 0, Y = 0, Z = 0; + for (GeoCoordinate g : geoCoordinateList) { + double lat, lon, x, y, z; + lat = g.getLatitude() * Math.PI / 180; + lon = g.getLongitude() * Math.PI / 180; + x = Math.cos(lat) * Math.cos(lon); + y = Math.cos(lat) * Math.sin(lon); + z = Math.sin(lat); + X += x; + Y += y; + Z += z; + } + + X = X / total; + Y = Y / total; + Z = Z / total; + double Lon = Math.atan2(Y, X); + double Hyp = Math.sqrt(X * X + Y * Y); + double Lat = Math.atan2(Z, Hyp); + return new GeoCoordinate(Lat * 180 / Math.PI, Lon * 180 / Math.PI); + } + + /** + * ������������������������������������������������������400km������������������ + * @param geoCoordinateList + * @return + */ + public static GeoCoordinate getCenterPoint400(List<GeoCoordinate> geoCoordinateList) { + // ������������������������400km��������� + int total = geoCoordinateList.size(); + double lat = 0, lon = 0; + for (GeoCoordinate g : geoCoordinateList) { + lat += g.getLatitude() * Math.PI / 180; + lon += g.getLongitude() * Math.PI / 180; + } + lat /= total; + lon /= total; + return new GeoCoordinate(lat * 180 / Math.PI, lon * 180 / Math.PI); + } + + public static void main(String[] args) { + List geoCoordinateList = new ArrayList(); + GeoCoordinate g = new GeoCoordinate(); + g.setLongitude(112.977324); + g.setLatitude(28.178376); + GeoCoordinate g2 = new GeoCoordinate(); + g2.setLongitude(112.975782); + g2.setLatitude(28.172258); + geoCoordinateList.add(g); + geoCoordinateList.add(g2); + + GeoCoordinate re = GetCenterPointFromListOfCoordinates.getCenterPoint(geoCoordinateList); + System.out.println(re.getLongitude() +" "+ re.getLatitude()); + } + + +} + -- Gitblit v1.8.0