To embed a Sozi presentation in a web page, you can use an <iframe>
element like this:
<iframe src="my-presentation.sozi.html">
My Sozi presentation should play here.
</iframe>
The width and height of the viewport for the embedded document can be set either as attributes
of the <iframe>
element, or using CSS.
An example is shown below.
Read more about the <iframe>
element.
Giving the keyboard focus to the Sozi presentation
When loading an HTML page, the browser gives the keyboard focus to the first element
that can accept it (hyperlink, form element, etc).
For this reason, in many cases, the embedded Sozi presentation will not respond to keyboard events
immediately on load.
One solution is to repeatedly hit the TAB
key
until the <iframe>
that displays your presentation receives focus.
You can also add the following script to your HTML document to automatically focus the
<iframe>
containing your presentation (assuming it is the first <iframe>
element in the page).
<script>
window.addEventListener("load", function () {
document.querySelector("iframe").focus();
}, false);
</script>
Controlling the presentation from the main HTML page
In the following example, we add two buttons to the main HTML page to
move to the previous or next frame.
Between the buttons, a <span>
element will show the title of the current frame.
Press these buttons to move to the previous/next frame:
<input id="btn-prev" type="button" value="←" title="Move to the previous frame">
<span id="frame-title">Loading…</span>
<input id="btn-next" type="button" value="→" title="Move to the next frame">
<iframe src="my-presentation.sozi.html">
My Sozi presentation should play here.
</iframe>
<script>
window.addEventListener("load", function () {
var frame = document.querySelector("iframe");
var btnPrev = document.getElementById("btn-prev");
var btnNext = document.getElementById("btn-next");
var spanTitle = document.getElementById("frame-title");
var player = frame.contentWindow.sozi.player;
spanTitle.innerHTML = player.currentFrame.title;
btnPrev.addEventListener("click", function () {
player.moveToPrevious();
}, false);
btnNext.addEventListener("click", function () {
player.moveToNext();
}, false);
player.addListener("frameChange", function () {
spanTitle.innerHTML = player.currentFrame.title;
});
}, false);
</script>
Here is an overview of the result:
Press these buttons to move to the previous/next frame: Loading…