[Toy Project] 이번에는 웹 페이지 오목이다(2)🎲 [JavaScript로 오목 로직 구현하기]

2024. 3. 13. 00:12·◈ Yermi Project/Toy Project💎
728x90

- 이번에는 웹 페이지 오목이다(2)

1. 화점 찍어주기

바둑판에 화점이 없으니 너무 밋밋하여 위치 계산하여 찍어주었다.
for(var i = 0 ; i < 3 ; i++) {
    for(var j = 0 ; j < 3 ; j++) {
        let dot = document.createElement('div');
        dot.setAttribute('class', 'dot');
        let margin_top = 58 + (i * 120);
        let margin_left = 58 + (j * 120);
        dot.setAttribute('style', `margin-top: ${margin_top}px; margin-left: ${margin_left}px;`);
        board.appendChild(dot);
    }
}

이제는 화점도 찍힌 예쁜 바둑판


2. 오목 로직 구현하기

상하, 좌우, 왼쪽 대각, 오른쪽 대각. 총 네 방향을 다 고려해야 했다.
방향마다 로직을 다 짜놓고 공통 부분은 하나하나 지워나갔다.
function checkWin(row, col, turn) {
    const directions = [
        [-1,  0], [1,  0], // 상하
        [0,  -1], [0,  1], // 좌우
        [-1, -1], [1,  1], // 좌상우하 대각선
        [-1,  1], [1, -1]  // 우상좌하 대각선
    ];

    for (const [dx, dy] of directions) {
        let cnt = 1;
        // 특정 방향으로 진행하면서 연속된 돌 개수 세기
        for (let i = 1; i < 5; i++) {
            const newRow = row + dx * i;
            const newCol = col + dy * i;

            if (newRow < 0 || newRow > 16 || newCol < 0 || newCol > 16 || game[newRow][newCol] !== turn) {
                break;
            }
            cnt++;
        }
        // 반대 방향으로 진행하면서 연속된 돌 개수 세기
        for (let i = 1; i < 5; i++) {
            const newRow = row - dx * i;
            const newCol = col - dy * i;

            if (newRow < 0 || newRow > 16 || newCol < 0 || newCol > 16 || game[newRow][newCol] !== turn) {
                break;
            }
            cnt++;
        }

        // 5개 이상일 경우 승리
        if (cnt >= 5) {
            return true;
        }
    }
    return false;
}

 

checkWin 함수를 기존 돌을 놓는 이벤트에 추가하여 오목 로직 적용 완료.
let game = new Array(17);
for(let i = 0 ; i < game.length ; i++) {
    game[i] = new Array(17);
}

let turn = 'B';

let tds = document.querySelectorAll('#go td');
tds.forEach((item) => {
    item.addEventListener('click', () => {
        // 위치 체크
        let row = Number(item.id.substring(0, item.id.indexOf('-')));
        let col = Number(item.id.substring(item.id.indexOf('-') + 1));
        
        // 돌 놓기
        if(game[row][col] === undefined) {
            game[row][col] = turn;
            let myTurn = turn === 'B';
            if(myTurn) {
                item.classList.add('black');
            } else {
                item.classList.add('white');
            }

            // 승리 체크
            if (checkWin(row, col, turn)) {
                let winner = myTurn ? '흑돌' : '백돌';
                setTimeout(function() {
                    alert(winner + ' 승!');
                    location.reload();
                }, 100);
            }
            
            turn = myTurn ? 'W' : 'B';
        }
    })
})

다섯개의 돌이 이어진다면 오목이라네~


3. 파비콘 및 메타태그 넣어주기

완성은 다 하였고, 배포 시에 좀 더 예쁘게 보이기 위해 파비콘과 메타태그를 추가하였다.
(이번 배포도 역시나 github로~)
<meta property="og:image" content="./images/omok.png">
<meta property="og:description" content="나무가 다섯그루면 오목">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>오목</title>
<link rel="icon" type="image/png" sizes="16x16" href="./images/omok_favicon.png">

 

오목

나무가 다섯그루면 오목

algo-gaja.github.io


- 소스코드

 

GitHub - algo-gaja/toy-project: 간단하게 만들어보는 Toy Project🧩

간단하게 만들어보는 Toy Project🧩. Contribute to algo-gaja/toy-project development by creating an account on GitHub.

github.com

 


 

테스트를 해준 현철브로의 선물..(?)


728x90
'◈ Yermi Project/Toy Project💎' 카테고리의 다른 글
  • [Toy Project] 식당 메뉴판 만들기🍖 (feat. CORS의 늪에 빠지다.) [axios, iframe 등을 활용한 네이버 블로그 스크랩핑 시도]
  • [Toy Project] 네이버 환율을 스크랩핑 해보자!💱 [Java로 만든 환율계산기]
  • [Toy Project] 이번에는 웹 페이지 오목이다(1)🎲 [JavaScript와 CSS로 바둑판 만들기]
  • [Toy Project] 예술의 정석, 일상에 예술 한 스푼🥄 [네이버지도를 활용한 간단한 웹페이지 배포]
