SystemlService.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212
  1. <?php
  2. namespace App\Service;
  3. use App\Model\Device;
  4. use App\Model\DeviceType;
  5. use App\Model\ScreenDevice;
  6. use App\Model\SystemL;
  7. class SystemlService extends Service
  8. {
  9. public static function getLastData($code = [], $min = -1){
  10. if(empty($code)) return [];
  11. $time = strtotime($min.' min',time());
  12. $time = $time * 1000;
  13. $result = SystemL::whereIn('device_no',$code)
  14. ->where('push_time','>=',$time)
  15. ->select('data_point_name','value','device_no')
  16. ->orderBy('id','desc')
  17. ->get()->toArray();
  18. $return = [];
  19. if(! empty($result)){
  20. foreach ($result as $value){
  21. if(isset($return[$value['device_no']])) continue;
  22. //只取每个设备最新的一条数据
  23. $return[$value['device_no']] = [
  24. 'data_point_name' => $value['data_point_name'],
  25. 'value' => $value['value']
  26. ];
  27. }
  28. }
  29. return $return;
  30. }
  31. //'gateway_id' => 键,'screen_id' => 值
  32. public static function getIsOnlineStatus($map = []){
  33. if(empty($map)) return [];
  34. //仓是否在线
  35. $result = $screen_id = $gateway = $tmp = [];
  36. foreach ($map as $value){
  37. $result[$value['screen_id']] = 0;
  38. // $gateway[] = $value['gateway_id'];
  39. // $tmp[$value['screen_id']] = $value['gateway_id'];
  40. $screen_id[] = $value['screen_id'];
  41. }
  42. ;
  43. //设备 和 仓的关系
  44. $return = ScreenDevice::from('screen_device as a')
  45. ->leftJoin('device as b','b.id','a.device_id')
  46. ->whereIn('a.screen_id',$screen_id)
  47. ->where('a.del_time',0)
  48. ->pluck('a.screen_id','b.code')
  49. ->toArray();
  50. // $device = Device::where('del_time',0)
  51. // ->whereIn('gateway_id',$gateway)
  52. // ->select('code','gateway_id')->get()->toArray();dump($tmp);die;
  53. // foreach ($device as $value){
  54. // foreach ($tmp as $k_screen_id => $v){
  55. // if($value['gateway_id'] == $v){
  56. // $return[$value['code']] = $k_screen_id;
  57. // }
  58. // }
  59. // }
  60. //获取最新设备的数据
  61. $data = self::getLastData(array_keys($return));
  62. foreach ($data as $key => $value){
  63. if(isset($return[$key])){
  64. $result[$return[$key]] = 1;
  65. }
  66. }
  67. return $result;
  68. }
  69. public static function getGpsStatus($screen_id){
  70. if(empty($screen_id)) return [];
  71. //仓 载运2/闲置1/停运0
  72. $result = [];
  73. foreach ($screen_id as $value){
  74. $result[$value] = 0;
  75. }
  76. $screen = ScreenDevice::from('screen_device as a')
  77. ->leftJoin('device as b','b.id','a.device_id')
  78. ->leftJoin('screen as c','c.id','a.screen_id')
  79. ->where('b.device_type_id',DeviceType::type_four)
  80. ->whereIn('a.screen_id',$screen_id)
  81. ->select('b.code','c.coordinate','a.screen_id')
  82. ->get()->toArray();
  83. if(empty($screen)) return $result;
  84. $screen_map = array_column($screen,null,'code');
  85. //获取最新设备的数据
  86. $data = self::getLastData(array_column($screen,'code'));
  87. foreach ($data as $key => $value){
  88. if(isset($screen_map[$key])){
  89. $tmp = $screen_map[$key];
  90. $tmp_coordinate = $tmp['coordinate'];
  91. if(isset($result[$tmp['screen_id']]) && $tmp_coordinate){
  92. //计算偏差值
  93. try {
  94. $meter = self::calculateDistance($tmp_coordinate,$value['value']);
  95. if($meter > 200){
  96. $result[$tmp['screen_id']] = 2;
  97. }else{
  98. $result[$tmp['screen_id']] = 1;
  99. }
  100. }catch (\Exception $e){
  101. continue;
  102. }
  103. }
  104. }
  105. }
  106. return $result;
  107. }
  108. public static function calculateDistance($coordinate1, $coordinate2) {
  109. $earthRadius = 6371000; // 地球半径,单位为米
  110. list($lat1,$lon1) = explode(',',$coordinate1);
  111. list($lat2,$lon2) = explode(',',$coordinate2);
  112. $lat1Rad = deg2rad($lat1);
  113. $lon1Rad = deg2rad($lon1);
  114. $lat2Rad = deg2rad($lat2);
  115. $lon2Rad = deg2rad($lon2);
  116. $deltaLat = $lat2Rad - $lat1Rad;
  117. $deltaLon = $lon2Rad - $lon1Rad;
  118. $a = sin($deltaLat / 2) * sin($deltaLat / 2) +
  119. cos($lat1Rad) * cos($lat2Rad) *
  120. sin($deltaLon / 2) * sin($deltaLon / 2);
  121. $c = 2 * atan2(sqrt($a), sqrt(1 - $a));
  122. $distance = $earthRadius * $c;
  123. return $distance;
  124. }
  125. public static function getExceptionStatus($screen_id){
  126. if(empty($screen_id)) return [];
  127. //仓 正常1/异常0
  128. $result = [];
  129. foreach ($screen_id as $value){
  130. $result[$value] = 0;
  131. }
  132. $screen = ScreenDevice::from('screen_device as a')
  133. ->leftJoin('device as b','b.id','a.device_id')
  134. ->whereIn('b.device_type_id',[DeviceType::type_two, DeviceType::type_three])
  135. ->whereIn('a.screen_id',$screen_id)
  136. ->select('b.code','a.screen_id')
  137. ->get()->toArray();
  138. if(empty($screen)) return $result;
  139. $screen_map = array_column($screen,null,'code');
  140. //获取最新设备的数据
  141. $data = self::getLastData(array_column($screen,'code'));
  142. foreach ($data as $key => $value){
  143. if(isset($screen_map[$key])){
  144. $tmp = $screen_map[$key];
  145. if(isset($result[$tmp['screen_id']]) && $value['value'] == 1){
  146. $result[$tmp['screen_id']] = 1;
  147. }
  148. }
  149. }
  150. return $result;
  151. }
  152. public static function getIsOnlineStatusGateWay($gateway){
  153. if(empty($gateway)) return [];
  154. //网关是否在线
  155. $result = [];
  156. foreach ($gateway as $value){
  157. $result[$value] = 0;
  158. }
  159. $device = Device::where('del_time',0)
  160. ->whereIn('gateway_id',$gateway)
  161. ->select('code','gateway_id')
  162. ->get()->toArray();
  163. $gateway_connect_device = [];
  164. foreach ($device as $value){
  165. $gateway_connect_device[$value['gateway_id']][] = $value['code'];
  166. }
  167. //获取最新设备的数据
  168. $data = self::getLastData(array_column($device,'code'));
  169. foreach ($gateway_connect_device as $gateway => $value){
  170. if(! empty($result[$gateway])) continue;
  171. foreach ($value as $code){
  172. if(isset($data[$code])){
  173. $result[$gateway] = 1;
  174. }
  175. }
  176. }
  177. return $result;
  178. }
  179. }