BikeHandler.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: Mead
  5. * Date: 2019/9/10
  6. * Time: 4:08 PM
  7. */
  8. namespace App\Handlers;
  9. use App\Maps\CacheMap;
  10. use App\Models\Area;
  11. use App\Models\AreaSetting;
  12. use App\Models\Parking;
  13. use Carbon\Carbon;
  14. use Illuminate\Support\Facades\Cache;
  15. use Illuminate\Support\Facades\Redis;
  16. use Illuminate\Support\Facades\Log;
  17. class BikeHandler
  18. {
  19. public function byLocationCheckIsInBanStopParking($lat, $lng, $area_id = 0)
  20. {
  21. $options = ['SORT' => 'ASC', 'COUNT' => 1, 'WITHDIST' => true];
  22. $redis = Redis::connection();
  23. $ban_stop_bike_stations = $redis->georadius(Parking::REDIS_BAN_STOP_BIKE_SITE_TAG . "_{$area_id}", $lng, $lat, 17000, 'm', $options);
  24. if (count($ban_stop_bike_stations) !== 1) {
  25. //没有找到禁停区
  26. return false;
  27. }
  28. $stop_bike_station = $ban_stop_bike_stations[0];
  29. $park_id = $stop_bike_station[0];
  30. $stop_bike_station_db = Cache::remember(Parking::REDIS_BAN_STOP_BIKE_SITE_TAG . $park_id, Carbon::now()->addHours(1), function () use ($park_id) {
  31. return Parking::where('id', $park_id)->where('status', Parking::STATUS_OK)->first();
  32. });
  33. $ConverHandler = new ConvertHandler();
  34. $is_in_station = $ConverHandler->is_point_in_polygon([
  35. 'latitude' => $lat,
  36. 'longitude' => $lng
  37. ], $stop_bike_station_db->parking_fence);
  38. if ($is_in_station) {
  39. return true;
  40. }
  41. //判断是否在辐射范围
  42. // $is_in_near_station = $ConverHandler->is_point_in_circle([
  43. // 'latitude' => $lat,
  44. // 'longitude' => $lng
  45. // ], ['center' => $stop_bike_station_db->parking_centre, 'radius' => $stop_bike_station_db->parking_radius]);
  46. //
  47. // if ($is_in_near_station) {
  48. // return true;
  49. // }
  50. return false;
  51. }
  52. /**
  53. * 判断是否在停车点
  54. * @param $lat
  55. * @param $lng
  56. * @param int $area_id
  57. * @return array
  58. * User: Mead
  59. */
  60. public function byLocationCheckIsInStopParking($lat, $lng, $area_id = 0)
  61. {
  62. // 判断是否有还车点
  63. $options = ['SORT' => 'ASC', 'COUNT' => 1, 'WITHDIST' => true];
  64. $redis = Redis::connection();
  65. $stop_bike_stations = $redis->georadius(Parking::REDIS_STOP_BIKE_SITE_TAG . "_{$area_id}", $lng, $lat, 17000, 'm', $options);
  66. if (count($stop_bike_stations) !== 1) {
  67. //没有找到停车点
  68. return [
  69. 'status' => false,
  70. 'distance' => 999999
  71. ];
  72. }
  73. $stop_bike_station = $stop_bike_stations[0];
  74. $distance = $stop_bike_station[1];
  75. $park_id = $stop_bike_station[0];
  76. $stop_bike_station_db = Cache::remember("PARKING_" . $park_id, Carbon::now()->addHours(1), function () use ($park_id) {
  77. return Parking::where('id', $park_id)->first();
  78. });
  79. // 判断是否在还车点内
  80. $ConverHandler = new ConvertHandler();
  81. $is_in_station = $ConverHandler->is_point_in_polygon([
  82. 'latitude' => $lat,
  83. 'longitude' => $lng
  84. ], $stop_bike_station_db->parking_fence);
  85. if ($is_in_station) {
  86. return [
  87. 'status' => true,
  88. 'distance' => $distance
  89. ];
  90. }
  91. $isOpenStopBikeFushe = Cache::remember(CacheMap::IS_OPEN_STOP_BIKE_FUSHE . ':' . $area_id, Carbon::now()->addSeconds(CacheMap::CACHE_TIME), function () use ($area_id) {
  92. return AreaSetting::where('area_id', $area_id)->value('is_parking_fushe');
  93. });
  94. if (!$isOpenStopBikeFushe) {
  95. //是否启用还车点辐射范围
  96. return [
  97. 'status' => false,
  98. 'distance' => $distance
  99. ];
  100. }
  101. // 判断是否在还车点范围内
  102. $is_in_near_station = $ConverHandler->is_point_in_circle([
  103. 'latitude' => $lat,
  104. 'longitude' => $lng
  105. ], ['center' => $stop_bike_station_db->parking_centre, 'radius' => $stop_bike_station_db->parking_radius]);
  106. if ($is_in_near_station) {
  107. return [
  108. 'status' => true,
  109. 'type' => 'circle',
  110. 'distance' => $distance
  111. ];
  112. }
  113. return [
  114. 'status' => false,
  115. 'distance' => $distance
  116. ];
  117. }
  118. /**
  119. * 通过距离获取调度费
  120. * @param $distance
  121. * User: Mead
  122. */
  123. public function byDistanceGetDistanceMoney($distance, $areaSetting)
  124. {
  125. $gl = $areaSetting->min_limit_km * 1000;
  126. if ($distance <= $gl) {
  127. return $areaSetting->min_dispatching_fee;
  128. }
  129. $over_distance = $distance - $gl;
  130. $over_money = bcadd($areaSetting->min_dispatching_fee, ceil($over_distance / (1000 * $areaSetting->over_limit_per_km)) * $areaSetting->over_limit_per_km_money, 2);
  131. if ($over_money < $areaSetting->max_dispatching_fee) {
  132. return $over_money;
  133. }
  134. return $areaSetting->max_dispatching_fee;
  135. }
  136. }