From f1afc9dd47bc8e9d4d2c86a5bbd099ee0d7824f2 Mon Sep 17 00:00:00 2001 From: CeDo <cedoogle@gmail.com> Date: 星期一, 07 六月 2021 20:14:00 +0800 Subject: [PATCH] Merge branch 'test_future_wangge' into test --- springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventGridMemberWarnLogServiceImpl.java | 91 +++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 91 insertions(+), 0 deletions(-) diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventGridMemberWarnLogServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventGridMemberWarnLogServiceImpl.java index 80cc345..626a6d0 100644 --- a/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventGridMemberWarnLogServiceImpl.java +++ b/springcloud_k8s_panzhihuazhihuishequ/service_grid/src/main/java/com/panzhihua/service_grid/service/impl/EventGridMemberWarnLogServiceImpl.java @@ -1,5 +1,6 @@ package com.panzhihua.service_grid.service.impl; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; @@ -7,6 +8,9 @@ import com.panzhihua.common.model.vos.R; import com.panzhihua.common.model.vos.grid.EventGridMemberWarnLogDetailsVO; import com.panzhihua.common.model.vos.grid.EventGridMemberWarnLogVO; +import com.panzhihua.common.model.vos.grid.LatLngVO; +import com.panzhihua.common.utlis.LngLatUtils; +import com.panzhihua.common.utlis.StringUtils; import com.panzhihua.service_grid.dao.*; import com.panzhihua.service_grid.model.dos.*; import com.panzhihua.service_grid.service.EventGridMemberWarnLogService; @@ -16,6 +20,7 @@ import javax.annotation.Resource; import java.util.Date; +import java.util.List; /** * @auther lyq @@ -28,6 +33,12 @@ @Resource private EventGridMemberWarnLogMapper eventGridMemberWarnLogMapper; + @Resource + private EventGridMemberGpsLogMapper eventGridMemberGpsLogMapper; + @Resource + private EventGridDataMapper eventGridDataMapper; + @Resource + private EventGridMemberRelationMapper eventGridMemberRelationMapper; /** * 新增网格员定时上报地理预警记录 * @param eventGridMemberWarnLogAddDTO @@ -108,4 +119,84 @@ return R.ok(this.baseMapper.gridMemberWorkWarning(new Page(gridMemberWainDTO.getPageNum(),gridMemberWainDTO.getPageSize()),gridMemberWainDTO)); } + /** + * 定时任务扫描网格员工作状态 + * @return 定时任务扫描结果 + */ + @Override + public R timedTaskGridMember(){ + + //查询所有网格数据 + List<EventGridDataDO> gridDataDOList = eventGridDataMapper.selectList(new QueryWrapper<EventGridDataDO>() + .lambda().eq(EventGridDataDO::getType,EventGridDataDO.type.sq)); + if(gridDataDOList.isEmpty()){ + return R.fail("未查询到网格数据"); + } + + List<EventGridMemberGpsLogDO> memberGpsLogDOS = eventGridMemberGpsLogMapper.selectList(new QueryWrapper<EventGridMemberGpsLogDO>() + .lambda().eq(EventGridMemberGpsLogDO::getPositionStation,EventGridMemberGpsLogDO.positionStation.no)); + if(!memberGpsLogDOS.isEmpty()){ + memberGpsLogDOS.forEach(memberGpsLog -> { + //取出经纬度信息 + if(StringUtils.isNotEmpty(memberGpsLog.getLngLat())){ + String []lngLat = memberGpsLog.getLngLat().split(","); + Double lat = Double.valueOf(lngLat[0]); + Double lng = Double.valueOf(lngLat[1]); + //遍历所有网格信息匹配网格员的坐标点是否在网格内 + Boolean isOk = true; + for (EventGridDataDO gridData:gridDataDOList) { + if(StringUtils.isNotEmpty(gridData.getData())){ + List<LatLngVO> latLngList = LngLatUtils.getLatLngFromText(gridData.getData()); + if(LngLatUtils.isInPolygon(latLngList,lng,lat)){//匹配通过 + isOk = false; + memberGpsLog.setGridId(gridData.getId()); + memberGpsLog.setGridCommunityId(gridData.getGridCommunityId()); + memberGpsLog.setGridStreetId(gridData.getGridStreetId()); + memberGpsLog.setGridName(gridData.getGridName()); + + Integer workStatus = 0; + //判断当前网格员与此网格是否有关系 + Integer count = eventGridMemberRelationMapper.selectCount(new QueryWrapper<EventGridMemberRelationDO>() + .lambda().eq(EventGridMemberRelationDO::getGridMemberId,memberGpsLog.getGridMemberId()) + .eq(EventGridMemberRelationDO::getGridId,memberGpsLog.getGridId())); + if(count > 0){ + //有关系说明此网格员未脱岗 + memberGpsLog.setPositionStation(EventGridMemberGpsLogDO.positionStation.normal); + workStatus = 1; + }else{ + //没关系说明此网格员脱岗了,需要添加预警信息 + memberGpsLog.setPositionStation(EventGridMemberGpsLogDO.positionStation.abnormal); + workStatus = 2; + + //新增网格员预警信息 + EventGridMemberWarnLogDO memberWarnLogDO = new EventGridMemberWarnLogDO(); + BeanUtils.copyProperties(memberGpsLog,memberWarnLogDO); + memberWarnLogDO.setId(null); + memberWarnLogDO.setContent("工作时间未在网格内预警"); + memberWarnLogDO.setHappenAt(memberGpsLog.getCreateAt()); + this.baseMapper.insert(memberWarnLogDO); + } + eventGridMemberGpsLogMapper.updateById(memberGpsLog); + //修改用户工作状态 + this.baseMapper.setUserWorkStatus(memberGpsLog.getGridMemberId(),workStatus); + break; + } + } + } + //判断这个网格员的点是否能匹配上所有的网格 + if(isOk){ + //新增网格员预警信息 + EventGridMemberWarnLogDO memberWarnLogDO = new EventGridMemberWarnLogDO(); + BeanUtils.copyProperties(memberGpsLog,memberWarnLogDO); + memberWarnLogDO.setId(null); + memberWarnLogDO.setContent("工作时间未在网格内预警"); + memberWarnLogDO.setHappenAt(memberGpsLog.getCreateAt()); + this.baseMapper.insert(memberWarnLogDO); + } + } + }); + } + return R.ok(); + } + } -- Gitblit v1.7.1