Skip to content

Commit

Permalink
fonts, finishing frame, emulator basics
Browse files Browse the repository at this point in the history
  • Loading branch information
EntityB committed May 12, 2017
1 parent 43c1ddd commit 570d6b0
Show file tree
Hide file tree
Showing 34 changed files with 834 additions and 162 deletions.
2 changes: 1 addition & 1 deletion config/webpack.dev.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ module.exports = {
entry: './src/index.js',

output: {
path: path.resolve(__dirname, '../www/gamee-tools'),
path: path.resolve(__dirname, '../www/gamee-emulator'),
filename: 'gamee-tools.js'
},
}
2 changes: 1 addition & 1 deletion config/webpack.prod.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ module.exports = {
entry: './src/index.js',

output: {
path: path.resolve(__dirname, '../www/gamee-tools'),
path: path.resolve(__dirname, '../www/gamee-emulator'),
filename: 'gamee-tools.js'
},

Expand Down
12 changes: 9 additions & 3 deletions frame.html
Original file line number Diff line number Diff line change
Expand Up @@ -6,11 +6,14 @@
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<!-- The above 3 meta tags *must* come first in the head; any other head content must come *after* these tags -->
<title>Bootstrap 101 Template</title>
<title>Gamee Emulator</title>

<!-- Bootstrap -->
<link href="bootstrap-3.3.7-dist/css/bootstrap.min.css" rel="stylesheet">

<!--opensans font-->
<link href="https://fonts.googleapis.com/css?family=Open+Sans:400,600" rel="stylesheet">

<!--custom styles-->
<link href="gamee-emulator/sticky-footer.css" rel="stylesheet">
<link href="gamee-emulator/style.css" rel="stylesheet">
Expand All @@ -29,7 +32,8 @@
<nav class="navbar navbar-default navbar-fixed-top">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand" href="index.html"><img src="img/gamee-developers-portal-logotype.svg" class="gamee-developers-portal-logotype"></a>
<a class="navbar-brand" href="index.html">
<img src="gamee-emulator/img/logo-dev.png" srcset="img/[email protected] 2x, img/[email protected] 3x" class="gamee-developers-portal-logotype">
</div>


Expand All @@ -40,14 +44,15 @@
</ul>
<ul class="nav navbar-nav align-right">
<li><a href="game-data-help.html">Game data help</a></li>
<li><a href="https://github.com/gameeapp/gamee-js/wiki">Gamee wiki</a></li>
<li><a href="https://github.com/gameeapp/gamee-js/wiki"><img src="gamee-emulator/img/github.ico" class="github-ico">Gamee wiki</a></li>
</ul>
</div>
</nav>

<!-- Begin page content -->
<div class="container page-content background-light col-md-8 col-md-offset-2 col-xs-12 col-xs-offset-0">


</div>

<footer class="footer">
Expand All @@ -61,6 +66,7 @@
<!-- Include all compiled plugins (below), or include individual files as needed -->
<script src="bootstrap-3.3.7-dist/js/bootstrap.min.js"></script>
<!-- gamee-tools -->
<script src="gamee-emulator/gamee-tools.js"></script>
</body>

</html>
237 changes: 237 additions & 0 deletions src/gameeWeb.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,237 @@
export var gameeWeb = (function () {

var hashCode = function (str) {
var hash = 0, i, chr;
if (str.length === 0) return hash;
for (i = 0; i < str.length; i++) {
chr = str.charCodeAt(i);
hash = ((hash << 5) - hash) + chr;
hash |= 0; // Convert to 32bit integer
}
return hash;
};

//select the iframe containing the message receiver remote script
var remoteframe;
var gameId;
var gameScoreEl;
var ghostScoreEl;
var ctrlWrapperEl = document.getElementById("controlls-wrapper");
var ctrl = ctrlWrapperEl.innerHTML;

function sendMessage() {

var method = document.getElementById("requestmethod").value;
var data = document.getElementById("requestdata").value;

// data = JSON.stringify(data);

postMessageToIframe({
request: {
method: method,
messageId: 0,
data: data
}
});
}

function postMessageToIframe(content) {
remoteframe.contentWindow.postMessage(content, "*");
}

function command(type) {
switch (type) {
case 'start':
postMessageToIframe({
request: {
method: type,
messageId: 0,
data: {
data: {}
}
}
});
break;
case 'startReplay':
postMessageToIframe({
request: {
method: 'start',
messageId: 0,
data: {
replay: true
}
}
});
break;
case 'startGhost':
postMessageToIframe({
request: {
method: 'start',
messageId: 0,
data: {
ghostMode: true
}
}
});
break;
default:
postMessageToIframe({
request: {
method: type,
messageId: 0
}
});
}
}

window.addEventListener('message', function (ev) {
var data;
try {
data = ev.data;
} catch (err) {
return;
}

if (data.request && typeof Array.isArray(data.request)) {
postMessageRequest(data.request);
} else if (data.response && typeof Array.isArray(data.response)) {
postMessageResponse(data.response);
}
});

var avatar = "";
function postMessageRequest(data) {
var id = data.messageId,
method = data.method,
rData = data.data;

switch (method) {
case 'init':
gameId = hashCode(remoteframe.src);
var responseData = {
saveState: null,
replayData: null,
sound: false
};
if (rData.capabilities) {
if (rData.capabilities.saveState) {
if (localStorage.getItem("saveState-" + gameId) !== null)
responseData.saveState = localStorage.getItem("saveState-" + gameId);
}
if (rData.capabilities.replay) {
if (localStorage.getItem("replayData-" + gameId) !== null) {
responseData.replayData = JSON.parse(localStorage.getItem("replayData-" + gameId));
prepareReplayButton();
}
}
if (rData.capabilities.ghostMode) {
if (localStorage.getItem("replayData-" + gameId) !== null) {
responseData.replayData = JSON.parse(localStorage.getItem("replayData-" + gameId));
prepareGhostButton();
}
}
}
response(id, responseData);
break;
case 'gameReady':
// response(id);
var startButton = document.createElement("button");
startButton.addEventListener("click", function () {
gameScoreEl.value = 0;
command('start');
});
startButton.innerHTML = "Start";
document.getElementById("controlls").appendChild(startButton);
break;
case 'updateScore':
var newScore = parseInt(rData.score);
var scoreEl = rData.ghostSign ? ghostScoreEl : gameScoreEl;
if (newScore > scoreEl.value)
scoreEl.value = newScore;
// response(id);
break;
case 'gameOver':
if (rData.replayData) {
localStorage.setItem("replayData-" + gameId, JSON.stringify(rData.replayData));
}
// response(id);
break;
case 'saveState':
localStorage.setItem("saveState-" + gameId, rData.state);
// response(id);
break;
case 'requestSocial':
var friends = [];
friends.push({ name: "Entita", avatar: avatar, highScore: 10000 });
friends.push({ name: "Lukas", avatar: "https://scontent.xx.fbcdn.net/v/t1.0-1/p720x720/10407458_10205512546521851_83732587093950795_n.jpg?oh\\u003d65577f4c957ab0055d09c2379f3eeeb2\\u0026amp;amp;amp;amp;amp;oe\\u003d595C02D2", highScore: 15000 });
friends.push({ name: "Mirek", avatar: "https://s3.amazonaws.com/gamee-users-devel/photo--494961467.png", highScore: 20000 });
var responseData = {
friends: friends
};
response(id, responseData);
break;
default:
throw "Unknown method call";
}
}

function postMessageResponse(data) {
// console.log("callback: " + data);
}

function response(id, data) {
var data = {
response: {
messageId: id,
data: data
}
};

postMessageToIframe(data);
}

function prepareReplayButton() {
var replayEl = document.createElement("button");
replayEl.innerHTML = "Replay";
replayEl.addEventListener("click", function () {
gameScoreEl.value = 0;
command('startReplay');
});

document.getElementById("controlls").appendChild(replayEl);
}

function prepareGhostButton() {
var ghostEl = document.createElement("button");
ghostEl.innerHTML = "Ghost mode";
ghostEl.addEventListener("click", function () {
gameScoreEl.value = 0;
command('startGhost');
});

ghostScoreEl = document.createElement("input");
ghostScoreEl.disabled = true;

var label = document.createElement("label");
label.innerHTML = "Ghost score";
document.getElementById("controlls").appendChild(ghostEl);
document.getElementById("controlls").appendChild(label);
document.getElementById("controlls").appendChild(ghostScoreEl);
}

function initalizeControlls() {
ctrlWrapperEl.innerHTML = "";
ctrlWrapperEl.innerHTML = ctrl;

gameScoreEl = document.getElementById("game-score");
}

return {
init: function (iframe) {
remoteframe = iframe;
initalizeControlls();
},
command: command,
sendMessage: sendMessage
}
})();
5 changes: 2 additions & 3 deletions src/index.js
Original file line number Diff line number Diff line change
@@ -1,3 +1,2 @@
var a = 50;
var b = 40;
var c = 30;
import {gameeWeb} from './gameeWeb.js';
import {tools} from './tools.js';
50 changes: 50 additions & 0 deletions src/tools.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
(function () {
var oldHash;
var pages = document.querySelectorAll(".main");

window.addEventListener("hashchange", linkRedirect, false);

function linkRedirect() {

pages.forEach(function (page) {
page.style.display = "none";
});

var pageToShowId = window.location.hash.slice(1) + "-page";
var pageToShow = document.getElementById(pageToShowId) || document.getElementById("dashboard-page");
pageToShow.style.display = "block";
}

linkRedirect();
})();

$('#iframe-url-sub').on('click', function () {
var url = $('#iframe-url').val();
setProjectPreview("Remote project", url);
window.location.hash = "#project";
});


export function setProjectPreview(projectName, url) {
prepareIframeForGamePreview(projectName, url);
}


export function prepareIframeForGamePreview(projectName, url) {
var link = "/projects/" + projectName;
if (url)
link = url;

var wrapper = document.getElementById("game-wrapper");
wrapper.innerHTML = "";

var iframe = document.createElement("iframe");

gameeWeb.init(iframe);

iframe.src = link;
iframe.frameBorder = 0;
iframe.width = 640;
iframe.height = 640;
wrapper.appendChild(iframe);
}
Empty file removed www/connect-phone-manual.html
Empty file.
Loading

0 comments on commit 570d6b0

Please sign in to comment.