GameController.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  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. $answer_diff = abs(10 - $anwser_time);
  52. }
  53. switch ($answer_diff) {
  54. case '0':
  55. $score = 100;
  56. break;
  57. case '1':
  58. $score = 90;
  59. break;
  60. case '2':
  61. $score = 80;
  62. break;
  63. case '3':
  64. $score = 70;
  65. break;
  66. case '4':
  67. $score = 60;
  68. break;
  69. case '5':
  70. $score = 50;
  71. break;
  72. case '6':
  73. $score = 40;
  74. break;
  75. case '7':
  76. $score = 30;
  77. break;
  78. case '8':
  79. $score = 20;
  80. break;
  81. case '9':
  82. $score = 10;
  83. break;
  84. default:
  85. $score = 0;
  86. break;
  87. }
  88. }else{
  89. $score = 0;
  90. }
  91. //写入记录
  92. $result = RoomAnswer::insert([
  93. "question_id" => $question_id,
  94. "option_id" => $option_id,
  95. "user_id" => $user_id,
  96. "room_id" => $room_id,
  97. "score" => $score,
  98. "created_at" => date('Y-m-d H:i:s'),
  99. "updated_at" => date('Y-m-d H:i:s'),
  100. ]);
  101. if(!$result){
  102. //发送消息
  103. $response['code'] = 400;
  104. $response['msg'] = '重复回答';
  105. return response()->json($response);
  106. }
  107. if($score){
  108. //增加总分
  109. RoomUser::where([
  110. "user_id" => $user_id,
  111. "room_id" => $room_id,
  112. ])->increment('score', $score);
  113. }
  114. $total_score = (int) RoomUser::where([
  115. "user_id" => $user_id,
  116. "room_id" => $room_id,
  117. ])->value('score');
  118. $message['score'] = $score;
  119. $message['total_score'] = $total_score;
  120. $message['user_id'] = $user_id;
  121. $message['type'] = 'answer';
  122. Gateway::sendToGroup($room_id, json_encode($message));
  123. //获取房间信息,最后一个回答触发结算程序
  124. $room_user_limit = Room::where("room_id", $room_id)->value("user_limit");
  125. //获取当前题目回答人数
  126. $answer_user_count = RoomAnswer::where([
  127. "room_id" => $room_id,
  128. "question_id" => $question_id,
  129. ])->count();
  130. if($room_user_limit == $answer_user_count){
  131. if(!isset($start_at)){
  132. $start_at = RoomQuestion::where(["question_id" => $question_id, "room_id" => $room_id])->value('start_at');
  133. }
  134. $next_date = date('YmdHis', strtotime("{$start_at} +10 seconds"));
  135. //先删除固定结算任务队列
  136. Redis::lrem("Game_settlement_{$next_date}", 1, $room_id);
  137. //执行结算队列
  138. Settlement::dispatch($room_id)->onQueue('settlement');
  139. }
  140. //发送消息
  141. $response['code'] = 0;
  142. $response['msg'] = '回答成功';
  143. //返回回答信息
  144. return response()->json($response);
  145. }
  146. /**
  147. * 加入房间
  148. */
  149. public function Join(Request $request)
  150. {
  151. if(!$request->session()->has('user_id')){
  152. $response['code'] = 400;
  153. $response['msg'] = '请先登录';
  154. return response()->json($response);
  155. }
  156. $user_id = $request->session()->get('user_id');
  157. //检查是否在房间中
  158. $is_in_room = RoomUser::where("user_id", $user_id)->where("state", 1)->count();
  159. if($is_in_room){
  160. $response['code'] = 400;
  161. $response['msg'] = "已在房间中";
  162. return response()->json($response);
  163. }
  164. //删除队列再加入匹配
  165. Redis::lrem('match_list', 1, $user_id);
  166. Redis::rpush('match_list', $user_id);
  167. $response['code'] = 0;
  168. $response['msg'] = "已加入匹配队列";
  169. return response()->json($response);
  170. }
  171. /**
  172. * 取消匹配
  173. */
  174. public function Quit(Request $request)
  175. {
  176. if(!$request->session()->has('user_id')){
  177. $response['code'] = 400;
  178. $response['msg'] = '请先登录';
  179. return response()->json($response);
  180. }
  181. $username = $session->get('username');
  182. $avatar = $session->get('avatar');
  183. $user_id = $request->session()->get('user_id');
  184. $username = $request->session()->get('username');
  185. $avatar = $request->session()->get('avatar');
  186. $client_id = $request->input('client_id');
  187. $data = json_encode(['user_id'=>$user_id,'level'=>'T1','avatar'=>$avatar,'username'=>$username,'client_id'=>$client_id]);
  188. Redis::lrem('match_list',1,$data);
  189. //删除房间
  190. Redis::del('T1');
  191. $response['code'] = 0;
  192. $response['msg'] = "已取消匹配";
  193. return response()->json($response);
  194. }
  195. }