Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/1gyou1/subway-game
https://github.com/1gyou1/subway-game
api async-await react-router-dom reactjs usenavigate-hook useparams-hook
Last synced: 4 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/1gyou1/subway-game
- Owner: 1GYOU1
- Created: 2023-10-25T01:24:37.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2024-01-13T15:42:03.000Z (about 1 year ago)
- Last Synced: 2024-12-26T19:14:02.195Z (about 2 months ago)
- Topics: api, async-await, react-router-dom, reactjs, usenavigate-hook, useparams-hook
- Language: JavaScript
- Homepage: https://1gyou1.github.io/subway-game/
- Size: 6.86 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# subway-game
- 2023년 11월 진행
- React.js 라이브러리, 지하철 노선도 API를 사용하여 지하철 랜덤 호선 맞추기 게임 구현
### 👀 MainPage View
data:image/s3,"s3://crabby-images/ab3ae/ab3ae071720fd31441a7615ba57f9d80b732a4e5" alt="지하철_1"
data:image/s3,"s3://crabby-images/d6cc2/d6cc2b21fe81672e7344b79e151645d4cfb0f7a0" alt="지하철_2"
data:image/s3,"s3://crabby-images/155ed/155ed5a53bb0b2ec592262f50c26eed81d102911" alt="지하철_3"
data:image/s3,"s3://crabby-images/6b32b/6b32b932941de07d11eed916092c51fd1f785ffa" alt="지하철_4"
data:image/s3,"s3://crabby-images/241a6/241a679acf76acbb7c9cc6ec4ab50084074693e2" alt="지하철_5"
### 📌 주요 기술 스택
![]()
![]()
![]()
![]()
### 📌 주요 기능
- 인트로 애니메이션
- 지하철 노선도 API
- 숫자 랜덤 노출
- 타이머
- 정답, 오답, 중복 체크### Github Pages
https://1gyou1.github.io/subway-game/
### 프로젝트 진행 과정
1.
프로젝트 기획/구상data:image/s3,"s3://crabby-images/5f889/5f88984657127f990b64c5f08c53d9e1aa2968a8" alt="ppt1"
data:image/s3,"s3://crabby-images/d705a/d705aa79a461e461325229b038304904130bdad7" alt="ppt3"
data:image/s3,"s3://crabby-images/d98d9/d98d9496d868d2f46d43f9f69518f53b7eab511c" alt="ppt4"
data:image/s3,"s3://crabby-images/20ef3/20ef376298ad3f1a2616d46e6ef8ce5e05cc49d7" alt="ppt5"
data:image/s3,"s3://crabby-images/f2910/f291068ff9fa88973394333f0af01995f929af63" alt="ppt7"
data:image/s3,"s3://crabby-images/2983b/2983beed304f1ad34175c03d5bbcc238cca3ad8e" alt="ppt8"
data:image/s3,"s3://crabby-images/d772a/d772aef4424fd355c216368f12427b7eb0765f7a" alt="ppt9"
data:image/s3,"s3://crabby-images/93384/933848d3975260ddb04c146cb2585b0c810b8a43" alt="ppt10"
data:image/s3,"s3://crabby-images/13828/13828a38c5f533aada41a17c63790b5d71587926" alt="ppt11"
data:image/s3,"s3://crabby-images/0d3bb/0d3bba45a6da65ce8db7fb74d79c359c5dbbfe46" alt="ppt12"
data:image/s3,"s3://crabby-images/61435/614355fbb70a51e17a8482fc82043f36e33770a6" alt="ppt13"
data:image/s3,"s3://crabby-images/62781/627812c5c74fa5f4c02ad4413145b990b65575e0" alt="ppt14"
data:image/s3,"s3://crabby-images/e0131/e01312187dd6560b86d808758fd00490b5bad3aa" alt="ppt15"
data:image/s3,"s3://crabby-images/9ef17/9ef1779572873093b7ecc0692422770c39bd4789" alt="ppt16"
2. 프로젝트 설치, 개발 환경 세팅
3. 인트로 애니메이션 구현
4. 게임 시작, 방법 화면 구현
5. 체크박스로 노선 선택해서 선택한 노선만 랜덤 호출 (Select.js)
ㄴ 처음 게임 옵션은 1, 2, 3, 4호선 중에 선택하여 랜덤
ㄴ 업그레이드 버전은 1, 2, 3, 4, 5, 6, 7, 8, 9호선 모두 랜덤 고정
6. 0 ~ 4중에 랜덤으로 숫자 노출
ㄴ한 문제마다 랜덤 돌리기
ㄴ Select 컴포넌트에서 선택한 호선 배열로 가져오고 index 랜덤으로 돌려서 출력
7. api 맨 처음 한번만 가져오기. ex - {['01호선', '평택역']}
ㄴ 필요한 형태로 가져오기{{ LINE_NUM, STATION_NM }, [1, 평택], [1, 금정]}
ㄴ 서울역 예외처리 - 데이터가 '서울'이 아닌 '서울역'으로 되어있어서 수정 필요.
8. input (정답 칸에)입력 텍스트 받아오기
ㄴ입력한 값 useState에 넣고(inputValue) 특수문자, 영어, 숫자 입력 제한
9. input에 답안 입력 후 엔터키, 클릭 시 제출, 초기화
ㄴ 자동 input focus
10. 제출한 입력값이 api 요소의 호선(0번째 배열 요소값), 역 이름(1번째 배열 요소값)이 비교
ㄴ 맞으면 원본배열에서 삭제, 내 맞춘 답안 정답 배열 setCorrect에 넣기
ㄴ 같은 역이름을 가진 다른 호선 배열 값도 삭제(중복 체크), 내 맞춘 답안 정답 배열 setCorrect에 넣기
ㄴ 이미 정답 배열에 있는 값이라면 중복 이미지 노출
11. 정답, 오답, 중복 이미지 노출
ㄴ 정답, 오답, 중복이면 다음 문제 노출
ㄴ 정답이면 quizCount++ (퀴즈 타이틀 숫자 + 1)
ㄴ 정답이면 myScore 점수 올리기 (한 문제당 + 10)
12. 최대 10문제 진행 quizCount++
13. 타이머기능 10초 -> 10초 지나면 게임 오버. (결과 페이지로)
14. 새로 고침 방지
15. 결과 값 params로 전달
16. 결과 페이지 노출 (상, 중, 하)
17. Next stage
ㄴ nextStage intro.js
ㄴ nextStage Go.js
ㄴ 1~9호선 랜덤 노출
ㄴ 5초 안에 맞추기
18. nextStage에서 게임오버하면 nextStage로 재시작 버튼 생성
ㄴ 처음부터 버튼도 생성