사용자:Jinhoftyu/백괴던전: 두 판 사이의 차이

리버티게임, 모두가 만들어가는 자유로운 게임
편집 요약 없음
태그: 되돌려진 기여
편집 요약 없음
 
(같은 사용자의 중간 판 41개는 보이지 않습니다)
1번째 줄: 1번째 줄:
[https://libertyga.me/index.php?title=%EC%82%AC%EC%9A%A9%EC%9E%90:Jinhoftyu/%EB%B0%B1%EA%B4%B4%EB%8D%98%EC%A0%84.js&action=edit]
{{pluginX
{{pluginX
|문서=사용자:Jinhoftyu/백괴던전.js
|문서=사용자:Jinhoftyu/백괴던전.js
4번째 줄: 5번째 줄:
|제작자=Jinhoftyu
|제작자=Jinhoftyu
}}
}}
<!DOCTYPE html>
{{#css:
<head>
#map {
  <meta charset="UTF-8">
    background: black;
  <title>스타일 적용하기</title>
    color: white;
  <style>
    font-size: 16px;
/*구글 웹 폰트 적용*/
    font-family: monospace;
@import url(//fonts.googleapis.com/earlyaccess/jejumyeongjo.css);
    padding: 0.5em;
}
#stats {
    background: black;
    color: white;
    font-size: 16px;
    font-family: monospace;
    padding: 0.5em;
}


.jm-font{
#console {
font-family: 'Jeju Myeongjo', serif;/*웹 폰트 지정*/
    background: black;
color: orange;
    color: white;
}
    font-size: 16px;
  </style>
    font-family: monospace;
</head>
    padding: 0.5em;
<body>
}
  <h1>가나다라마바사</h1><br/>
}}
  <hr/>
<div id="console"></div>
  <p class="jm-font">제주-명조 웹 폰트를 적용한 글씨이다.</p>
<div id="map"></div>
  <p>브라우저 기본 글꼴 적용한 글씨이다.</p>
<div id="stats"></div>
</body>
</html>
<style>
@import url(//fonts.googleapis.com/earlyaccess/jejumyeongjo.css);
 
.jm-font{
font-family: 'Source Code Pro';
color: black;
}
</style>
<span id="text"></span>

2023년 10월 26일 (목) 00:09 기준 최신판

[1]

var mapX = 40;
var mapY = 10;
var base = new Array(mapY);
for (var i = 0; i < base.length; i++) {
    base[i] = new Array(mapX);
}
function mapGen() {
	for (var y = 0; y < mapY; y++) {
		for (var x = 0; x < mapX; x++) {
			if (y == 0 || y == mapY - 1 || x == 0 || x == mapX - 1) {
        		base[y][x] = "#";
    		} else if (x == 1 && y == 1) {
    	    	base[y][x] = "<";
    		} else if (x == mapX - 2 && y == mapY - 2) {
    	    	base[y][x] = ">";
    	    } else {
    	    	base[y][x] = ".";
        	}
		}
	}
}
var entity = [];
var item = [];
var log = "";
var console = document.getElementById("console");
function refLog() {
    var size = 0;
    for (var i = 0; i < log.length; i++) {
        if (log.charAt(i) == "<br />") {
            size++;
        }
    }
	if (size > 3) {
        log = log.substring(log.indexOf("<br />") + 1);
    }
	console.innerHTML = log;
	stats.innerHTML = temp2;
}
var map = document.getElementById("map");
var plx = 1;
var ply = 1;
function refreshMap() {
	var temp = "";
	for (var y = 0; y < mapY; y++) {
        for (var x = 0; x < mapX; x++) {
                var floor = base[y][x];
                var s = " ";
                if (floor != "\0") {
                    s = floor;
                }
                if (plx == x && ply == y) {
                    s = "@";
                }
                temp += s;
            }
            temp += "<br />";
        }
	map.innerHTML = temp;
}
var stats = document.getElementById("stats");
var name = "Jinhoftyu";
var role = "Wizard";
var time = 0;
var level = 1;
var xl = 1;
var hp = 15;
var maxhp = 15;
var pw = 10;
var maxpw = 10;
var temp2 = name + " the " + role + " t:" + time + "<br />Dlvl:" + level + " Lv:" + xl + " HP:" + hp + "/" + maxhp + " Pw:" + pw + "/" + maxpw;
stats.innerHTML = temp2;
document.addEventListener('keydown', function(event) {
    if (event.code === 'KeyD') {
    	move(1, 0);
    }
    if (event.code === 'KeyA') {
    	move(-1, 0);
    }
    if (event.code === 'KeyW') {
    	move(0, -1);
    }
    if (event.code === 'KeyS') {
    	move(0, 1);
    }
});

function move(dx, dy) {
	if (base[ply + dy][plx + dx] != '#') {
		plx += dx;
		ply += dy;
		var floor = base[ply][plx];
		if (floor != '.' && floor != '\0') {
    		log += "You are standing in " + floorDes(floor) + ".<br />";
    	}
		turn();
	}
}

function turn() {
	time++;
    refreshMap();
	refLog();
}

function floorDes(c) {
	var s;
	switch (c) {
		case "<":
			s = "staircase leading upward";
			break;
        case ">":
			s = "staircase leading downward";
			break;
        default:
        	s = "nothing";
    }
    return s;
}
                
mapGen();
refreshMap();
refLog();