예르미(yermi)
예르미(yermi)
끊임없이 제 자신을 계발하는 개발자입니다👨🏻‍💻
  • 예르미(yermi)
    예르미의 코딩노트
    예르미(yermi)
  • 전체
    오늘
    어제
    • 분류 전체보기 (937)
      • ◎ Java (133)
        • Java☕ (93)
        • JSP📋 (26)
        • Applet🧳 (6)
        • Interview👨🏻‍🏫 (8)
      • ◎ JavaScript (48)
        • JavaScript🦎 (25)
        • jQuery🌊 (8)
        • React🌐 (2)
        • Vue.js🔰 (6)
        • Node.js🫒 (3)
        • Google App Script🐑 (4)
      • ◎ HTML5+CSS3 (17)
        • HTML5📝 (8)
        • CSS3🎨 (9)
      • ──────────── (0)
      • ▣ Framework (67)
        • Spring🍃 (36)
        • Spring Boot🍀 (12)
        • Bootstrap💜 (3)
        • Selenium🌕 (6)
        • MyBatis🐣 (10)
      • ▣ Tools (47)
        • API🎯 (18)
        • Library🎲 (15)
        • JitPack🚀 (3)
        • Jenkins👨🏻 (7)
        • Thymeleaf🌿 (4)
      • ▣ Server (32)
        • Apache Tomcat🐱 (14)
        • Apache HTTP Server🛡️ (1)
        • Nginx🧶 (7)
        • OracleXE💿 (4)
        • VisualSVN📡 (4)
      • ▣ OS : 운영체제 (18)
        • cmd : 명령프롬프트💻 (10)
        • Linux🐧 (8)
      • ▣ SQL : Database (56)
        • Oracle SQL🏮 (26)
        • PL SQL💾 (9)
        • MySQL🐬 (6)
        • MariaDB🦦 (6)
        • H2 Database🔠 (3)
        • SQL 실전문제🐌 (6)
      • ────────── (0)
      • ◈ Human Project (86)
        • Mini : Library Service📚 (15)
        • 화면 설계 [HTML]🐯 (10)
        • 서버 프로그램 구현🦁 (15)
        • Team : 여수어때🛫 (19)
        • Custom : Student🏫 (9)
        • Custom : Board📖 (18)
      • ◈ Yermi Project (40)
        • 조사모아(Josa-moa)📬 (5)
        • Riddle-Game🧩 (6)
        • 맛있을 지도🍚 (2)
        • 어디 가! 박대리!🙋🏻‍♂️ (5)
        • 조크베어🐻‍❄️ (4)
        • Looks Like Thirty🦉 (2)
        • Toy Project💎 (12)
        • 오픈소스 파헤치기🪐 (4)
      • ◈ Refactoring (15)
        • Mini : Library Service📚 (8)
        • 서버 프로그램 구현🦁 (1)
        • Team : 여수어때🛫 (0)
        • 쿼리 튜닝일지🔧 (6)
      • ◈ Coding Test (89)
        • 백준(BOJ)👨🏻‍💻 (70)
        • 프로그래머스😎 (2)
        • 코드트리🌳 (7)
        • 알고리즘(Algorithm)🎡 (10)
      • ◈ Study (102)
        • 기초튼튼 개발지식🥔 (25)
        • HTTP 웹 지식💡 (4)
        • 클린코드(Clean Code)🩺 (1)
        • 디자인패턴(GoF)🥞 (12)
        • 다이어그램(Diagram)📈 (4)
        • 파이썬(Python)🐍 (16)
        • 에러노트(Error Note)🧱 (34)
        • 웹 보안(Web Security)🔐 (6)
      • ◈ 공부모임 (39)
        • 혼공학습단⏰ (18)
        • 코드트리 챌린지👊🏻 (2)
        • 개발도서 100독👟 (8)
        • 나는 리뷰어다🌾 (11)
      • ◈ 자격증 공부 (37)
        • 정보처리기사🔱 (16)
        • 정보처리산업기사🔅 (9)
        • 컴퓨터활용능력 1급📼 (12)
      • ─────────── (0)
      • ◐ 기타 (113)
        • 알아두면 좋은 팁(tip)✨ (46)
        • 개발자의 일상🎈 (44)
        • 개발도서 서평🔍 (10)
        • 개발관련 세미나🎤 (2)
        • 블로그 꾸미기🎀 (9)
        • 사도신경 프로젝트🎚️ (2)
  • 인기 글

  • 최근 댓글

  • 태그

    자바스크립트
    html
    꿀팁
    jsp
    Error Note
    코딩 테스트
    프로그래밍
    코딩
    Oracle
    백준 티어
    CSS
    Database
    백준
    spring
    일상
    javascript
    SQL
    BOJ
    Project
    Java
  • 250x250
  • hELLO· Designed By정상우.v4.10.3
예르미(yermi)
[Toy Project] 이번에는 웹 페이지 오목이다(2)🎲 [JavaScript로 오목 로직 구현하기]
상단으로

티스토리툴바