-
Notifications
You must be signed in to change notification settings - Fork 3
/
scalable.html
168 lines (129 loc) · 5.55 KB
/
scalable.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
<!DOCTYPE HTML>
<html>
<!--
pgn4web javascript chessboard
copyright (C) 2009-2014 Paolo Casaschi
see README file and http://pgn4web.casaschi.net
for credits, license and more details
-->
<head>
<title>Gelfand Grisichuk 2011 - needs an HTML5 browser with SVG IMG support</title>
<!-- use viewport settings when body.onresize adapts the chessboard to the available space -->
<meta name="viewport" content="initial-scale=1, maximum-scale=1">
<link rel="icon" sizes="16x16" href="pawn.ico" />
<style type="text/css">
html, body {
margin:0px;
padding:0px;
}
body {
background: #F4F4F4;
}
.boardTable {
border-style: solid;
border-color: transparent;
}
.whiteSquare, .highlightWhiteSquare {
background-color: #FFCE9E;
}
.blackSquare, .highlightBlackSquare {
background-color: #D18B47;
}
</style>
<style id="dynamicStyle" type="text/css"></style>
<script type="text/javascript">
"use strict";
var squareSize;
function myOnResize() {
var boardObject = document.getElementById("GameBoard");
var squareSize = Math.floor(Math.min(window.innerWidth, window.innerHeight) / 9);
if (squareSize > 0) {
var pieceSize = Math.floor(squareSize * (pieceFont == "svgchess" ? 0.9 : 0.8));
var boardBorder = Math.ceil(squareSize / 20);
var shadowBorder = Math.floor(squareSize / 2);
var sheet = document.styleSheets[1];
var oldRules = sheet.cssRules.lenght;
sheet.insertRule(".boardTable { border-width: " + boardBorder + "px; border-radius: " + boardBorder + "px; box-shadow: 0px 0px " + shadowBorder + "px #734C27; } ", sheet.cssRules.length);
sheet.insertRule(".pieceImage { width:" + pieceSize + "px; height:" + pieceSize + "px; } ", sheet.cssRules.length);
sheet.insertRule(".whiteSquare, .blackSquare, .highlightWhiteSquare, .highlightBlackSquare { width:" + squareSize + "px; height:" + squareSize + "px; } ", sheet.cssRules.length);
for (var ii = 0; ii < oldRules; ii++) { sheet.deleteRule(0); }
boardObject.style.paddingTop = (window.innerHeight - 8 * squareSize - 2 * boardBorder) / 2 + "px";
boardObject.style.paddingBottom = (window.innerHeight - 8 * squareSize - 2 * boardBorder) / 2 + "px";
boardObject.style.paddingLeft = (window.innerWidth - 8 * squareSize - 2 * boardBorder) / 2 + "px";
boardObject.style.paddingRight = (window.innerWidth - 8 * squareSize - 2 * boardBorder) / 2 + "px";
var theObj = document.getElementById("boardTable");
if (theObj) {
theObj.style.height = (squareSize * 8 + boardBorder * 2) + "px";
theObj.style.width = (squareSize * 8 + boardBorder * 2) + "px";
}
}
}
</script>
<script src="pgn4web.js" type="text/javascript"></script>
<script type="text/javascript">
"use strict";
var pieceFont = "random";
var thisRegExp = /(&|\?)(pieceFont|pf)=([^&]*)(&|$)/i;
if (window.location.search.match(thisRegExp) !== null) {
pieceFont = unescape(window.location.search.match(thisRegExp)[3]);
}
if (pieceFont == "i") { pieceFont = "igorsvg"; }
if (pieceFont == "s") { pieceFont = "svgchess"; }
if (pieceFont == "t") { pieceFont = "tilesvg"; }
if ((pieceFont != "igorsvg") && (pieceFont != "svgchess") && (pieceFont != "tilesvg")) { pieceFont = "random"; }
if ((pieceFont == "random") || (pieceFont == "r")) {
pieceFont = ["igorsvg", "svgchess", "tilesvg"][Math.floor(3 * Math.random())];
}
SetImagePath("images/" + pieceFont);
SetImageType("svg");
SetHighlightOption(true);
SetAutoplayDelay(2000); // milliseconds
SetAutostartAutoplay(true);
SetAutoplayNextGame(true);
SetShortcutKeysEnabled(false);
function customFunctionOnPgnGameLoad() { myOnResize(); }
function customDebugInfo() { return "squareSize=" + squareSize; }
// redefine FlipBoard() to include myOnResize()
window['defaultFlipBoard'] = window['FlipBoard'];
window['FlipBoard'] = function() { defaultFlipBoard(); myOnResize(); };
</script>
</head>
<body onResize="myOnResize();">
<!-- paste your PGN below and make sure you dont specify an external source with SetPgnUrl() -->
<form style="display: none;"><textarea style="display: none;" id="pgnText">
[Event "WCh Candidates"]
[Site "Kazan RUS"]
[Date "2011.05.25"]
[Round "3.6"]
[White "Gelfand, Boris"]
[Black "Grischuk, Alexander"]
[Result "1-0"]
1. d4 Nf6 2. c4 g6 3. Nf3 Bg7 4. g3 d5 5. cxd5 Nxd5 6. Bg2 Nb6 7. Nc3 Nc6 8. e3
O-O 9. O-O Re8 10. Re1 a5 11. Qe2 Bg4 12. h3 Be6 13. b3 a4 14. Rb1 axb3 15. axb3
Qc8 16. Kh2 Ra5 17. Rd1 Rh5 18. Nh4 Bf6 19. f4 Rd8 20. Qf2 Bxh4 21. gxh4 Nd5 22.
Nxd5 Rhxd5 23. Bb2 Rb5 24. Qe2 Rh5 25. e4 Bxb3 26. Rdc1 Na5 27. d5 b6 28. Be5 c5
29. dxc6 f6 30. Ba1 Rc5 31. Rxc5 bxc5 32. Qb5 Qc7 33. Rxb3 Nxc6 34. e5 Nd4 35.
Qc4+ 1-0
</textarea></form>
<!-- paste your PGN above and make sure you dont specify an external source with SetPgnUrl() -->
<div id="GameBoard"></div>
<script type="text/javascript">
"use strict";
window.onerror = function(msg, url, linenumber) {
document.body.innerHTML = "<p style='font-family: sans-serif; text-align: center;'><br>this web browser<br>is not supported</p>";
document.body.innerHTML += "<p style='font-family: sans-serif; text-align: left;'><br><br>message: " + msg + "<br><br>url: " + url + "<br><br>line: " + linenumber + "<br><br>browser: " + navigator.userAgent + "</p>";
};
function checkSVGSupport() {
var img = document.createElement("img");
img.onerror = function() { throw("SVG browser support required for the IMG HTML tag"); };
img.onload = function() { };
img.setAttribute("src","%3D");
}
function pgn4web_onload(e) {
checkSVGSupport();
myOnResize();
start_pgn4web();
}
</script>
</body>
</html>