| | |
| | | import com.alibaba.fastjson.JSON;
|
| | | import com.alibaba.fastjson.JSONArray;
|
| | | import com.alibaba.fastjson.JSONObject;
|
| | | import com.moral.mapper.DictionaryDataMapper;
|
| | | import com.moral.mapper.OrganizationMapper;
|
| | | import com.moral.service.HistoryHourlyService;
|
| | | import com.moral.util.MyLatLng;
|
| | | import com.moral.util.mapUtils;
|
| | | import org.apache.commons.collections.CollectionUtils;
|
| | | import org.springframework.stereotype.Service;
|
| | | import org.springframework.util.ObjectUtils;
|
| | |
|
| | | import com.github.pagehelper.PageHelper;
|
| | | import com.moral.common.bean.Constants;
|
| | | import com.moral.common.bean.PageBean;
|
| | |
| | | import com.moral.common.util.StringUtils;
|
| | | import com.moral.common.util.ValidateUtil;
|
| | | import com.moral.entity.Device;
|
| | | import com.moral.entity.DeviceProperty;
|
| | | import com.moral.entity.MonitorPoint;
|
| | | import com.moral.mapper.DeviceMapper;
|
| | | import com.moral.mapper.DevicePropertyMapper;
|
| | | import com.moral.mapper.DictionaryDataMapper;
|
| | | import com.moral.mapper.MonitorPointMapper;
|
| | | import com.moral.mapper.OrganizationMapper;
|
| | | import com.moral.service.DeviceService;
|
| | | import com.moral.service.HistoryHourlyService;
|
| | | import com.moral.service.MonitorPointService;
|
| | | import com.moral.service.OrganizationService;
|
| | | import com.moral.util.MyLatLng;
|
| | | import com.moral.util.mapUtils;
|
| | |
|
| | | import org.apache.commons.collections.CollectionUtils;
|
| | | import org.springframework.stereotype.Service;
|
| | | import org.springframework.util.ObjectUtils;
|
| | | import tk.mybatis.mapper.entity.Example;
|
| | | import tk.mybatis.mapper.entity.Example.Criteria;
|
| | |
|
| | |
| | |
|
| | | @Resource
|
| | | private DeviceService deviceService;
|
| | | |
| | |
|
| | | @Resource
|
| | | private OrganizationService organizationService;
|
| | |
|
| | | @Resource
|
| | | private HistoryHourlyService historyHourlyService;
|
| | | |
| | |
|
| | | @Resource
|
| | | DevicePropertyMapper devicePropertyMapper;
|
| | |
|
| | | private static Class ENTITY_CLASS = MonitorPoint.class;
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByAreaName(Map<String, Object> parameters) {
|
| | | ValidateUtil.notNull(parameters.get("areaName"), "param.is.null");
|
| | | return monitorPointMapper.getMonitorPointsByAreaName(parameters);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> queryWithStateByMap(Map<String, Object> params){
|
| | | params.put("isDelete",Constants.IS_DELETE_FALSE);
|
| | | public List<MonitorPoint> queryWithStateByMap(Map<String, Object> params) {
|
| | | params.put("isDelete", Constants.IS_DELETE_FALSE);
|
| | | Object orgIdObj = params.get("orgId");
|
| | | List<MonitorPoint> monitorPointList = null;
|
| | | if(orgIdObj != null) {
|
| | | if (orgIdObj != null) {
|
| | | Integer orgId = Integer.parseInt(orgIdObj.toString());
|
| | | List<Integer> orgIds = orgMapper.selectLowerOrgIds(orgId);
|
| | | params.put("orgIds",orgIds);
|
| | | params.put("orgIds", orgIds);
|
| | | monitorPointList = monitorPointMapper.selectByMap(params);
|
| | | // for(MonitorPoint monitorPoint:monitorPointList){
|
| | | // Integer state = getStateFromRedis(monitorPoint.getId());
|
| | |
| | | }
|
| | | return monitorPointList == null ? new ArrayList<>() : monitorPointList;
|
| | | }
|
| | | private Integer getStateFromRedis(Integer monitorPointId){
|
| | |
|
| | | private Integer getStateFromRedis(Integer monitorPointId) {
|
| | | StringBuilder key = new StringBuilder();
|
| | | key.append("state_").append(monitorPointId).append("_*");
|
| | | List<Map> stateList = redisUtils.getList(key.toString(),Map.class);
|
| | | List<Map> stateList = redisUtils.getList(key.toString(), Map.class);
|
| | | int state = -1;
|
| | | if(stateList!=null){
|
| | | for (Map deviceState:stateList){
|
| | | int s = Integer.parseInt(deviceState.get("state").toString());
|
| | | state = s>state&&s<4?s:state;
|
| | | if (stateList != null) {
|
| | | for (Map deviceState : stateList) {
|
| | | int s = Integer.parseInt(deviceState.get("state").toString());
|
| | | state = s > state && s < 4 ? s : state;
|
| | | }
|
| | | }
|
| | | state = state==-1?4:state;
|
| | | state = state == -1 ? 4 : state;
|
| | | return state;
|
| | | }
|
| | |
|
| | | @Override
|
| | | public PageBean queryByPageBean(PageBean pageBean) {
|
| | | Example example = ExampleUtil.generateExample(ENTITY_CLASS,pageBean);
|
| | | Example example = ExampleUtil.generateExample(ENTITY_CLASS, pageBean);
|
| | | List<Example.Criteria> criteriaList = example.getOredCriteria();
|
| | | PageHelper.startPage(pageBean.getPageIndex(),pageBean.getPageSize());
|
| | | PageHelper.startPage(pageBean.getPageIndex(), pageBean.getPageSize());
|
| | | List<MonitorPoint> monitorPointList = monitorPointMapper.selectWithAreaNameByExample(example);
|
| | | return new PageBean(monitorPointList);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public MonitorPoint queryWithRelationById(Integer id){
|
| | | Example example = new Example(ENTITY_CLASS);
|
| | | example.or().andEqualTo("id",id);
|
| | | List<MonitorPoint> monitorPointList = monitorPointMapper.selectWithAreaNameByExample(example);
|
| | | return monitorPointList!=null&&monitorPointList.size()>0?monitorPointList.get(0):null;
|
| | | public MonitorPoint queryWithRelationById(Integer id) {
|
| | | Example example = new Example(ENTITY_CLASS);
|
| | | example.or().andEqualTo("id", id);
|
| | | List<MonitorPoint> monitorPointList = monitorPointMapper.selectWithAreaNameByExample(example);
|
| | | return monitorPointList != null && monitorPointList.size() > 0 ? monitorPointList.get(0) : null;
|
| | | }
|
| | |
|
| | | @Override
|
| | | public void addOrModify(MonitorPoint monitorPoint) {
|
| | | try{
|
| | | if(monitorPoint.getId()==null){
|
| | | try {
|
| | | if (monitorPoint.getId() == null) {
|
| | | monitorPoint.setIsDelete(Constants.IS_DELETE_FALSE);
|
| | | monitorPointMapper.insertSelective(monitorPoint);
|
| | | }else{
|
| | | } else {
|
| | | MonitorPoint queryMonitorPoint = new MonitorPoint();
|
| | | queryMonitorPoint.setId(monitorPoint.getId());
|
| | | queryMonitorPoint.setOrganizationId(monitorPoint.getOrganizationId());
|
| | | // num = 1,说明未改变,此查询在更新之前
|
| | | Integer num = monitorPointMapper.selectCount(queryMonitorPoint);
|
| | | boolean needRefreshCach = (num!=1);
|
| | | Integer num = monitorPointMapper.selectCount(queryMonitorPoint);
|
| | | boolean needRefreshCach = (num != 1);
|
| | | monitorPointMapper.updateByPrimaryKeySelective(monitorPoint);
|
| | | if(needRefreshCach){
|
| | | if (needRefreshCach) {
|
| | | // 刷新当前监控点下设备 在redis里设备信息
|
| | | refreshDevicesInRedis(monitorPoint.getId());
|
| | | }
|
| | | }
|
| | | }
|
| | | catch (Exception ex){
|
| | | throw ex;
|
| | | } catch (Exception ex) {
|
| | | throw ex;
|
| | | }
|
| | | }
|
| | |
|
| | | /*
|
| | | 刷新当前监控点下设备 在redis里设备信息
|
| | | */
|
| | | private void refreshDevicesInRedis(int monitorPointId){
|
| | | private void refreshDevicesInRedis(int monitorPointId) {
|
| | | Device queryDevice = new Device();
|
| | | queryDevice.setMonitorPointId(monitorPointId);
|
| | | List<Device> deviceList = deviceMapper.select(queryDevice);
|
| | | if (!CollectionUtils.isEmpty(deviceList)){
|
| | | if (!CollectionUtils.isEmpty(deviceList)) {
|
| | | List<Integer> orgIds = monitorPointMapper.selectOrganizationIds(monitorPointId);
|
| | | if (!CollectionUtils.isEmpty(orgIds)){
|
| | | deviceList.stream().forEach(dev ->{
|
| | | if(!StringUtils.isNullOrEmpty(dev.getMac())){
|
| | | String key = "device_"+dev.getMac();
|
| | | if (!CollectionUtils.isEmpty(orgIds)) {
|
| | | deviceList.stream().forEach(dev -> {
|
| | | if (!StringUtils.isNullOrEmpty(dev.getMac())) {
|
| | | String key = "device_" + dev.getMac();
|
| | | // // 简化的设备信息 用以缓存redis
|
| | | // Device simpleDevice = new Device();
|
| | | // simpleDevice.setId(dev.getId());
|
| | |
| | | // simpleDevice.setMonitorPointId(dev.getMonitorPointId());
|
| | | // 设置新组织关系,防止读写分离时数据库同步延迟
|
| | | dev.setOrganizationIds(orgIds);
|
| | | redisUtils.set(key,dev);
|
| | | redisUtils.set(key, dev);
|
| | | }
|
| | | });
|
| | | }
|
| | | }
|
| | |
|
| | | }
|
| | |
|
| | | @Override
|
| | | public void deleteByIds(Integer... ids) {
|
| | | MonitorPoint monitorPoint = new MonitorPoint();
|
| | | monitorPoint.setIsDelete(Constants.IS_DELETE_TRUE);
|
| | | if(ids!=null&&ids.length>0){
|
| | | if(ids.length==1){
|
| | | if (ids != null && ids.length > 0) {
|
| | | if (ids.length == 1) {
|
| | | monitorPoint.setId(ids[0]);
|
| | | monitorPointMapper.updateByPrimaryKeySelective(monitorPoint);
|
| | | }else{
|
| | | } else {
|
| | | Example example = new Example(ENTITY_CLASS);
|
| | | example.or().andIn("id", Arrays.asList(ids));
|
| | | monitorPointMapper.updateByExampleSelective(monitorPoint,example);
|
| | | monitorPointMapper.updateByExampleSelective(monitorPoint, example);
|
| | | }
|
| | |
|
| | | }
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByName(String name) {
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByName(String name) {
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | |
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE).andLike("name", "%" + name + "%");
|
| | | example.or().andEqualTo("isDelete", Constants.IS_DELETE_FALSE)
|
| | | .andCondition("getPY(" + getReplaceStr("name") + ") like ", "%" + name + "%");
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE).andLike("name", "%" + name + "%");
|
| | | example.or().andEqualTo("isDelete", Constants.IS_DELETE_FALSE)
|
| | | .andCondition("getPY(" + getReplaceStr("name") + ") like ", "%" + name + "%");
|
| | |
|
| | | List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example);
|
| | | return monitorPoints;
|
| | | }
|
| | | List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example);
|
| | | return monitorPoints;
|
| | | }
|
| | |
|
| | | private String getReplaceStr(String name){
|
| | | private String getReplaceStr(String name) {
|
| | | List<String[]> list = new ArrayList<String[]>();
|
| | | list.add(new String[]{"(",""});
|
| | | list.add(new String[]{")",""});
|
| | | list.add(new String[]{"(", ""});
|
| | | list.add(new String[]{")", ""});
|
| | | for (String[] string : list) {
|
| | | name = replace(name,string[0],string[1]);
|
| | | }
|
| | | return name;
|
| | | }
|
| | | |
| | | private String replace(String name,String fromStr,String toStr){
|
| | | return "REPLACE (" + name + ",'" + fromStr + "','" + toStr + "')";
|
| | | }
|
| | | name = replace(name, string[0], string[1]);
|
| | | }
|
| | | return name;
|
| | | }
|
| | |
|
| | | private String replace(String name, String fromStr, String toStr) {
|
| | | return "REPLACE (" + name + ",'" + fromStr + "','" + toStr + "')";
|
| | | }
|
| | |
|
| | | /**
|
| | | *
|
| | | * @param idList
|
| | | * @return {id:,state:}
|
| | | * @return {id:,state:}
|
| | | */
|
| | | @Override
|
| | | public List<Map<String, String>> queryMonitroPointsState(List<Integer> idList) {
|
| | | List<Map<String, String>> list = idList.stream().map( id -> {
|
| | | Integer state = getStateFromRedis(id);
|
| | | Map<String,String> stateMap = new HashMap<>();
|
| | | stateMap.put("id",id.toString());
|
| | | stateMap.put("state",state.toString());
|
| | | return stateMap;
|
| | | List<Map<String, String>> list = idList.stream().map(id -> {
|
| | | Integer state = getStateFromRedis(id);
|
| | | Map<String, String> stateMap = new HashMap<>();
|
| | | stateMap.put("id", id.toString());
|
| | | stateMap.put("state", state.toString());
|
| | | return stateMap;
|
| | | }).collect(Collectors.toList());
|
| | | return list;
|
| | | }
|
| | |
|
| | | /**
|
| | | * 获取所属组织的监控点总数
|
| | | *
|
| | | * @param orgId
|
| | | * @return
|
| | | */
|
| | | @Override
|
| | | public Integer countOfSubOrgs(@NotNull Integer orgId){
|
| | | public Integer countOfSubOrgs(@NotNull Integer orgId) {
|
| | | Example example = new Example(ENTITY_CLASS);
|
| | | //过滤超级管理员账号
|
| | | if(!dictionaryDataMapper.isSupperOrgId(orgId)){
|
| | | if (!dictionaryDataMapper.isSupperOrgId(orgId)) {
|
| | | List<Integer> orgIds = orgMapper.selectLowerOrgIds(orgId);
|
| | | example.or().andIn("organizationId",orgIds);
|
| | | example.or().andIn("organizationId", orgIds);
|
| | | }
|
| | | return monitorPointMapper.selectCountByExample(example);
|
| | | }
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByOrganizationId(Integer orgId) {
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | | |
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | if (Constants.isNotSpecialOrgId(orgId)) {
|
| | | //criteria.andEqualTo("organizationId", orgId);
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(orgId);
|
| | | criteria.andIn("organizationId", organizationIds);
|
| | |
|
| | | }
|
| | | example.orderBy("name").asc();
|
| | | return monitorPointMapper.selectByExample(example);
|
| | | }
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByRegion(Map<String, Object> parameters) {
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | | |
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | criteria.andEqualTo(parameters.get("name").toString(), parameters.get("value"));
|
| | | return monitorPointMapper.selectByExample(example);
|
| | | }
|
| | | @Override
|
| | | public List<Integer> queryVersionsById(Integer id){
|
| | | return monitorPointMapper.selectVersionsById(id);
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByOrganizationId(Integer orgId) {
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | |
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | if (Constants.isNotSpecialOrgId(orgId)) {
|
| | | //criteria.andEqualTo("organizationId", orgId);
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(orgId);
|
| | | criteria.andIn("organizationId", organizationIds);
|
| | |
|
| | | }
|
| | | example.orderBy("name").asc();
|
| | | return monitorPointMapper.selectByExample(example);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByOrganizationIds(Set<Integer> orgIds) {
|
| | | return monitorPointMapper.getMonitorPointsByOrganizationIds(orgIds);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsByRegion(Map<String, Object> parameters) {
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | |
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | criteria.andEqualTo(parameters.get("name").toString(), parameters.get("value"));
|
| | | return monitorPointMapper.selectByExample(example);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<Integer> queryVersionsById(Integer id) {
|
| | | return monitorPointMapper.selectVersionsById(id);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public MonitorPoint queryMonitorPointById(Integer mpointId) {
|
| | | return this.monitorPointMapper.selectByPrimaryKey(mpointId);
|
| | | return this.monitorPointMapper.selectByPrimaryKey(mpointId);
|
| | | }
|
| | |
|
| | | /**
|
| | | * @Description: 如果站点中没有设备则不会返回站点
|
| | | * @Param: [parameters]
|
| | | * @return: java.util.List<com.moral.entity.MonitorPoint>
|
| | | * @Author: 下雨听风
|
| | | * @Date: 2020/12/2
|
| | | */
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsAndDevicesByRegion(Map<String, Object> parameters) {
|
| | | //校验参数
|
| | | Object organizationId = parameters.remove("organizationId");
|
| | | //判断参数是否为null,如果为null则抛出自定义异常,msgKey为异常信息
|
| | | ValidateUtil.notNull(organizationId, "param.is.null");
|
| | | ValidateUtil.notNull(parameters.get("regionCode"), "param.is.null");
|
| | |
|
| | | //组装查询条件
|
| | | ParameterUtils.getRegionType4RegionCode(parameters);
|
| | |
|
| | | //查询对应code的站点数据
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | |
|
| | | //判断是否为本公司开发人员,如果不是则添加orgid限制用户查看权限
|
| | | if (Constants.isNotSpecialOrgId(Integer.valueOf(organizationId.toString()))) {
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(Integer.valueOf(organizationId.toString()));
|
| | | criteria.andIn("organizationId", organizationIds);
|
| | | }
|
| | | criteria.andEqualTo(parameters.get("regionType") + "Code", parameters.remove("regionCode"));
|
| | | List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example);
|
| | |
|
| | | //查询所有设备信息
|
| | | Example deviceExample = new Example(Device.class);
|
| | | Criteria deviceCriteria = deviceExample.createCriteria();
|
| | | deviceCriteria.orEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | List<Device> devicesInfo = deviceMapper.selectByExample(deviceExample);
|
| | |
|
| | | //获取所有站点信息
|
| | | Example monitorExample = new Example(MonitorPoint.class);
|
| | | Criteria monitorCriteria = monitorExample.createCriteria();
|
| | | monitorCriteria.orEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | List<MonitorPoint> monitorPointInfo = monitorPointMapper.selectByExample(monitorExample);
|
| | |
|
| | | //获取所有设备附加属性
|
| | | List<DeviceProperty> devicePropertyList = devicePropertyMapper.selectAll();
|
| | |
|
| | | //附加属性全部添加到设备实体中
|
| | | for (Device d : devicesInfo) {
|
| | | for (DeviceProperty dp : devicePropertyList) {
|
| | | if (dp.getId().equals(d.getId())) {
|
| | | d.setDeviceProperty(dp);
|
| | | }
|
| | | }
|
| | | }
|
| | |
|
| | | //把对应的设备信息添加到站点中
|
| | | Map<Integer, List<Device>> monitorDeviceMap = new HashMap();
|
| | | for (MonitorPoint m : monitorPointInfo) {
|
| | | List<Device> monitorDevices = new ArrayList<>();
|
| | | for (Device d : devicesInfo) {
|
| | | if (m.getId().equals(d.getMonitorPointId())) {
|
| | | monitorDevices.add(d);
|
| | | }
|
| | | }
|
| | | monitorDeviceMap.put(m.getId(), monitorDevices);
|
| | | }
|
| | |
|
| | | //对应地区Code的迭代器,向站点中添加设备信息
|
| | | Iterator<MonitorPoint> iterator = monitorPoints.iterator();
|
| | | while (iterator.hasNext()) {
|
| | | MonitorPoint monitorPoint = iterator.next();
|
| | | for (Map.Entry<Integer, List<Device>> entry : monitorDeviceMap.entrySet()) {
|
| | | if (monitorPoint.getId().equals(entry.getKey())) {
|
| | | if (!CollectionUtils.isEmpty(entry.getValue())) {
|
| | | monitorPoint.setDevices(entry.getValue());
|
| | | } else {
|
| | | iterator.remove();
|
| | | }
|
| | | }
|
| | | }
|
| | | }
|
| | | return monitorPoints;
|
| | | }
|
| | |
|
| | | /**
|
| | | * @Description: 如果站点中没有设备也会返回站点
|
| | | * @Param: [parameters]
|
| | | * @return: java.util.List<com.moral.entity.MonitorPoint>
|
| | | * @Author: 下雨听风
|
| | | * @Date: 2020/12/2
|
| | | */
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsAndDevicesByRegionNew(Map<String, Object> parameters) {
|
| | | //校验参数
|
| | | Object organizationId = parameters.remove("organizationId");
|
| | | //判断参数是否为null,如果为null则抛出自定义异常,msgKey为异常信息
|
| | | ValidateUtil.notNull(organizationId, "param.is.null");
|
| | | ValidateUtil.notNull(parameters.get("regionCode"), "param.is.null");
|
| | |
|
| | | //组装查询条件
|
| | | ParameterUtils.getRegionType4RegionCode(parameters);
|
| | |
|
| | | //查询对应code的站点数据
|
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | |
|
| | | //判断是否为本公司开发人员,如果不是则添加orgid限制用户查看权限
|
| | | if (Constants.isNotSpecialOrgId(Integer.valueOf(organizationId.toString()))) {
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(Integer.valueOf(organizationId.toString()));
|
| | | criteria.andIn("organizationId", organizationIds);
|
| | | }
|
| | | criteria.andEqualTo(parameters.get("regionType") + "Code", parameters.remove("regionCode"));
|
| | | List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example);
|
| | |
|
| | | //查询所有设备信息
|
| | | Example deviceExample = new Example(Device.class);
|
| | | Criteria deviceCriteria = deviceExample.createCriteria();
|
| | | deviceCriteria.orEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | List<Device> devicesInfo = deviceMapper.selectByExample(deviceExample);
|
| | |
|
| | | //获取所有站点信息
|
| | | Example monitorExample = new Example(MonitorPoint.class);
|
| | | Criteria monitorCriteria = monitorExample.createCriteria();
|
| | | monitorCriteria.orEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | List<MonitorPoint> monitorPointInfo = monitorPointMapper.selectByExample(monitorExample);
|
| | |
|
| | | //获取所有设备附加属性
|
| | | List<DeviceProperty> devicePropertyList = devicePropertyMapper.selectAll();
|
| | |
|
| | | //附加属性全部添加到设备实体中
|
| | | for (Device d : devicesInfo) {
|
| | | for (DeviceProperty dp : devicePropertyList) {
|
| | | if (dp.getId().equals(d.getId())) {
|
| | | d.setDeviceProperty(dp);
|
| | | }
|
| | | }
|
| | | }
|
| | |
|
| | | //把对应的设备信息添加到站点中
|
| | | Map<Integer, List<Device>> monitorDeviceMap = new HashMap();
|
| | | for (MonitorPoint m : monitorPointInfo) {
|
| | | List<Device> monitorDevices = new ArrayList<>();
|
| | | for (Device d : devicesInfo) {
|
| | | if (m.getId().equals(d.getMonitorPointId())) {
|
| | | monitorDevices.add(d);
|
| | | }
|
| | | }
|
| | | monitorDeviceMap.put(m.getId(), monitorDevices);
|
| | | }
|
| | |
|
| | | //对应地区Code的迭代器,向站点中添加设备信息
|
| | | Iterator<MonitorPoint> iterator = monitorPoints.iterator();
|
| | | while (iterator.hasNext()) {
|
| | | MonitorPoint monitorPoint = iterator.next();
|
| | | for (Map.Entry<Integer, List<Device>> entry : monitorDeviceMap.entrySet()) {
|
| | | if (monitorPoint.getId().equals(entry.getKey())) {
|
| | | if (!CollectionUtils.isEmpty(entry.getValue())) {
|
| | | monitorPoint.setDevices(entry.getValue());
|
| | | }
|
| | | }
|
| | | }
|
| | | }
|
| | | return monitorPoints;
|
| | | }
|
| | |
|
| | |
|
| | | @SuppressWarnings("unchecked")
|
| | | @Override
|
| | | public Collection<Object> getDevicesStateByRegion(Map<String, Object> parameters) {
|
| | | //校验参数
|
| | | Object organizationId = parameters.remove("organizationId");
|
| | | ValidateUtil.notNull(organizationId, "param.is.null");
|
| | | ValidateUtil.notNull(parameters.get("regionCode"), "param.is.null");
|
| | |
|
| | | //组装查询条件
|
| | | ParameterUtils.getRegionType4RegionCode(parameters);
|
| | |
|
| | | if (Constants.isNotSpecialOrgId(Integer.valueOf(organizationId.toString()))) {
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(Integer.valueOf(organizationId.toString()));
|
| | | parameters.put("orgIds", organizationIds);
|
| | | }
|
| | | List<Map<String, Object>> monitorPoints = deviceMapper.getDevicesStateByRegion(parameters);
|
| | | Map<String, Object> result = new HashMap<String, Object>();
|
| | | Map<String, Object> device;
|
| | | List<Map<String, Object>> devices;
|
| | | for (Map<String, Object> map : monitorPoints) {
|
| | | String id = map.get("id").toString();
|
| | |
|
| | | device = new HashMap<String, Object>();
|
| | | device.put("id", map.remove("deviceId"));
|
| | | device.put("name", map.remove("deviceName"));
|
| | | device.put("state", map.remove("state"));
|
| | | device.put("mac", map.remove("mac"));
|
| | |
|
| | | if (result.containsKey(id)) {
|
| | | Map<String, Object> monitorPoint = (Map<String, Object>) result.get(id);
|
| | | devices = (List<Map<String, Object>>) monitorPoint.get("devices");
|
| | | } else {
|
| | | devices = new ArrayList<Map<String, Object>>();
|
| | | result.put(id, map);
|
| | | }
|
| | | devices.add(device);
|
| | | map.put("devices", devices);
|
| | | result.put(id, map);
|
| | | }
|
| | |
|
| | | return result.values();
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointsAndDevicesByRegion(Map<String, Object> parameters) {
|
| | | //校验参数
|
| | | Object organizationId = parameters.remove("organizationId");
|
| | | ValidateUtil.notNull(organizationId, "param.is.null");
|
| | | ValidateUtil.notNull(parameters.get("regionCode"), "param.is.null");
|
| | |
|
| | | //组装查询条件
|
| | | ParameterUtils.getRegionType4RegionCode(parameters);
|
| | | |
| | | Example example = new Example(MonitorPoint.class);
|
| | | Criteria criteria = example.createCriteria();
|
| | | criteria.andEqualTo("isDelete", Constants.IS_DELETE_FALSE);
|
| | | if (Constants.isNotSpecialOrgId(Integer.valueOf(organizationId.toString()))) {
|
| | | //criteria.andEqualTo("organizationId", organizationId);
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(Integer.valueOf(organizationId.toString()));
|
| | | criteria.andIn("organizationId", organizationIds);
|
| | | }
|
| | | criteria.andEqualTo(parameters.get("regionType") + "Code", parameters.remove("regionCode"));
|
| | | |
| | | //查询监控点数据
|
| | | List<MonitorPoint> monitorPoints = monitorPointMapper.selectByExample(example);
|
| | | //查询监控点下所有的设备
|
| | | Iterator<MonitorPoint> iterator = monitorPoints.iterator();
|
| | | while (iterator.hasNext()) {
|
| | | MonitorPoint monitorPoint = iterator.next();
|
| | | List<Device> devices = deviceService.getDevicesByMonitorPointId(monitorPoint.getId());
|
| | | if (ObjectUtils.isEmpty(devices)) {
|
| | | iterator.remove();
|
| | | } else {
|
| | | monitorPoint.setDevices(devices);
|
| | | }
|
| | | |
| | | }
|
| | | return monitorPoints;
|
| | | }
|
| | |
|
| | | @SuppressWarnings("unchecked")
|
| | | @Override
|
| | | public Collection<Object> getDevicesStateByRegion(Map<String, Object> parameters) {
|
| | | //校验参数
|
| | | Object organizationId = parameters.remove("organizationId");
|
| | | ValidateUtil.notNull(organizationId, "param.is.null");
|
| | | ValidateUtil.notNull(parameters.get("regionCode"), "param.is.null");
|
| | |
|
| | | //组装查询条件
|
| | | ParameterUtils.getRegionType4RegionCode(parameters);
|
| | | |
| | | if (Constants.isNotSpecialOrgId(Integer.valueOf(organizationId.toString()))) {
|
| | | Set<Integer> organizationIds = organizationService.getChildOrganizationIds(Integer.valueOf(organizationId.toString()));
|
| | | parameters.put("orgIds", organizationIds);
|
| | | }
|
| | | List<Map<String, Object>> monitorPoints = deviceMapper.getDevicesStateByRegion(parameters);
|
| | | Map<String, Object> result = new HashMap<String, Object>();
|
| | | Map<String,Object> device;
|
| | | List<Map<String, Object>> devices;
|
| | | for (Map<String, Object> map : monitorPoints) {
|
| | | String id = map.get("id").toString();
|
| | |
|
| | | device = new HashMap<String,Object>();
|
| | | device.put("id", map.remove("deviceId"));
|
| | | device.put("name", map.remove("deviceName"));
|
| | | device.put("state", map.remove("state"));
|
| | | device.put("mac", map.remove("mac"));
|
| | |
|
| | | if (result.containsKey(id)) {
|
| | | Map<String, Object> monitorPoint = (Map<String, Object>) result.get(id);
|
| | | devices = (List<Map<String, Object>>) monitorPoint.get("devices");
|
| | | } else {
|
| | | devices = new ArrayList<Map<String, Object>>();
|
| | | result.put(id, map);
|
| | | }
|
| | | devices.add(device);
|
| | | map.put("devices", devices);
|
| | | result.put(id, map);
|
| | | }
|
| | | |
| | | return result.values();
|
| | | }
|
| | | |
| | | @Override
|
| | | public void isCompensateCalculation(Map<String, Object> parameters) {
|
| | | MonitorPoint monitorPoint = monitorPointMapper.selectByPrimaryKey(Integer.valueOf(parameters.get("monitorPointId").toString()));
|
| | | if (Integer.valueOf(320581).equals(monitorPoint.getAreaCode())) {
|
| | | parameters.put("compensate", true);
|
| | | }
|
| | | |
| | | }
|
| | | @Override
|
| | | public Map<String, Object> selectAllById(String id) {
|
| | | int id2 = Integer.parseInt(id);
|
| | | Map<String, Object> map = monitorPointMapper.selectAllById(id2);
|
| | | return map;
|
| | | }
|
| | | MonitorPoint monitorPoint = monitorPointMapper.selectByPrimaryKey(Integer.valueOf(parameters.get("monitorPointId").toString()));
|
| | | if (Integer.valueOf(320581).equals(monitorPoint.getAreaCode())) {
|
| | | parameters.put("compensate", true);
|
| | | }
|
| | |
|
| | | }
|
| | |
|
| | | @Override
|
| | | public Map<String, Object> selectAllById(String id) {
|
| | | int id2 = Integer.parseInt(id);
|
| | | Map<String, Object> map = monitorPointMapper.selectAllById(id2);
|
| | | return map;
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<Device> getDeviceList(int id) {
|
| | |
| | | params.put("device3", device3);
|
| | | for (Device device33 : device3) {
|
| | | String mac3 = device33.getMac();
|
| | | String tvoc = historyHourlyService.getTVOCByMac(mac3, Time,sensor);
|
| | | String tvoc = historyHourlyService.getTVOCByMac(mac3, Time, sensor);
|
| | | if (tvoc != null) {
|
| | | workshop = Double.parseDouble(tvoc);
|
| | | } else {
|
| | |
| | | } else {
|
| | | for (Device device11 : device1) {
|
| | | String mac1 = device11.getMac();
|
| | | flue = Double.parseDouble(historyHourlyService.getTVOCByMac(mac1, Time,sensor));
|
| | | flue = Double.parseDouble(historyHourlyService.getTVOCByMac(mac1, Time, sensor));
|
| | | if (workshop == 0.0) {
|
| | | purificationRate = "车间设备无数据浓度,无法计算浓度值";
|
| | | } else {
|
| | |
| | | for (Device device22 : device2) {
|
| | | String mac2 = device22.getMac();
|
| | | String pressure2 = historyHourlyService.getPressureByMac(mac2, Time);
|
| | |
|
| | | System.out.println("pressure2="+pressure2);
|
| | | if (pressure2 != null) {
|
| | | pressure = Double.parseDouble(pressure2);
|
| | | list1.add(pressure);
|
| | | }else {
|
| | | } else {
|
| | | collectionRate = "该公司厂界设备无数据浓度,无法计算收集率";
|
| | | }
|
| | |
|
| | |
| | | } else {
|
| | | collectionRate = "该公司厂界设备无数据浓度,无法计算收集率";
|
| | | }
|
| | | System.out.println(list1);
|
| | | Double pressure33 = 0.0;
|
| | | for (Device device33 : device3) {
|
| | | String mac3 = device33.getMac();
|
| | |
| | | List<Map> windList = new ArrayList<Map>();//存放每台设备的风向和经纬度
|
| | | Map<String, Object> jsonMap = new HashMap<String, Object>();//每台设备的数据
|
| | | Map<String, Object> deviceMap = null;
|
| | | for (Device device : deviceList) {
|
| | | deviceMap = new HashMap<String, Object>();
|
| | | smac = device.getMac();
|
| | | latitude = device.getLatitude();
|
| | | longitude = device.getLongitude();
|
| | | if (deviceList.size() > 1) {
|
| | | for (Device device : deviceList) {
|
| | | deviceMap = new HashMap<String, Object>();
|
| | | smac = device.getMac();
|
| | | latitude = device.getLatitude();
|
| | | longitude = device.getLongitude();
|
| | |
|
| | | jsonMap = historyHourlyService.getDataByMac(smac, Time);
|
| | | deviceMap.put("longitude", longitude);
|
| | | deviceMap.put("latitude", latitude);
|
| | | if (jsonMap != null) {
|
| | | deviceMap.put("jsonMap", jsonMap);
|
| | | } else {
|
| | | deviceMap.put("jsonMap", "该设备该时间点无数据");
|
| | | }
|
| | |
|
| | | list.add(deviceMap);
|
| | | }
|
| | | Map<String, Object> mapData = new HashMap<String, Object>();
|
| | | Map<String, Object> mapDevice;
|
| | | JSONArray windDir;
|
| | | for (Map<String, Object> objectMap : list) {
|
| | | mapDevice = new HashMap<String, Object>();
|
| | | Map<String, Object> map = null;
|
| | | if (!(objectMap.get("jsonMap") instanceof String)) {
|
| | | mapData = (Map<String, Object>) objectMap.get("jsonMap");
|
| | | map = (Map) JSON.parseObject((String) mapData.get("json"));
|
| | | windDir = (JSONArray) JSONArray.toJSON(map.get("e23"));
|
| | | JSONArray concentration = (JSONArray) JSONArray.toJSON(map.get(sensor));
|
| | |
|
| | | BigDecimal bigDecimal1=new BigDecimal(0);
|
| | | BigDecimal bigDecimal=new BigDecimal(0);
|
| | | if (concentration!=null){
|
| | | if (concentration.get(0) instanceof Integer){
|
| | | bigDecimal1 =new BigDecimal(concentration.get(0).toString());
|
| | | }else {
|
| | | bigDecimal1= (BigDecimal) concentration.get(0);
|
| | | }
|
| | | if (windDir!=null){
|
| | | if (windDir.get(0) instanceof Integer){
|
| | | bigDecimal =new BigDecimal(windDir.get(0).toString());
|
| | | }else {
|
| | | bigDecimal=(BigDecimal) windDir.get(0);
|
| | | }
|
| | | mapDevice.put("e23", bigDecimal.doubleValue());
|
| | | mapDevice.put("sensor", bigDecimal1.doubleValue());
|
| | | mapDevice.put("longitude", objectMap.get("longitude"));
|
| | | mapDevice.put("latitude", objectMap.get("latitude"));
|
| | | }else {
|
| | | mapDevice.put("noSensor", "无风向数据");
|
| | | mapDevice.put("longitude", objectMap.get("longitude"));
|
| | | mapDevice.put("latitude", objectMap.get("latitude"));
|
| | | }
|
| | | jsonMap = historyHourlyService.getDataByMac(smac, Time);
|
| | | deviceMap.put("longitude", longitude);
|
| | | deviceMap.put("latitude", latitude);
|
| | | if (jsonMap != null) {
|
| | | deviceMap.put("jsonMap", jsonMap);
|
| | | } else {
|
| | | deviceMap.put("jsonMap", "该设备该时间点无数据");
|
| | | }
|
| | | } else {
|
| | | mapDevice.put("info", objectMap.get("jsonMap"));
|
| | | mapDevice.put("longitude", objectMap.get("longitude"));
|
| | | mapDevice.put("latitude", objectMap.get("latitude"));
|
| | | }
|
| | | windList.add(mapDevice);
|
| | | }
|
| | | // if (windDir!=null){}
|
| | | Double differenceNum = 0.0;
|
| | | Map<String, Object> indexMap;
|
| | | List<Map> mapList = new ArrayList<>();
|
| | | for (int j = 0; j < windList.size(); j++) {
|
| | | for (int k = 0; k < windList.size(); k++) {
|
| | | if (k != j) {
|
| | | indexMap = new HashMap<String, Object>();
|
| | | if (windList.get(k).containsKey("e23") && windList.get(j).containsKey("e23")) {
|
| | | Double e23Numk = (Double) windList.get(k).get("e23");
|
| | | Double e23Numj = (Double) windList.get(j).get("e23");
|
| | | Double diff = e23Numk - e23Numj;
|
| | | BigDecimal b = new BigDecimal(Math.abs(diff));
|
| | |
|
| | | differenceNum = b.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
|
| | | if (differenceNum > 180) {
|
| | | differenceNum = 360 - differenceNum;
|
| | | list.add(deviceMap);
|
| | | }
|
| | | Map<String, Object> mapData = new HashMap<String, Object>();
|
| | | Map<String, Object> mapDevice;
|
| | | JSONArray windDir;
|
| | | for (Map<String, Object> objectMap : list) {
|
| | | mapDevice = new HashMap<String, Object>();
|
| | | Map<String, Object> map = null;
|
| | | if (!(objectMap.get("jsonMap") instanceof String)) {
|
| | | mapData = (Map<String, Object>) objectMap.get("jsonMap");
|
| | | map = (Map) JSON.parseObject((String) mapData.get("json"));
|
| | | windDir = (JSONArray) JSONArray.toJSON(map.get("e23"));
|
| | | JSONArray concentration = (JSONArray) JSONArray.toJSON(map.get(sensor));
|
| | |
|
| | | BigDecimal bigDecimal1 = new BigDecimal(0);
|
| | | BigDecimal bigDecimal = new BigDecimal(0);
|
| | | if (concentration != null) {
|
| | | if (concentration.get(0) instanceof Integer) {
|
| | | bigDecimal1 = new BigDecimal(concentration.get(0).toString());
|
| | | } else {
|
| | | bigDecimal1 = (BigDecimal) concentration.get(0);
|
| | | }
|
| | | indexMap.put("k", k);
|
| | | indexMap.put("j", j);
|
| | | indexMap.put("diff", differenceNum);
|
| | | } else {
|
| | | indexMap.put("k", k);
|
| | | indexMap.put("j", j);
|
| | | indexMap.put("info", "设备无数据");
|
| | | if (windDir != null) {
|
| | | if (windDir.get(0) instanceof Integer) {
|
| | | bigDecimal = new BigDecimal(windDir.get(0).toString());
|
| | | } else {
|
| | | bigDecimal = (BigDecimal) windDir.get(0);
|
| | | }
|
| | | mapDevice.put("e23", bigDecimal.doubleValue());
|
| | | mapDevice.put("sensor", bigDecimal1.doubleValue());
|
| | | mapDevice.put("longitude", objectMap.get("longitude"));
|
| | | mapDevice.put("latitude", objectMap.get("latitude"));
|
| | | } else {
|
| | | mapDevice.put("noSensor", "无风向数据");
|
| | | mapDevice.put("longitude", objectMap.get("longitude"));
|
| | | mapDevice.put("latitude", objectMap.get("latitude"));
|
| | | }
|
| | | }
|
| | | } else {
|
| | | mapDevice.put("info", objectMap.get("jsonMap"));
|
| | | mapDevice.put("longitude", objectMap.get("longitude"));
|
| | | mapDevice.put("latitude", objectMap.get("latitude"));
|
| | | }
|
| | | windList.add(mapDevice);
|
| | | }
|
| | | // if (windDir!=null){}
|
| | | Double differenceNum = 0.0;
|
| | | Map<String, Object> indexMap;
|
| | | List<Map> mapList = new ArrayList<>();
|
| | | for (int j = 0; j < windList.size(); j++) {
|
| | | for (int k = 0; k < windList.size(); k++) {
|
| | | if (k != j) {
|
| | | indexMap = new HashMap<String, Object>();
|
| | | if (windList.get(k).containsKey("e23") && windList.get(j).containsKey("e23")) {
|
| | | Double e23Numk = (Double) windList.get(k).get("e23");
|
| | | Double e23Numj = (Double) windList.get(j).get("e23");
|
| | | Double diff = e23Numk - e23Numj;
|
| | | BigDecimal b = new BigDecimal(Math.abs(diff));
|
| | |
|
| | | differenceNum = b.setScale(4, BigDecimal.ROUND_HALF_UP).doubleValue();
|
| | | if (differenceNum > 180) {
|
| | | differenceNum = 360 - differenceNum;
|
| | | }
|
| | | indexMap.put("k", k);
|
| | | indexMap.put("j", j);
|
| | | indexMap.put("diff", differenceNum);
|
| | | } else {
|
| | | indexMap.put("k", k);
|
| | | indexMap.put("j", j);
|
| | | indexMap.put("info", "设备无数据");
|
| | | }
|
| | |
|
| | | // indexMap.put("longitude",windList.get(k).get("longitude"));
|
| | | // indexMap.put("latitude",windList.get(k).get("latitude"));
|
| | | mapList.add(indexMap);
|
| | | } else {
|
| | | continue;
|
| | | }
|
| | | mapList.add(indexMap);
|
| | | } else {
|
| | | continue;
|
| | | }
|
| | |
|
| | | }
|
| | | }
|
| | | }
|
| | | Double min = 0.0;
|
| | | int indexMin = 0;
|
| | | if (mapList.size()>0){
|
| | | if (mapList.get(0).containsKey("diff")) {
|
| | | min = (Double) mapList.get(0).get("diff");
|
| | | for (int q = 1; q < mapList.size(); q++) {
|
| | | if (mapList.get(q).containsKey("diff")) {
|
| | | if (min > (Double) mapList.get(q).get("diff")) {
|
| | | min = (Double) mapList.get(q).get("diff");
|
| | | Double min = 0.0;
|
| | | int indexMin = 0;
|
| | | if (mapList.size() > 0) {
|
| | | if (mapList.get(0).containsKey("diff")) {
|
| | | min = (Double) mapList.get(0).get("diff");
|
| | | for (int q = 1; q < mapList.size(); q++) {
|
| | | if (mapList.get(q).containsKey("diff")) {
|
| | | if (min > (Double) mapList.get(q).get("diff")) {
|
| | | min = (Double) mapList.get(q).get("diff");
|
| | | indexMin = q;
|
| | | }
|
| | | } else {
|
| | | indexMin = q;
|
| | | }
|
| | | } else {
|
| | | indexMin = q;
|
| | | }
|
| | | }
|
| | | }
|
| | | }
|
| | |
|
| | | Map twoDeviceMap = mapList.get(indexMin);
|
| | | List<Map> list1 = new ArrayList<Map>(); //存放风向夹角最小的两台设备的经纬度
|
| | | list1.add(windList.get((Integer) twoDeviceMap.get("k")));
|
| | | list1.add(windList.get((Integer) twoDeviceMap.get("j")));
|
| | | Double wind = 0.0;
|
| | | Double sum = 0.0;
|
| | | if (list1.get(0).containsKey("e23")) {
|
| | | if (Math.abs((Double) list1.get(0).get("e23") - (Double) list1.get(1).get("e23")) > 180) {
|
| | | sum = (Double) list1.get(0).get("e23") + (Double) list1.get(1).get("e23");
|
| | | wind = sum / 2 + 180;
|
| | | if (wind > 360) {
|
| | | wind = wind - 360;
|
| | | Map twoDeviceMap = mapList.get(indexMin);
|
| | | List<Map> list1 = new ArrayList<Map>(); //存放风向夹角最小的两台设备的经纬度
|
| | | list1.add(windList.get((Integer) twoDeviceMap.get("k")));
|
| | | list1.add(windList.get((Integer) twoDeviceMap.get("j")));
|
| | |
|
| | | Double wind = 0.0;
|
| | | Double sum = 0.0;
|
| | | if (list1.get(0).containsKey("e23")) {
|
| | | if (Math.abs((Double) list1.get(0).get("e23") - (Double) list1.get(1).get("e23")) > 180) {
|
| | | sum = (Double) list1.get(0).get("e23") + (Double) list1.get(1).get("e23");
|
| | | wind = sum / 2 + 180;
|
| | | if (wind > 360) {
|
| | | wind = wind - 360;
|
| | | }
|
| | | } else {
|
| | | for (Map map : list1) {
|
| | | sum += (Double) map.get("e23");
|
| | | }
|
| | | wind = sum / 2;
|
| | | }
|
| | | } else {
|
| | | for (Map map : list1) {
|
| | | sum += (Double) map.get("e23");
|
| | | }
|
| | | wind = sum / 2;
|
| | | wind = 0.0;
|
| | | }
|
| | | } else {
|
| | | wind = 0.0;
|
| | | }
|
| | | Map<String, Object> longAndLatiMap;
|
| | | List<Map> longAndLatiList = new ArrayList<>();//经纬度夹角集合,存放的是windList中两台设备的下标和两台设备夹角与风向角的差值
|
| | | List<Map> preAngleDeviceList = new ArrayList<Map>(); //角度减去风向最小的两台设备
|
| | | if (wind != 0.0) {
|
| | | for (int f = 0; f < windList.size(); f++) {
|
| | | for (int h = 0; h < windList.size(); h++) {
|
| | | if (f != h) {
|
| | | longAndLatiMap = new HashMap<String, Object>();
|
| | | longAndLatiMap.put("h", h);
|
| | | longAndLatiMap.put("f", f);
|
| | | Double angle = mapUtils.getAngle(
|
| | | new MyLatLng((Double) windList.get(h).get("longitude"),
|
| | | (Double) windList.get(h).get("latitude")),
|
| | | new MyLatLng((Double) windList.get(f).get("longitude"),
|
| | | (Double) windList.get(f).get("latitude")));
|
| | | Double angleDiff = Math.abs(angle - wind);
|
| | | longAndLatiMap.put("angle", angleDiff);
|
| | | longAndLatiList.add(longAndLatiMap);
|
| | | Map<String, Object> longAndLatiMap;
|
| | | List<Map> longAndLatiList = new ArrayList<>();//经纬度夹角集合,存放的是windList中两台设备的下标和两台设备夹角与风向角的差值
|
| | | List<Map> preAngleDeviceList = new ArrayList<Map>(); //角度减去风向最小的两台设备
|
| | | if (wind != 0.0) {
|
| | | for (int f = 0; f < windList.size(); f++) {
|
| | | for (int h = 0; h < windList.size(); h++) {
|
| | | if (f != h) {
|
| | | longAndLatiMap = new HashMap<String, Object>();
|
| | | longAndLatiMap.put("h", h);
|
| | | longAndLatiMap.put("f", f);
|
| | | Double angle = mapUtils.getAngle(
|
| | | new MyLatLng((Double) windList.get(h).get("longitude"),
|
| | | (Double) windList.get(h).get("latitude")),
|
| | | new MyLatLng((Double) windList.get(f).get("longitude"),
|
| | | (Double) windList.get(f).get("latitude")));
|
| | | Double angleDiff = Math.abs(angle - wind);
|
| | | longAndLatiMap.put("angle", angleDiff);
|
| | | longAndLatiList.add(longAndLatiMap);
|
| | | }
|
| | | }
|
| | | }
|
| | | }
|
| | | Double minAngle = (Double) longAndLatiList.get(0).get("angle");
|
| | | int indexAngle = 0;
|
| | | for (int j = 0; j < longAndLatiList.size(); j++) {
|
| | | if (minAngle > (Double) longAndLatiList.get(j).get("angle")) {
|
| | | minAngle = (Double) longAndLatiList.get(j).get("angle");
|
| | | indexAngle = j;
|
| | | Double minAngle = (Double) longAndLatiList.get(0).get("angle");
|
| | | int indexAngle = 0;
|
| | | for (int j = 0; j < longAndLatiList.size(); j++) {
|
| | | if (minAngle > (Double) longAndLatiList.get(j).get("angle")) {
|
| | | minAngle = (Double) longAndLatiList.get(j).get("angle");
|
| | | indexAngle = j;
|
| | | }
|
| | | }
|
| | | //windList.get((Integer) longAndLatiList.get(indexAngle).get("f"))获得风向和经纬度
|
| | | preAngleDeviceList.add(windList.get((Integer) longAndLatiList.get(indexAngle).get("h")));
|
| | | preAngleDeviceList.add(windList.get((Integer) longAndLatiList.get(indexAngle).get("f")));
|
| | |
|
| | | Double length = mapUtils.getDistance((Double) preAngleDeviceList.get(0).get("longitude"), (Double) preAngleDeviceList.get(0).get("latitude"),
|
| | | (Double) preAngleDeviceList.get(1).get("longitude"), (Double) preAngleDeviceList.get(1).get("latitude"));
|
| | | Double subLength = length / 5;
|
| | | Double subLength1 = length / 6.1;
|
| | | Double angle = mapUtils.getAngle(
|
| | | new MyLatLng((Double) preAngleDeviceList.get(0).get("longitude"),
|
| | | (Double) preAngleDeviceList.get(0).get("latitude")),
|
| | | new MyLatLng((Double) preAngleDeviceList.get(1).get("longitude"),
|
| | | (Double) preAngleDeviceList.get(1).get("latitude")));
|
| | |
|
| | | params.put("preAngleDeviceList", preAngleDeviceList);
|
| | | params.put("angle", angle);
|
| | | List locationList = new ArrayList();
|
| | | String[] firstLocation = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, (Double) preAngleDeviceList.get(0).get("longitude"),
|
| | | (Double) preAngleDeviceList.get(0).get("latitude"), subLength);
|
| | | String[] secondLoction = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(firstLocation[0]),
|
| | | Double.parseDouble(firstLocation[1]), subLength);
|
| | | String[] thirdLocation = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(secondLoction[0]),
|
| | | Double.parseDouble(secondLoction[1]), subLength);
|
| | | String[] fourthLoction = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(thirdLocation[0]),
|
| | | Double.parseDouble(thirdLocation[1]), subLength);
|
| | | String[] fivethLoction = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(fourthLoction[0]),
|
| | | Double.parseDouble(fourthLoction[1]), subLength1);
|
| | | locationList.add(firstLocation);
|
| | | locationList.add(secondLoction);
|
| | | locationList.add(thirdLocation);
|
| | | locationList.add(fourthLoction);
|
| | | locationList.add(fivethLoction);
|
| | | params.put("locationList", locationList);
|
| | |
|
| | | String preAngleDeviceString = JSON.toJSON(preAngleDeviceList).toString();
|
| | | params.put("preAngleDeviceString", preAngleDeviceString);//两台添加箭头的设备
|
| | | } else {
|
| | | params.put("preAngleDeviceString", 0);
|
| | | }
|
| | | //windList.get((Integer) longAndLatiList.get(indexAngle).get("f"))获得风向和经纬度
|
| | | preAngleDeviceList.add(windList.get((Integer) longAndLatiList.get(indexAngle).get("h")));
|
| | | preAngleDeviceList.add(windList.get((Integer) longAndLatiList.get(indexAngle).get("f")));
|
| | |
|
| | | Double length = mapUtils.getDistance((Double) preAngleDeviceList.get(0).get("longitude"), (Double) preAngleDeviceList.get(0).get("latitude"),
|
| | | (Double) preAngleDeviceList.get(1).get("longitude"), (Double) preAngleDeviceList.get(1).get("latitude"));
|
| | | Double subLength = length / 5;
|
| | | Double angle = mapUtils.getAngle(
|
| | | new MyLatLng((Double) preAngleDeviceList.get(0).get("longitude"),
|
| | | (Double) preAngleDeviceList.get(0).get("latitude")),
|
| | | new MyLatLng((Double) preAngleDeviceList.get(1).get("longitude"),
|
| | | (Double) preAngleDeviceList.get(1).get("latitude")));
|
| | |
|
| | | params.put("preAngleDeviceList", preAngleDeviceList);
|
| | | params.put("angle", angle);
|
| | | List locationList = new ArrayList();
|
| | | String[] firstLocation = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, (Double) preAngleDeviceList.get(0).get("longitude"),
|
| | | (Double) preAngleDeviceList.get(0).get("latitude"), subLength);
|
| | | String[] secondLoction = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(firstLocation[0]),
|
| | | Double.parseDouble(firstLocation[1]), subLength);
|
| | | String[] thirdLocation = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(secondLoction[0]),
|
| | | Double.parseDouble(secondLoction[1]), subLength);
|
| | | String[] fourthLoction = mapUtils.calLocationByDistanceAndLocationAndDirection(angle, Double.parseDouble(thirdLocation[0]),
|
| | | Double.parseDouble(thirdLocation[1]), subLength);
|
| | | locationList.add(firstLocation);
|
| | | locationList.add(secondLoction);
|
| | | locationList.add(thirdLocation);
|
| | | locationList.add(fourthLoction);
|
| | | params.put("locationList", locationList);
|
| | |
|
| | | String preAngleDeviceString = JSON.toJSON(preAngleDeviceList).toString();
|
| | | params.put("preAngleDeviceString", preAngleDeviceString);//两台添加箭头的设备
|
| | | params.put("wind", wind);
|
| | | //String preAngleDeviceString=preAngleDeviceList.
|
| | | params.put("deviceList", deviceList);
|
| | | } else {
|
| | | params.put("preAngleDeviceString", "");
|
| | | if (deviceList.size() != 0) {
|
| | | params.put("deviceList", deviceList.get(0));
|
| | | } else {
|
| | | params.put("deviceList", "");
|
| | | }
|
| | | params.put("preAngleDeviceString", 1);
|
| | | params.put("locationList", "");
|
| | | }
|
| | | //String preAngleDeviceString=preAngleDeviceList.
|
| | |
|
| | | params.put("wind", wind);
|
| | | params.put("list1", list1);
|
| | | params.put("deviceList", deviceList);
|
| | | params.put("latitudeCompany", latitudeCompany);
|
| | | params.put("longitudeCompany", longitudeCompany);
|
| | | }
|
| | |
|
| | | return params;
|
| | | }
|
| | |
|
| | | @Override
|
| | | public JSONObject getMacList(int monitPointId) {
|
| | | JSONObject params = new JSONObject();
|
| | | MonitorPoint monitorPoint = monitorPointMapper.getMonitorPointById(monitPointId);
|
| | |
|
| | | //获取厂界所有设备
|
| | | List<Device> deviceList = deviceService.getDeviceById2(monitPointId);
|
| | |
|
| | | params.put("longitudeCompany", monitorPoint.getLongitude());
|
| | | params.put("latitudeCompany", monitorPoint.getLatitude());
|
| | | params.put("latitudeCompany", monitorPoint.getLatitude());
|
| | | params.put("monitPointId", monitPointId);
|
| | | params.put("deviceList", deviceList);
|
| | | return params;
|
| | | }
|
| | |
|
| | | @Override
|
| | | public List<MonitorPoint> getMonitorPointListByAccountId(int id) {
|
| | | return monitorPointMapper.getMonitorPointListByAccountId(id);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public MonitorPoint byIdGetMonitorPoint(int id) {
|
| | | return monitorPointMapper.byIdGetMonitorPoint(id);
|
| | | }
|
| | |
|
| | | @Override
|
| | | public String getOrgIdByMac(String mac) {
|
| | | return monitorPointMapper.getOrgIdByMac(mac);
|
| | | }
|
| | |
|
| | |
|
| | | }
|