package com.moral.api.service.impl; import com.alibaba.fastjson.JSON; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.moral.api.entity.*; import com.moral.api.mapper.*; import com.moral.api.service.*; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import com.moral.constant.Constants; import com.moral.util.*; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.util.ObjectUtils; import java.text.ParseException; import java.text.SimpleDateFormat; import java.util.*; import java.util.stream.Collectors; /** *

* 服务实现类 *

* * @author moral * @since 2022-01-19 */ @Service public class ServicesScopeServiceImpl extends ServiceImpl implements ServicesScopeService { @Autowired private OrganizationMapper organizationMapper; @Autowired private ServicesScopeMapper servicesScopeMapper; @Autowired private OrganizationService organizationService; @Autowired private ServicesScopeDeviceMapper servicesScopeDeviceMapper; @Autowired private DeviceMapper deviceMapper; @Autowired private HistoryMonthlyMapper historyMonthlyMapper; @Autowired private HistoryDailyMapper historyDailyMapper; @Autowired private HistoryHourlyMapper historyHourlyMapper; @Autowired private HistoryHourlyService historyHourlyService; @Override public List> getDateByOrgIdAndCondition(Map map) { int orgId = Integer.parseInt(map.get("organization_id").toString()); //定义一个集合,存放所有id List allOrgId = new ArrayList<>(); allOrgId.add(orgId); //循环集合 //所有子组织 List allChildrenOrganization = organizationService.getChildrenOrganizationsById(orgId); if (!ObjectUtils.isEmpty(allChildrenOrganization) || allChildrenOrganization.size() < 1){ for (Organization organization:allChildrenOrganization) { allOrgId.add(organization.getId()); } } //集合去重 List allOrgIdWithoutDuplicates = allOrgId.stream().distinct().collect(Collectors.toList()); List> resultList = new ArrayList<>(); for (int organizationId:allOrgIdWithoutDuplicates) { Map resultMap = new HashMap<>(); QueryWrapper organizationQueryWrapper = new QueryWrapper<>(); organizationQueryWrapper.eq("is_delete",Constants.NOT_DELETE); organizationQueryWrapper.eq("id",organizationId); if (!ObjectUtils.isEmpty(map.get("regionCode"))){ String region = RegionCodeUtils.regionCodeConvertToName(Integer.parseInt(map.get("regionCode").toString())); organizationQueryWrapper.eq(region,Integer.parseInt(map.get("regionCode").toString())); } Organization organization = new Organization(); organization = organizationMapper.selectOne(organizationQueryWrapper); if (ObjectUtils.isEmpty(organization)){ continue; } resultMap.put("id",organization.getId()); resultMap.put("name",organization.getName()); QueryWrapper servicesScopeQueryWrapper = new QueryWrapper<>(); servicesScopeQueryWrapper.eq("is_delete",Constants.NOT_DELETE); servicesScopeQueryWrapper.eq("organization_id",organizationId); if (!ObjectUtils.isEmpty(map.get("name"))){ servicesScopeQueryWrapper.like("name",map.get("name").toString()); } List servicesScopes = new ArrayList<>(); servicesScopes = servicesScopeMapper.selectList(servicesScopeQueryWrapper); if (servicesScopes.size()<1){ continue; } List> servicesScopeList= new ArrayList<>(); for (ServicesScope servicesScope:servicesScopes) { Map servicesScopeMap = new HashMap<>(); servicesScopeMap.put("id",servicesScope.getId()); servicesScopeMap.put("name",servicesScope.getName()); servicesScopeMap.put("organizationId",servicesScope.getOrganizationId()); servicesScopeMap.put("centerLongitude",servicesScope.getCenterLongitude()); servicesScopeMap.put("centerLatitude",servicesScope.getCenterLatitude()); servicesScopeList.add(servicesScopeMap); } resultMap.put("servicesScopes",servicesScopeList); resultList.add(resultMap); } if (resultList.size()<1){ return null; } return resultList; } @Override public List> honeycombDiagram(Integer serviceScopeId,Integer distance,String type,String time,String sensorCode) { List> resultList = new ArrayList<>(); ServicesScope servicesScope = servicesScopeMapper.selectById(serviceScopeId); QueryWrapper servicesScopeDeviceQueryWrapper = new QueryWrapper<>(); servicesScopeDeviceQueryWrapper.eq("services_scope_id",servicesScope.getId()); servicesScopeDeviceQueryWrapper.eq("is_delete",Constants.NOT_DELETE); List servicesScopeDevices = servicesScopeDeviceMapper.selectList(servicesScopeDeviceQueryWrapper); List deviceIds = servicesScopeDevices.stream().map(d -> d.getDeviceId()).collect(Collectors.toList()); QueryWrapper deviceQueryWrapper = new QueryWrapper<>(); deviceQueryWrapper.eq("is_delete",Constants.NOT_DELETE); deviceQueryWrapper.in("id",deviceIds); List devices = deviceMapper.selectList(deviceQueryWrapper); List deviceMacs = devices.stream().map(d -> d.getMac()).collect(Collectors.toList()); Map devicesMap = new HashMap<>(); for (Device device : devices) { devicesMap.put(device.getMac(), device); } Map> historyDataMap = new HashMap<>(); SimpleDateFormat sdf = new SimpleDateFormat(DateUtils.yyyy_MM_dd_HH_mm_ss_EN); if (type.equals("monthly")){ Date monthly_time = DateUtils.getDate(time+"-01 00:00:00",DateUtils.yyyy_MM_dd_HH_mm_ss_EN); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.in("mac", deviceMacs); wrapper.eq("time", monthly_time); List historyMonthlies = historyMonthlyMapper.selectList(wrapper); for (HistoryMonthly historyMonthly : historyMonthlies) { historyDataMap.put(historyMonthly.getMac(), JSON.parseObject(JSON.toJSONString(historyMonthly), Map.class)); } } if (type.equals("daily")){ Date daily_time = DateUtils.getDate(time+" 00:00:00",DateUtils.yyyy_MM_dd_HH_mm_ss_EN); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.in("mac", deviceMacs); wrapper.eq("time", daily_time); List historyDailies = historyDailyMapper.selectList(wrapper); for (HistoryDaily historyDaily : historyDailies) { historyDataMap.put(historyDaily.getMac(), JSON.parseObject(JSON.toJSONString(historyDaily), Map.class)); } } if (type.equals("hourly")){ Date hourly_time = DateUtils.getDate(time+":00:00",DateUtils.yyyy_MM_dd_HH_mm_ss_EN); QueryWrapper wrapper = new QueryWrapper<>(); wrapper.in("mac", deviceMacs); wrapper.eq("time", hourly_time); List historyHourlies = historyHourlyService.getHourlyDataByMacs(deviceMacs,time); for (HistoryHourly historyHourly : historyHourlies) { historyDataMap.put(historyHourly.getMac(), JSON.parseObject(JSON.toJSONString(historyHourly), Map.class)); } } String boundary = servicesScope.getBoundary(); String[] lon_lat_arrs = boundary.split(";"); List> areas=new ArrayList>(); List lonList = new ArrayList<>(); List latList = new ArrayList<>(); for (String lon_lat:lon_lat_arrs) { String[] lonAndLat = lon_lat.split(","); Map lon_lat_map = new HashMap();//左下 lon_lat_map.put("px", Double.parseDouble(lonAndLat[0])); lon_lat_map.put("py", Double.parseDouble(lonAndLat[1])); areas.add(lon_lat_map); lonList.add(Double.parseDouble(lonAndLat[0])); latList.add(Double.parseDouble(lonAndLat[1])); } Double lonMax = Collections.max(lonList); Double lonMin = Collections.min(lonList); Double latMax = Collections.max(latList); Double latMin = Collections.min(latList); double lon_getmeter = LongitudeAndLatitudeUtils.getmeter(lonMax, latMin, lonMin, latMin); Double lon_numberOfCopies = DoubleUtils.div(lon_getmeter, distance.doubleValue(), 0); double lat_getmeter = LongitudeAndLatitudeUtils.getmeter(lonMax, latMin, lonMax, latMax); Double lat_numberOfCopies = DoubleUtils.div(lat_getmeter, distance.doubleValue(), 0); double lon_sub = DoubleUtils.sub(lonMax, lonMin); double lat_sub = DoubleUtils.sub(latMax, latMin); Double lon_oneShare = DoubleUtils.div(lon_sub, lon_numberOfCopies,15); Double lat_ontShare = DoubleUtils.div(lat_sub, lat_numberOfCopies,15); Double point_lon = lonMin; for (int i=0;i resultMap = new HashMap<>(); Double getmeter = 100000000.0; String near_mac = ""; for(String key:devicesMap.keySet()){ Device device = devicesMap.get(key); double getmeter1 = LongitudeAndLatitudeUtils.getmeter(point_lon, point_lat, device.getLongitude(), device.getLatitude()); if (getmeter1 map = historyDataMap.get(near_mac); if (map != null){ String value = map.get("value").toString(); JSONObject jsonObject = JSONObject.parseObject(value); Double sensorValue = Double.parseDouble(jsonObject.get(sensorCode).toString()); resultMap.put("lon",point_lon); resultMap.put("lat",point_lat); resultMap.put("value",sensorValue); resultList.add(resultMap); } } point_lat = DoubleUtils.add(point_lat,lat_ontShare); } point_lon = DoubleUtils.add(point_lon,lon_oneShare); } return resultList; } /*private OrganizationServicesScopeVO treeStructure(int orgId){ OrganizationServicesScopeVO organizationServicesScopeVO = new OrganizationServicesScopeVO(); Organization organization = organizationMapper.selectById(orgId); organizationServicesScopeVO.setOrganization(organization); QueryWrapper chileOrganizationQueryWrapper = new QueryWrapper<>(); chileOrganizationQueryWrapper.eq("is_delete",Constants.NOT_DELETE); chileOrganizationQueryWrapper.eq("parent_id",orgId); List childOrganizations = new ArrayList<>(); childOrganizations = organizationMapper.selectList(chileOrganizationQueryWrapper); if (childOrganizations.size()>0){ List organizationServicesScopeVOS = new ArrayList<>(); for (Organization childOrganization:childOrganizations) { OrganizationServicesScopeVO organizationServicesScopeVO1 = treeStructure(childOrganization.getId()); if (ObjectUtils.isEmpty(organizationServicesScopeVO1)){ organizationServicesScopeVOS.add(organizationServicesScopeVO1); } } organizationServicesScopeVO.setOrganizationServicesScopeVOS(organizationServicesScopeVOS); } //servicesScopeMapper.selectList() return null; }*/ }