GameController.php 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. <?php
  2. namespace App\Home\Controllers;
  3. use App\Http\Controllers\Controller;
  4. use Illuminate\Http\Request;
  5. use GatewayWorker\Lib\Gateway;
  6. use App\Model\Question;
  7. use App\Model\Option;
  8. use App\Model\RoomUser;
  9. use App\Model\RoomQuestion;
  10. use App\Model\RoomAnswer;
  11. use App\Model\Room;
  12. use Illuminate\Support\Facades\Redis;
  13. use App\Jobs\Settlement;
  14. class GameController extends Controller
  15. {
  16. /**
  17. * 回答问题
  18. */
  19. public function Answer(Request $request)
  20. {
  21. if(!$request->session()->has('user_id')){
  22. $response['code'] = 400;
  23. $response['msg'] = '请先登录';
  24. return response()->json($response);
  25. }
  26. $answer_time = time();
  27. $question_id = $request->input('question_id');
  28. $option_id = $request->input('option_id');
  29. $user_id = $request->session()->get('user_id');
  30. //注册gateway地址
  31. Gateway::$registerAddress = '127.0.0.1:1238';
  32. //获取房间号
  33. $room_id = RoomUser::where(["user_id"=>$user_id,"state"=>1])->value('room_id');
  34. if(!$room_id){
  35. $response['code'] = 400;
  36. $response['msg'] = '没有加入房间';
  37. return response()->json($response);
  38. }
  39. //判断答案逻辑
  40. $is_true = Option::where([
  41. ["question_id", $question_id],
  42. ["option_id", $option_id],
  43. ["is_answer", 1],
  44. ])->count();
  45. //判断用户回答获取分数
  46. if($is_true){
  47. //获取当前题目开始时间
  48. $start_at = RoomQuestion::where(["question_id" => $question_id, "room_id" => $room_id])->value('start_at');
  49. $answer_diff = $answer_time - strtotime($start_at);
  50. if($request->input('anwser_time')){
  51. $anwser_time = (int) $request->input('anwser_time');
  52. $answer_diff = abs(10 - $anwser_time);
  53. }
  54. switch ($answer_diff) {
  55. case '0':
  56. $score = 100;
  57. break;
  58. case '1':
  59. $score = 90;
  60. break;
  61. case '2':
  62. $score = 80;
  63. break;
  64. case '3':
  65. $score = 70;
  66. break;
  67. case '4':
  68. $score = 60;
  69. break;
  70. case '5':
  71. $score = 50;
  72. break;
  73. case '6':
  74. $score = 40;
  75. break;
  76. case '7':
  77. $score = 30;
  78. break;
  79. case '8':
  80. $score = 20;
  81. break;
  82. case '9':
  83. $score = 10;
  84. break;
  85. default:
  86. $score = 0;
  87. break;
  88. }
  89. }else{
  90. $score = 0;
  91. }
  92. //写入记录
  93. $result = RoomAnswer::insert([
  94. "question_id" => $question_id,
  95. "option_id" => $option_id,
  96. "user_id" => $user_id,
  97. "room_id" => $room_id,
  98. "score" => $score,
  99. "created_at" => date('Y-m-d H:i:s'),
  100. "updated_at" => date('Y-m-d H:i:s'),
  101. ]);
  102. if(!$result){
  103. //发送消息
  104. $response['code'] = 400;
  105. $response['msg'] = '重复回答';
  106. return response()->json($response);
  107. }
  108. if($score){
  109. //增加总分
  110. RoomUser::where([
  111. "user_id" => $user_id,
  112. "room_id" => $room_id,
  113. ])->increment('score', $score);
  114. }
  115. $total_score = (int) RoomUser::where([
  116. "user_id" => $user_id,
  117. "room_id" => $room_id,
  118. ])->value('score');
  119. $message['score'] = $score;
  120. $message['total_score'] = $total_score;
  121. $message['user_id'] = $user_id;
  122. $message['type'] = 'answer';
  123. Gateway::sendToGroup($room_id, json_encode($message));
  124. //获取房间信息,最后一个回答触发结算程序
  125. $room_user_limit = Room::where("room_id", $room_id)->value("user_limit");
  126. //获取当前题目回答人数
  127. $answer_user_count = RoomAnswer::where([
  128. "room_id" => $room_id,
  129. "question_id" => $question_id,
  130. ])->count();
  131. if($room_user_limit == $answer_user_count){
  132. if(!isset($start_at)){
  133. $start_at = RoomQuestion::where(["question_id" => $question_id, "room_id" => $room_id])->value('start_at');
  134. }
  135. $next_date = date('YmdHis', strtotime("{$start_at} +10 seconds"));
  136. //先删除固定结算任务队列
  137. Redis::lrem("Game_settlement_{$next_date}", 1, $room_id);
  138. //执行结算队列
  139. Settlement::dispatch($room_id)->onQueue('settlement');
  140. }
  141. //发送消息
  142. $response['code'] = 0;
  143. $response['msg'] = '回答成功';
  144. //返回回答信息
  145. return response()->json($response);
  146. }
  147. /**
  148. * 加入房间
  149. */
  150. public function Join(Request $request)
  151. {
  152. if(!$request->session()->has('user_id')){
  153. $response['code'] = 400;
  154. $response['msg'] = '请先登录';
  155. return response()->json($response);
  156. }
  157. $user_id = $request->session()->get('user_id');
  158. //检查是否在房间中
  159. $is_in_room = RoomUser::where("user_id", $user_id)->where("state", 1)->count();
  160. if($is_in_room){
  161. $response['code'] = 400;
  162. $response['msg'] = "已在房间中";
  163. return response()->json($response);
  164. }
  165. //删除队列再加入匹配
  166. Redis::lrem('match_list', 1, $user_id);
  167. Redis::rpush('match_list', $user_id);
  168. $response['code'] = 0;
  169. $response['msg'] = "已加入匹配队列";
  170. return response()->json($response);
  171. }
  172. /**
  173. * 取消匹配
  174. */
  175. public function Quit(Request $request)
  176. {
  177. if(!$request->session()->has('user_id')){
  178. $response['code'] = 400;
  179. $response['msg'] = '请先登录';
  180. return response()->json($response);
  181. }
  182. $username = $session->get('username');
  183. $avatar = $session->get('avatar');
  184. $user_id = $request->session()->get('user_id');
  185. $username = $request->session()->get('username');
  186. $avatar = $request->session()->get('avatar');
  187. $client_id = $request->input('client_id');
  188. $data = json_encode(['user_id'=>$user_id,'level'=>'T1','avatar'=>$avatar,'username'=>$username,'client_id'=>$client_id]);
  189. Redis::lrem('match_list',1,$data);
  190. //删除房间
  191. Redis::del('T1');
  192. $response['code'] = 0;
  193. $response['msg'] = "已取消匹配";
  194. return response()->json($response);
  195. }
  196. }