added simple click controls, click left side to go back, right side to go forward
This commit is contained in:
parent
21d8869ad3
commit
1acc278b78
2 changed files with 77 additions and 21 deletions
80
scripts.js
80
scripts.js
|
@ -3,8 +3,6 @@ var book;
|
||||||
|
|
||||||
window.onload = function() {
|
window.onload = function() {
|
||||||
|
|
||||||
book = new ComicBook();
|
|
||||||
|
|
||||||
var srcs = {
|
var srcs = {
|
||||||
1: "http://dev.justforcomics.com/get/image/?f=comics/extracted/oni_whiteout_melt_1/00.jpg",
|
1: "http://dev.justforcomics.com/get/image/?f=comics/extracted/oni_whiteout_melt_1/00.jpg",
|
||||||
2: "http://dev.justforcomics.com/get/image/?f=comics/extracted/oni_whiteout_melt_1/01.jpg",
|
2: "http://dev.justforcomics.com/get/image/?f=comics/extracted/oni_whiteout_melt_1/01.jpg",
|
||||||
|
@ -16,6 +14,8 @@ window.onload = function() {
|
||||||
8: "http://dev.justforcomics.com/get/image/?f=comics/extracted/oni_whiteout_melt_1/07.jpg"
|
8: "http://dev.justforcomics.com/get/image/?f=comics/extracted/oni_whiteout_melt_1/07.jpg"
|
||||||
};
|
};
|
||||||
|
|
||||||
|
book = new ComicBook();
|
||||||
|
|
||||||
book.draw("comic", srcs);
|
book.draw("comic", srcs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -28,10 +28,12 @@ function ComicBook() {
|
||||||
|
|
||||||
var buffer = 4;
|
var buffer = 4;
|
||||||
var pointer = 0;
|
var pointer = 0;
|
||||||
|
var loaded = 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* @param {String} id The canvas ID to draw the comic on.
|
* @param {String} id The canvas ID to draw the comic on.
|
||||||
* @param {Array} srcs An array of all the comic page srcs, in order
|
* @param {Object} srcs An array of all the comic page srcs, in order
|
||||||
|
* @see #preload
|
||||||
*/
|
*/
|
||||||
this.draw = function(id, srcs) {
|
this.draw = function(id, srcs) {
|
||||||
|
|
||||||
|
@ -39,13 +41,21 @@ function ComicBook() {
|
||||||
canvas = document.getElementById(id);
|
canvas = document.getElementById(id);
|
||||||
context = canvas.getContext("2d");
|
context = canvas.getContext("2d");
|
||||||
|
|
||||||
|
// preload images
|
||||||
preload(srcs);
|
preload(srcs);
|
||||||
|
|
||||||
|
// add page controls
|
||||||
|
canvas.addEventListener("click", comicOnClick, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Preload all images, draw the page only after a given number have been loaded.
|
||||||
|
*
|
||||||
|
* @param srcs {Object} srcs
|
||||||
|
* @see #drawPage
|
||||||
|
*/
|
||||||
function preload(srcs) {
|
function preload(srcs) {
|
||||||
|
|
||||||
var loaded = 0;
|
|
||||||
|
|
||||||
if (srcs.length < buffer) buffer = srcs.length; // don't get stuck if the buffer level is higher than the number of pages
|
if (srcs.length < buffer) buffer = srcs.length; // don't get stuck if the buffer level is higher than the number of pages
|
||||||
|
|
||||||
for (i in srcs) {
|
for (i in srcs) {
|
||||||
|
@ -62,13 +72,13 @@ function ComicBook() {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* Draw the current page in the canvas
|
||||||
|
*
|
||||||
* TODO: break this down into drawSinglePage() & drawDoublePage()
|
* TODO: break this down into drawSinglePage() & drawDoublePage()
|
||||||
* TODO: if the current browser doesn't have canvas support, use img tags
|
* TODO: if the current browser doesn't have canvas support, use img tags
|
||||||
*/
|
*/
|
||||||
function drawPage() {
|
function drawPage() {
|
||||||
|
|
||||||
console.log(pointer, pages);
|
|
||||||
|
|
||||||
var page = pages[pointer];
|
var page = pages[pointer];
|
||||||
|
|
||||||
canvas.width = page.width;
|
canvas.width = page.width;
|
||||||
|
@ -76,13 +86,57 @@ function ComicBook() {
|
||||||
context.drawImage(page, 0, 0);
|
context.drawImage(page, 0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.drawNextPage = function() {
|
/**
|
||||||
if (pointer < pointer + 1) pointer++;
|
* Increment the counter and draw the page in the canvas
|
||||||
drawPage();
|
*
|
||||||
|
* @see #drawPage
|
||||||
|
*/
|
||||||
|
function drawNextPage() {
|
||||||
|
if (pointer < pointer + 1) {
|
||||||
|
pointer++;
|
||||||
|
drawPage();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
this.drawPrevPage = function() {
|
|
||||||
if (pointer > 0) pointer--;
|
/**
|
||||||
drawPage();
|
* Decrement the counter and draw the page in the canvas
|
||||||
|
*
|
||||||
|
* @see #drawPage
|
||||||
|
*/
|
||||||
|
function drawPrevPage() {
|
||||||
|
if (pointer > 0) {
|
||||||
|
pointer--;
|
||||||
|
drawPage();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function comicOnClick(e) {
|
||||||
|
switch (getCursorPosition(e)) {
|
||||||
|
case "left": drawPrevPage(); break;
|
||||||
|
case "right": drawNextPage(); break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Figure out the cursor position relative to the canvas.
|
||||||
|
*
|
||||||
|
* Thanks to: Mark Pilgrim & http://diveintohtml5.org/canvas.html
|
||||||
|
*/
|
||||||
|
function getCursorPosition(e) {
|
||||||
|
|
||||||
|
var x;
|
||||||
|
|
||||||
|
// check if page relative positions exist
|
||||||
|
if (e.pageX) x = e.pageX;
|
||||||
|
|
||||||
|
// if not figure them out
|
||||||
|
else x = e.clientX + document.body.scrollLeft + document.documentElement.scrollLeft;
|
||||||
|
|
||||||
|
// make the position relative to the canvas
|
||||||
|
x -= canvas.offsetLeft;
|
||||||
|
|
||||||
|
// check if the user clicked on the left or right side
|
||||||
|
return (x <= canvas.width / 2) ? 'left' : 'right';
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -1,4 +1,6 @@
|
||||||
canvas {
|
canvas {
|
||||||
|
/*
|
||||||
background-color: #ddd;
|
background-color: #ddd;
|
||||||
width: 100%;
|
width: 100%;
|
||||||
|
*/
|
||||||
}
|
}
|
Loading…
Add table
Add a link
Reference in a new issue