diff options
Diffstat (limited to 'lib/epub.js/examples/input.html')
-rw-r--r-- | lib/epub.js/examples/input.html | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/lib/epub.js/examples/input.html b/lib/epub.js/examples/input.html new file mode 100644 index 0000000..375b4ef --- /dev/null +++ b/lib/epub.js/examples/input.html @@ -0,0 +1,91 @@ +<!DOCTYPE html> +<html> +<head> + <meta charset="utf-8"> + <meta name="viewport" content="width=device-width, initial-scale=1"> + <title>EPUB.js Input Example</title> + + <script src="https://cdnjs.cloudflare.com/ajax/libs/jszip/3.1.5/jszip.min.js"></script> + <script src="../dist/epub.js"></script> + + <link rel="stylesheet" type="text/css" href="examples.css"> + +</head> +<body> + <div id="title"><input type="file" id="input"></div> + <div id="viewer" class="spreads"></div> + <a id="prev" href="#prev" class="arrow">‹</a> + <a id="next" href="#next" class="arrow">›</a> + + <script> + + var book = ePub(); + var rendition; + + var inputElement = document.getElementById("input"); + + inputElement.addEventListener('change', function (e) { + var file = e.target.files[0]; + if (window.FileReader) { + var reader = new FileReader(); + reader.onload = openBook; + reader.readAsArrayBuffer(file); + } + }); + + function openBook(e){ + var bookData = e.target.result; + var title = document.getElementById("title"); + var next = document.getElementById("next"); + var prev = document.getElementById("prev"); + + book.open(bookData, "binary"); + + rendition = book.renderTo("viewer", { + width: "100%", + height: 600 + }); + + rendition.display(); + + var keyListener = function(e){ + + // Left Key + if ((e.keyCode || e.which) == 37) { + rendition.prev(); + } + + // Right Key + if ((e.keyCode || e.which) == 39) { + rendition.next(); + } + + }; + + rendition.on("keyup", keyListener); + rendition.on("relocated", function(location){ + console.log(location); + }); + + next.addEventListener("click", function(e){ + rendition.next(); + e.preventDefault(); + }, false); + + prev.addEventListener("click", function(e){ + rendition.prev(); + e.preventDefault(); + }, false); + + + + + document.addEventListener("keyup", keyListener, false); + } + + + + </script> + +</body> +</html> |