@bitsy/hecks
Version:
a collection of re-usable scripts for bitsy game maker
72 lines (66 loc) • 1.87 kB
JavaScript
/**
@summary twine-bitsy-comms SugarCube v2 Macro
@license MIT
@version 1.0.0
@author Sean S. LeBlanc
@description
example: <<bitsy>>./my bitsy.html<</bitsy>>
the bitsy game will render as an iframe with the class "bitsy"
inside of the passage that includes it;
you can use this to customize its CSS
(e.g. `border: none;`, `image-rendering: pixelated;`)
*/
Macro.add('bitsy', {
tags: null,
handler: function () {
// setup iframe
var iframe = document.createElement('iframe');
iframe.width = 512;
iframe.height = 512;
iframe.src = this.payload[0].contents;
iframe.className = 'bitsy';
// setup listeners
function handleBitsyMessage(event) {
var type = event.data.type;
var data = event.data.data;
switch (type) {
case 'start':
iframe.contentWindow.postMessage({
type: 'variables',
data: State.variables,
}, '*');
break;
case 'play':
Engine.play(data);
break;
case 'back':
Engine.backward();
break;
case 'variable':
State.variables[data.name] = data.value;
break;
case 'eval':
console.warn('The "eval" command is commented out by default since it\'s easy to abuse. Uncomment it in your javascript if you want to use it.');
// eval(data);
break;
default:
console.warn('Unhandled message from Bitsy:', type, data);
break;
}
}
window.addEventListener("message", handleBitsyMessage, false);
$(document).one(':passagestart', function () {
window.removeEventListener("message", handleBitsyMessage, false);
});
// make sure the iframe keeps focus
// so that bitsy can capture key events
setTimeout(function () {
iframe.focus();
iframe.onblur = function () {
iframe.focus();
};
});
// output
this.output.appendChild(iframe);
}
});