Eine Digitaluhr die etwas animiert ist beim Zahlenwechsel
Code
<!doctype html>
<html>
<head>
<title>Analogue/Digital Clock</title>
<script>
new Image().src = '';//;
new Image().src = '';//'./graphics/dot.png';
new Image().src = '';//;
</script>
</head>
<body onload="go()">
<canvas id="canvas1" height="110" width="350">
Sorry, your browser does not support the element so you cannot view this demo.
</canvas>
<script>
function go(){
var OFFSET_X = 20;
var OFFSET_Y = 15;
var imgLine = new Image();
imgLine.src = '';//;
var imgBgLine = new Image();
imgBgLine.src = '';//'./graphics/bgline.png';
var imgDot = new Image();
imgDot.src = '';//;
var LINE_WIDTH = imgLine.height;
var LINE_LENGTH = imgLine.width;
var DOT_WIDTH = imgDot.width;
var GAP = 2 * DOT_WIDTH;
var TICKS_PER_SEC = 30;
var DIGIT_X_1 = OFFSET_X;
var DIGIT_X_2 = DIGIT_X_1 + (2 * LINE_WIDTH + LINE_LENGTH + GAP);
var DIGIT_X_3 = DIGIT_X_2 + (2 * LINE_WIDTH + LINE_LENGTH + 2 * GAP + DOT_WIDTH);
var DIGIT_X_4 = DIGIT_X_3 + (2 * LINE_WIDTH + LINE_LENGTH + GAP);
var DIGIT_X_5 = DIGIT_X_4 + (2 * LINE_WIDTH + LINE_LENGTH + 2 * GAP + DOT_WIDTH);
var DIGIT_X_6 = DIGIT_X_5 + (2 * LINE_WIDTH + LINE_LENGTH + GAP);
var DOT_X_1 = OFFSET_X + (3 * LINE_WIDTH + 2 * LINE_LENGTH + 2 * GAP);
var DOT_X_2 = DOT_X_1 + 2 * GAP + (3 * LINE_WIDTH + 2 * LINE_LENGTH + 2 * GAP);
var DOT_Y_1 = OFFSET_Y + (2 * LINE_LENGTH + 3 * LINE_WIDTH) / 4;
var DOT_Y_2 = OFFSET_Y + (2 * LINE_LENGTH + 3 * LINE_WIDTH) * 3 / 4 - DOT_WIDTH;
var X1 = 0;
var X2 = LINE_WIDTH + LINE_LENGTH;
var Y1 = 0;
var Y2 = LINE_WIDTH + LINE_LENGTH;
var Y3 = 2 * LINE_WIDTH + 2 * LINE_LENGTH;
var canvas = document.getElementById('canvas1');
var ctx = canvas.getContext('2d');
var WIDTH = Number(canvas.width);
var HEIGHT = Number(canvas.height);
function forEach(arr, fnDoThis){
var i=0, l=arr.length;
for(i=0; i<l; i++){
if (false===fnDoThis(i, arr[i])){
return;
}
}
}
function makeLine(x, y, degrees, scale, fnOnTickDoThis, imgObj){
var line = {};
var img = imgObj ? imgObj : imgLine;
var ox = x, oy = y, oDegrees = degrees, oScale = scale;
line.setPos = function(px,py){
x = px;
y = py;
}
line.move = function(dx, dy){
line.setPos(x + dx, y + dy);
};
line.setAngle = function(pDegrees){
degrees = pDegrees;
};
line.getAngle = function(){
return degrees;
};
line.setScale = function(pScale){
scale = pScale;
};
line.tick = function(tickValue){
fnOnTickDoThis && fnOnTickDoThis(line, tickValue);
};
line.draw = function(xOffset, yOffset){
ctx.save();
var radians = degrees * Math.PI / 180;
ctx.translate(x + xOffset, y + yOffset);
ctx.translate(-LINE_WIDTH/2, LINE_WIDTH/2);
ctx.rotate(radians);
ctx.translate(LINE_WIDTH/2, -LINE_WIDTH/2);
ctx.drawImage(img, 0, 0, LINE_LENGTH * scale, LINE_WIDTH);
ctx.restore();
};
return line;
}
function makeDigit(x, y){
var digit = {};
var lines = [];
digit.addLine = function(line){
lines.push(line);
};
digit.clearLines = function(){
lines = [];
};
digit.tick = function(tickValue){
forEach(lines, function(i,line){
line && line.tick(tickValue);
});
};
digit.draw = function(){
forEach(lines, function(i,line){
line && line.draw(x, y);
});
};
return digit;
}
var digitHour1 = makeDigit(DIGIT_X_1, OFFSET_Y);
var digitHour2 = makeDigit(DIGIT_X_2, OFFSET_Y);
var digitMin1 = makeDigit(DIGIT_X_3, OFFSET_Y);
var digitMin2 = makeDigit(DIGIT_X_4, OFFSET_Y);
var digitSec1 = makeDigit(DIGIT_X_5, OFFSET_Y);
var digitSec2 = makeDigit(DIGIT_X_6, OFFSET_Y);
var digits = [digitHour1, digitHour2, digitMin1, digitMin2, digitSec1, digitSec2];
var prevTime = getTimeParts();
var tick = 0;
setInterval(function(){
var tickValue = (tick % TICKS_PER_SEC) / TICKS_PER_SEC;
ctx.clearRect(0, 0,WIDTH,HEIGHT);
drawDots();
drawBgLines();
if (tickValue === 0){
var newTime = getTimeParts();
forEach(digits, function(i, digit){
var from = prevTime[i];
var to = newTime[i];
digit.clearLines();
var newLineArgLists = transforms[from][to];
if (!newLineArgLists){
newLineArgLists = transforms[to][to];
}
forEach(pickOne(newLineArgLists), function(i,newLineArgList){
digit.addLine(makeLine.apply(null, newLineArgList));
});
});
prevTime = newTime;
} else {
forEach(digits, function(i,digit){
digit.tick(tickValue);
});
}
forEach(digits, function(i,digit){
digit.draw();
});
tick++;
}, 1000 / TICKS_PER_SEC);
function drawBgLines(){
function drawBgDigit(xOffset){
makeLine(xOffset + X1, OFFSET_Y + Y1, 0, 1, null, imgBgLine).draw(0,0);
makeLine(xOffset + X1, OFFSET_Y + Y1, 90, 1, null, imgBgLine).draw(0,0);
makeLine(xOffset + X2, OFFSET_Y + Y1, 90, 1, null, imgBgLine).draw(0,0);
makeLine(xOffset + X1, OFFSET_Y + Y2, 0, 1, null, imgBgLine).draw(0,0);
makeLine(xOffset + X1, OFFSET_Y + Y2, 90, 1, null, imgBgLine).draw(0,0);
makeLine(xOffset + X2, OFFSET_Y + Y2, 90, 1, null, imgBgLine).draw(0,0);
makeLine(xOffset + X1, OFFSET_Y + Y3, 0, 1, null, imgBgLine).draw(0,0);
}
drawBgDigit(DIGIT_X_1);
drawBgDigit(DIGIT_X_2);
drawBgDigit(DIGIT_X_3);
drawBgDigit(DIGIT_X_4);
drawBgDigit(DIGIT_X_5);
drawBgDigit(DIGIT_X_6);
}
function drawDots(){
function drawDot(x, y){
ctx.save();
ctx.translate(x, y);
ctx.drawImage(imgDot, 0, 0, DOT_WIDTH, DOT_WIDTH);
ctx.restore();
}
drawDot(DOT_X_1, DOT_Y_1);
drawDot(DOT_X_1, DOT_Y_2);
drawDot(DOT_X_2, DOT_Y_1);
drawDot(DOT_X_2, DOT_Y_2);
}
function pickOne(arr){
var totalWeight = 0;
forEach(arr, function(i,item){
totalWeight += item.weight;
});
var i = Math.random() * totalWeight;
var weightSoFar = 0;
var selectedMoves;
forEach(arr, function(j,item){
weightSoFar += item.weight;
if (weightSoFar > i){
selectedMoves = item.lines;
return false;
}
});
return selectedMoves;
}
function getTimeParts(){
var parts = [];
var now = new Date();
var hours = now.getHours();
parts.push(Math.floor(hours / 10));
parts.push(hours % 10);
var mins = now.getMinutes();
parts.push(Math.floor(mins / 10));
parts.push(mins % 10);
var secs = now.getSeconds();
parts.push(Math.floor(secs / 10));
parts.push(secs % 10);
return parts;
}
var fnMoveDown = function(line){
line.move(0, (LINE_LENGTH + LINE_WIDTH) / TICKS_PER_SEC);
};
var fnMoveUp = function(line){
line.move(0, -(LINE_LENGTH + LINE_WIDTH) / TICKS_PER_SEC);
};
var fnMoveLeft = function(line){
line.move(-(LINE_LENGTH + LINE_WIDTH) / TICKS_PER_SEC, 0);
};
var fnMoveRight = function(line){
line.move((LINE_LENGTH + LINE_WIDTH) / TICKS_PER_SEC, 0);
};
var fnShrinkLeft = function(line, tickValue){
line.setScale(1 - tickValue);
};
var fnShrinkRight = function(line, tickValue){
fnMoveRight(line);
line.setScale(1 - tickValue);
};
var fnShrinkDown = function(line, tickValue){
fnMoveDown(line);
line.setScale(1 - tickValue);
};
var fnGrowLeft = function(line, tickValue){
fnMoveLeft(line);
line.setScale(tickValue);
};
var fnGrowRight = function(line, tickValue){
line.setScale(tickValue);
};
var fnRotateClockwise = function(line, tickValue){
var angle = line.getAngle();
line.setAngle(angle + (90 / TICKS_PER_SEC));
};
var fnRotateClockwise2 = function(line, tickValue){
var angle = line.getAngle();
line.setAngle(angle + (180 / TICKS_PER_SEC));
};
var fnRotateAntiClockwise = function(line, tickValue){
var angle = line.getAngle();
line.setAngle(angle - (90 / TICKS_PER_SEC));
};
var fnRotateAntiClockwise2 = function(line, tickValue){
var angle = line.getAngle();
line.setAngle(angle - (180 / TICKS_PER_SEC));
};
var transforms = {
'0' : {
'0' : [
{'weight' : 27, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
},{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, fnRotateClockwise],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X2, Y1, 90, 1, fnRotateClockwise],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X2, Y3,180, 1, fnRotateClockwise],
[X1, Y3,270, 1, fnRotateClockwise]
]
},{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y2,270, 1, fnRotateClockwise2],
[X1, Y2, 90, 1, fnMoveUp],
[X2, Y1, 90, 1, fnMoveDown],
[X2, Y2, 90, 1, fnRotateClockwise2],
[X1, Y3, 0, 1, null]
]
},{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, fnMoveDown],
[X2, Y1, 90, 1, fnMoveLeft],
[X1, Y2, 90, 1, fnMoveRight],
[X2, Y2, 90, 1, fnMoveUp],
[X1, Y3, 0, 1, null]
]
}
],
'1' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, fnShrinkRight],
[X1, Y1, 90, 1, fnMoveRight],
[X2, Y1, 90, 1, null],
[X1, Y2, 90, 1, fnMoveRight],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, fnShrinkRight]
]
}, {'weight' : 1, 'lines' : [
[X2, Y1,180, 1, fnRotateAntiClockwise],
[X1, Y2,270, 1, fnShrinkLeft],
[X1, Y2, 90, 1, fnShrinkLeft],
[X2, Y3,180, 1, fnRotateClockwise],
[X2, Y1, 90, 1, null],
[X2, Y2, 90, 1, null]
]
}
]
},
'1' : {
'1' : [
{'weight' : 18, 'lines' : [
[X2, Y1, 90, 1, null],
[X2, Y2, 90, 1, null]
]
},{'weight' : 1, 'lines' : [
[X2, Y2,270, 1, fnRotateAntiClockwise2],
[X2, Y2, 90, 1, fnMoveUp],
]
},{'weight' : 1, 'lines' : [
[X2, Y2, 90, 1, fnRotateClockwise2],
[X2, Y1, 90, 1, fnMoveDown]
]
}
],
'2' : [
{'weight' : 1, 'lines' : [
[X2, Y1, 0, 0, fnGrowLeft],
[X2, Y1, 90, 1, null],
[X2, Y2, 0, 0, fnGrowLeft],
[X2, Y2, 90, 1, fnMoveLeft],
[X2, Y3, 0, 0, fnGrowLeft]
]
},{'weight' : 1, 'lines' : [
[X2, Y1, 90, 1, fnRotateClockwise],
[X2, Y1, 90, 1, null],
[X2, Y2, 90, 1, fnRotateClockwise],
[X2, Y2, 90, 1, fnMoveLeft],
[X2, Y3,270, 1, fnRotateAntiClockwise]
]
}
]
},
'2' : {
'0' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, fnRotateAntiClockwise],
[X2, Y2,180, 1, fnRotateAntiClockwise],
[X1, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}
],
'2' : [
{'weight' : 9, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
},{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, fnShrinkLeft],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, fnShrinkLeft],
[X1, Y2, 0, 1, fnRotateClockwise],
[X2, Y2,180, 1, fnRotateClockwise],
[X1, Y3, 0, 1, null]
]
}
],
'3' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, fnMoveRight],
[X1, Y3, 0, 1, null]
]
}
]
},
'3' : {
'3' : [
{'weight' : 18, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X2, Y2, 90, 1, null],
[X2, Y2,180, 1, fnRotateClockwise],
[X2, Y2, 90, 1, fnRotateClockwise],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X2, Y2, 90, 1, null],
[X2, Y2,180, 1, fnRotateAntiClockwise],
[X2, Y2,270, 1, fnRotateAntiClockwise],
[X1, Y3, 0, 1, null]
]
}
],
'4' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, fnRotateClockwise],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, fnShrinkRight]
]
}
]
},
'4' : {
'4' : [
{'weight' : 9, 'lines' : [
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, fnMoveDown],
[X2, Y2,180, 1, fnRotateClockwise],
[X2, Y2, 90, 1, fnRotateClockwise]
]
}
],
'5' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, fnRotateClockwise],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X2, Y3, 0, 0, fnGrowLeft]
]
}
]
},
'5' : {
'0' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y2,180, 1, fnRotateClockwise],
[X1, Y2, 0, 1, fnRotateClockwise],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}
],
'5' : [
{'weight' : 9, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 0, 1, fnRotateClockwise],
[X1, Y1, 90, 1, fnShrinkLeft],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, fnShrinkLeft],
[X2, Y2,180, 1, fnRotateAntiClockwise],
[X1, Y3, 0, 1, null]
]
}
],
'6' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y2, 0, 1, fnRotateClockwise],
[X2, Y2, 90, 0, null],
[X1, Y3, 0, 1, null]
]
}
]
},
'6' : {
'6' : [
{'weight' : 27, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, fnRotateClockwise],
[X1, Y1, 0, 0, fnGrowRight],
[X1, Y1, 90, 1, fnShrinkLeft],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X1, Y2, 0, 1, fnRotateClockwise],
[X1, Y3,270, 1, fnRotateClockwise],
[X2, Y3,180, 1, fnRotateClockwise],
[X2, Y2, 90, 1, fnRotateClockwise]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X1, Y2, 90, 1, fnRotateAntiClockwise],
[X1, Y3, 0, 1, fnRotateAntiClockwise],
[X2, Y3,270, 1, fnRotateAntiClockwise],
[X2, Y2,180, 1, fnRotateAntiClockwise]
]
}
],
'7' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, fnMoveRight],
[X1, Y2, 0, 1, fnShrinkRight],
[X1, Y2, 90, 1, fnMoveRight],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, fnShrinkRight]
]
}
]
},
'7' : {
'7' : [
{'weight' : 9, 'lines' : [
[X1, Y1, 0, 1, null],
[X2, Y1, 90, 1, null],
[X2, Y2, 90, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X2, Y1,180, 0, fnGrowRight],
[X2, Y1,180, 1, fnRotateAntiClockwise],
[X2, Y1, 90, 1, fnMoveDown],
[X2, Y2, 90, 1, fnShrinkDown]
]
}
],
'8' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 0, 1, fnRotateClockwise],
[X2, Y1, 90, 1, null],
[X2, Y2, 0, 0, fnGrowLeft],
[X2, Y2, 90, 1, fnMoveLeft],
[X2, Y2, 90, 1, null],
[X2, Y3, 0, 0, fnGrowLeft]
]
}
]
},
'8' : {
'8' : [
{'weight' : 18, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, fnMoveDown],
[X2, Y1, 90, 1, null],
[X2, Y1, 90, 1, fnMoveLeft],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 0, 1, fnRotateClockwise],
[X1, Y1, 90, 1, fnShrinkLeft],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, fnShrinkLeft],
[X1, Y2, 90, 1, null],
[X2, Y2, 90, 1, null],
[X2, Y2, 90, 1, fnRotateClockwise],
[X1, Y3, 0, 1, null]
]
}
],
'9' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, fnMoveRight],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X1, Y2, 90, 1, fnRotateAntiClockwise],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}
]
},
'9' : {
'9' : [
{'weight' : 18, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y2,270, 1, fnRotateAntiClockwise],
[X2, Y2,270, 0, fnGrowRight],
[X2, Y2,180, 1, fnRotateAntiClockwise],
[X2, Y2, 90, 1, fnShrinkLeft],
[X1, Y3, 0, 1, null]
]
}, {'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, fnShrinkLeft],
[X1, Y1, 90, 1, fnShrinkLeft],
[X2, Y1, 90, 1, null],
[X2, Y1, 90, 1, fnRotateClockwise],
[X1, Y2, 0, 1, null],
[X1, Y2, 0, 1, fnRotateAntiClockwise],
[X1, Y2, 0, 1, null],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}
],
'0' : [
{'weight' : 1, 'lines' : [
[X1, Y1, 0, 1, null],
[X1, Y1, 90, 1, null],
[X2, Y1, 90, 1, null],
[X1, Y2, 0, 1, fnRotateClockwise],
[X2, Y2, 90, 1, null],
[X1, Y3, 0, 1, null]
]
}
]
}
};
}
</script>
</body>
</html>