annotate presen/slides.js @ 26:8370b9afbf33

add presen
author e095732 <e095732@ie.u-ryukyu.ac.jp>
date Thu, 20 Dec 2012 16:29:59 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
26
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
1 /*
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
2 Google HTML5 slides template
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
3
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
4 Authors: Luke Mahé (code)
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
5 Marcin Wichary (code and design)
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
6
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
7 Dominic Mazzoni (browser compatibility)
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
8 Charles Chen (ChromeVox support)
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
9
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
10 URL: http://code.google.com/p/html5slides/
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
11
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
12
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
13 var PERMANENT_URL_PREFIX = 'http://html5slides.googlecode.com/svn/trunk/';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
14 */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
15 var PERMANENT_URL_PREFIX = './';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
16 var SLIDE_CLASSES = ['far-past', 'past', 'current', 'next', 'far-next'];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
17
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
18 var PM_TOUCH_SENSITIVITY = 15;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
19
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
20 var curSlide;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
21
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
22 /* ---------------------------------------------------------------------- */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
23 /* classList polyfill by Eli Grey
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
24 * (http://purl.eligrey.com/github/classList.js/blob/master/classList.js) */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
25
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
26 if (typeof document !== "undefined" && !("classList" in document.createElement("a"))) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
27
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
28 (function (view) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
29
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
30 var
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
31 classListProp = "classList"
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
32 , protoProp = "prototype"
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
33 , elemCtrProto = (view.HTMLElement || view.Element)[protoProp]
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
34 , objCtr = Object
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
35 strTrim = String[protoProp].trim || function () {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
36 return this.replace(/^\s+|\s+$/g, "");
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
37 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
38 , arrIndexOf = Array[protoProp].indexOf || function (item) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
39 for (var i = 0, len = this.length; i < len; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
40 if (i in this && this[i] === item) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
41 return i;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
42 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
43 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
44 return -1;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
45 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
46 // Vendors: please allow content code to instantiate DOMExceptions
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
47 , DOMEx = function (type, message) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
48 this.name = type;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
49 this.code = DOMException[type];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
50 this.message = message;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
51 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
52 , checkTokenAndGetIndex = function (classList, token) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
53 if (token === "") {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
54 throw new DOMEx(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
55 "SYNTAX_ERR"
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
56 , "An invalid or illegal string was specified"
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
57 );
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
58 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
59 if (/\s/.test(token)) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
60 throw new DOMEx(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
61 "INVALID_CHARACTER_ERR"
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
62 , "String contains an invalid character"
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
63 );
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
64 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
65 return arrIndexOf.call(classList, token);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
66 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
67 , ClassList = function (elem) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
68 var
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
69 trimmedClasses = strTrim.call(elem.className)
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
70 , classes = trimmedClasses ? trimmedClasses.split(/\s+/) : []
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
71 ;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
72 for (var i = 0, len = classes.length; i < len; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
73 this.push(classes[i]);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
74 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
75 this._updateClassName = function () {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
76 elem.className = this.toString();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
77 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
78 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
79 , classListProto = ClassList[protoProp] = []
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
80 , classListGetter = function () {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
81 return new ClassList(this);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
82 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
83 ;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
84 // Most DOMException implementations don't allow calling DOMException's toString()
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
85 // on non-DOMExceptions. Error's toString() is sufficient here.
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
86 DOMEx[protoProp] = Error[protoProp];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
87 classListProto.item = function (i) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
88 return this[i] || null;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
89 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
90 classListProto.contains = function (token) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
91 token += "";
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
92 return checkTokenAndGetIndex(this, token) !== -1;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
93 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
94 classListProto.add = function (token) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
95 token += "";
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
96 if (checkTokenAndGetIndex(this, token) === -1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
97 this.push(token);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
98 this._updateClassName();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
99 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
100 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
101 classListProto.remove = function (token) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
102 token += "";
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
103 var index = checkTokenAndGetIndex(this, token);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
104 if (index !== -1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
105 this.splice(index, 1);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
106 this._updateClassName();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
107 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
108 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
109 classListProto.toggle = function (token) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
110 token += "";
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
111 if (checkTokenAndGetIndex(this, token) === -1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
112 this.add(token);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
113 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
114 this.remove(token);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
115 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
116 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
117 classListProto.toString = function () {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
118 return this.join(" ");
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
119 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
120
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
121 if (objCtr.defineProperty) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
122 var classListPropDesc = {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
123 get: classListGetter
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
124 , enumerable: true
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
125 , configurable: true
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
126 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
127 try {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
128 objCtr.defineProperty(elemCtrProto, classListProp, classListPropDesc);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
129 } catch (ex) { // IE 8 doesn't support enumerable:true
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
130 if (ex.number === -0x7FF5EC54) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
131 classListPropDesc.enumerable = false;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
132 objCtr.defineProperty(elemCtrProto, classListProp, classListPropDesc);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
133 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
134 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
135 } else if (objCtr[protoProp].__defineGetter__) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
136 elemCtrProto.__defineGetter__(classListProp, classListGetter);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
137 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
138
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
139 }(self));
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
140
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
141 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
142 /* ---------------------------------------------------------------------- */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
143
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
144 /* Slide movement */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
145
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
146 function getSlideEl(no) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
147 if ((no < 0) || (no >= slideEls.length)) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
148 return null;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
149 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
150 return slideEls[no];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
151 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
152 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
153
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
154 function updateSlideClass(slideNo, className) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
155 var el = getSlideEl(slideNo);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
156
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
157 if (!el) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
158 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
159 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
160
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
161 if (className) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
162 el.classList.add(className);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
163 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
164
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
165 for (var i in SLIDE_CLASSES) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
166 if (className != SLIDE_CLASSES[i]) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
167 el.classList.remove(SLIDE_CLASSES[i]);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
168 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
169 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
170 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
171
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
172 function updateSlides() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
173 for (var i = 0; i < slideEls.length; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
174 switch (i) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
175 case curSlide - 2:
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
176 updateSlideClass(i, 'far-past');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
177 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
178 case curSlide - 1:
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
179 updateSlideClass(i, 'past');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
180 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
181 case curSlide:
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
182 updateSlideClass(i, 'current');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
183 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
184 case curSlide + 1:
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
185 updateSlideClass(i, 'next');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
186 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
187 case curSlide + 2:
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
188 updateSlideClass(i, 'far-next');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
189 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
190 default:
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
191 updateSlideClass(i);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
192 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
193 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
194 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
195
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
196 triggerLeaveEvent(curSlide - 1);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
197 triggerEnterEvent(curSlide);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
198
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
199 window.setTimeout(function() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
200 // Hide after the slide
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
201 disableSlideFrames(curSlide - 2);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
202 }, 301);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
203
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
204 enableSlideFrames(curSlide - 1);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
205 enableSlideFrames(curSlide + 2);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
206
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
207 if (isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
208 speakAndSyncToNode(slideEls[curSlide]);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
209 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
210
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
211 updateHash();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
212 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
213
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
214 function buildNextItem() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
215 var toBuild = slideEls[curSlide].querySelectorAll('.to-build');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
216
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
217 if (!toBuild.length) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
218 return false;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
219 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
220
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
221 toBuild[0].classList.remove('to-build', '');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
222
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
223 if (isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
224 speakAndSyncToNode(toBuild[0]);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
225 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
226
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
227 return true;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
228 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
229
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
230 function prevSlide() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
231 if (curSlide > 0) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
232 curSlide--;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
233
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
234 updateSlides();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
235 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
236 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
237
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
238 function nextSlide() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
239 if (buildNextItem()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
240 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
241 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
242
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
243 if (curSlide < slideEls.length - 1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
244 curSlide++;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
245
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
246 updateSlides();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
247 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
248 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
249
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
250 /* Slide events */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
251
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
252 function triggerEnterEvent(no) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
253 var el = getSlideEl(no);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
254 if (!el) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
255 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
256 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
257
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
258 var onEnter = el.getAttribute('onslideenter');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
259 if (onEnter) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
260 new Function(onEnter).call(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
261 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
262
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
263 var evt = document.createEvent('Event');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
264 evt.initEvent('slideenter', true, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
265 evt.slideNumber = no + 1; // Make it readable
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
266
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
267 el.dispatchEvent(evt);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
268 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
269
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
270 function triggerLeaveEvent(no) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
271 var el = getSlideEl(no);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
272 if (!el) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
273 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
274 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
275
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
276 var onLeave = el.getAttribute('onslideleave');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
277 if (onLeave) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
278 new Function(onLeave).call(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
279 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
280
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
281 var evt = document.createEvent('Event');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
282 evt.initEvent('slideleave', true, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
283 evt.slideNumber = no + 1; // Make it readable
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
284
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
285 el.dispatchEvent(evt);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
286 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
287
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
288 /* Touch events */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
289
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
290 function handleTouchStart(event) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
291 if (event.touches.length == 1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
292 touchDX = 0;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
293 touchDY = 0;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
294
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
295 touchStartX = event.touches[0].pageX;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
296 touchStartY = event.touches[0].pageY;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
297
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
298 document.body.addEventListener('touchmove', handleTouchMove, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
299 document.body.addEventListener('touchend', handleTouchEnd, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
300 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
301 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
302
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
303 function handleTouchMove(event) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
304 if (event.touches.length > 1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
305 cancelTouch();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
306 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
307 touchDX = event.touches[0].pageX - touchStartX;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
308 touchDY = event.touches[0].pageY - touchStartY;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
309 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
310 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
311
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
312 function handleTouchEnd(event) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
313 var dx = Math.abs(touchDX);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
314 var dy = Math.abs(touchDY);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
315
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
316 if ((dx > PM_TOUCH_SENSITIVITY) && (dy < (dx * 2 / 3))) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
317 if (touchDX > 0) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
318 prevSlide();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
319 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
320 nextSlide();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
321 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
322 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
323
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
324 cancelTouch();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
325 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
326
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
327 function cancelTouch() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
328 document.body.removeEventListener('touchmove', handleTouchMove, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
329 document.body.removeEventListener('touchend', handleTouchEnd, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
330 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
331
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
332 /* Preloading frames */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
333
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
334 function disableSlideFrames(no) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
335 var el = getSlideEl(no);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
336 if (!el) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
337 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
338 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
339
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
340 var frames = el.getElementsByTagName('iframe');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
341 for (var i = 0, frame; frame = frames[i]; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
342 disableFrame(frame);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
343 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
344 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
345
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
346 function enableSlideFrames(no) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
347 var el = getSlideEl(no);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
348 if (!el) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
349 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
350 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
351
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
352 var frames = el.getElementsByTagName('iframe');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
353 for (var i = 0, frame; frame = frames[i]; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
354 enableFrame(frame);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
355 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
356 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
357
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
358 function disableFrame(frame) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
359 frame.src = 'about:blank';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
360 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
361
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
362 function enableFrame(frame) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
363 var src = frame._src;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
364
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
365 if (frame.src != src && src != 'about:blank') {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
366 frame.src = src;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
367 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
368 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
369
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
370 function setupFrames() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
371 var frames = document.querySelectorAll('iframe');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
372 for (var i = 0, frame; frame = frames[i]; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
373 frame._src = frame.src;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
374 disableFrame(frame);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
375 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
376
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
377 enableSlideFrames(curSlide);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
378 enableSlideFrames(curSlide + 1);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
379 enableSlideFrames(curSlide + 2);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
380 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
381
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
382 function setupInteraction() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
383 /* Clicking and tapping */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
384
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
385 var el = document.createElement('div');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
386 el.className = 'slide-area';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
387 el.id = 'prev-slide-area';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
388 el.addEventListener('click', prevSlide, false);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
389 document.querySelector('section.slides').appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
390
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
391 var el = document.createElement('div');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
392 el.className = 'slide-area';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
393 el.id = 'next-slide-area';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
394 el.addEventListener('click', nextSlide, false);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
395 document.querySelector('section.slides').appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
396
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
397 /* Swiping */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
398
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
399 document.body.addEventListener('touchstart', handleTouchStart, false);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
400 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
401
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
402 /* ChromeVox support */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
403
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
404 function isChromeVoxActive() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
405 if (typeof(cvox) == 'undefined') {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
406 return false;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
407 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
408 return true;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
409 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
410 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
411
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
412 function speakAndSyncToNode(node) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
413 if (!isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
414 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
415 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
416
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
417 cvox.ChromeVox.navigationManager.switchToStrategy(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
418 cvox.ChromeVoxNavigationManager.STRATEGIES.LINEARDOM, 0, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
419 cvox.ChromeVox.navigationManager.syncToNode(node);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
420 cvox.ChromeVoxUserCommands.finishNavCommand('');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
421 var target = node;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
422 while (target.firstChild) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
423 target = target.firstChild;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
424 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
425 cvox.ChromeVox.navigationManager.syncToNode(target);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
426 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
427
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
428 function speakNextItem() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
429 if (!isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
430 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
431 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
432
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
433 cvox.ChromeVox.navigationManager.switchToStrategy(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
434 cvox.ChromeVoxNavigationManager.STRATEGIES.LINEARDOM, 0, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
435 cvox.ChromeVox.navigationManager.next(true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
436 if (!cvox.DomUtil.isDescendantOfNode(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
437 cvox.ChromeVox.navigationManager.getCurrentNode(), slideEls[curSlide])){
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
438 var target = slideEls[curSlide];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
439 while (target.firstChild) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
440 target = target.firstChild;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
441 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
442 cvox.ChromeVox.navigationManager.syncToNode(target);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
443 cvox.ChromeVox.navigationManager.next(true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
444 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
445 cvox.ChromeVoxUserCommands.finishNavCommand('');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
446 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
447
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
448 function speakPrevItem() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
449 if (!isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
450 return;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
451 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
452
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
453 cvox.ChromeVox.navigationManager.switchToStrategy(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
454 cvox.ChromeVoxNavigationManager.STRATEGIES.LINEARDOM, 0, true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
455 cvox.ChromeVox.navigationManager.previous(true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
456 if (!cvox.DomUtil.isDescendantOfNode(
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
457 cvox.ChromeVox.navigationManager.getCurrentNode(), slideEls[curSlide])){
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
458 var target = slideEls[curSlide];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
459 while (target.lastChild){
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
460 target = target.lastChild;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
461 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
462 cvox.ChromeVox.navigationManager.syncToNode(target);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
463 cvox.ChromeVox.navigationManager.previous(true);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
464 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
465 cvox.ChromeVoxUserCommands.finishNavCommand('');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
466 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
467
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
468 /* Hash functions */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
469
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
470 function getCurSlideFromHash() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
471 var slideNo = parseInt(location.hash.substr(1));
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
472
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
473 if (slideNo) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
474 curSlide = slideNo - 1;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
475 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
476 curSlide = 0;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
477 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
478 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
479
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
480 function updateHash() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
481 location.replace('#' + (curSlide + 1));
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
482 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
483
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
484 /* Event listeners */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
485
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
486 function handleBodyKeyDown(event) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
487 switch (event.keyCode) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
488 case 39: // right arrow
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
489 case 13: // Enter
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
490 case 32: // space
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
491 case 34: // PgDn
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
492 nextSlide();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
493 event.preventDefault();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
494 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
495
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
496 case 37: // left arrow
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
497 case 8: // Backspace
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
498 case 33: // PgUp
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
499 prevSlide();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
500 event.preventDefault();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
501 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
502
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
503 case 40: // down arrow
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
504 if (isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
505 speakNextItem();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
506 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
507 nextSlide();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
508 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
509 event.preventDefault();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
510 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
511
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
512 case 38: // up arrow
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
513 if (isChromeVoxActive()) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
514 speakPrevItem();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
515 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
516 prevSlide();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
517 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
518 event.preventDefault();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
519 break;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
520 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
521 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
522
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
523 function addEventListeners() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
524 document.addEventListener('keydown', handleBodyKeyDown, false);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
525 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
526
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
527 /* Initialization */
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
528
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
529 function addPrettify() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
530 var els = document.querySelectorAll('pre');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
531 for (var i = 0, el; el = els[i]; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
532 if (!el.classList.contains('noprettyprint')) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
533 el.classList.add('prettyprint');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
534 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
535 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
536
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
537 var el = document.createElement('script');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
538 el.type = 'text/javascript';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
539 el.src = PERMANENT_URL_PREFIX + 'prettify.js';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
540 el.onload = function() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
541 prettyPrint();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
542 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
543 document.body.appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
544 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
545
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
546 function addFontStyle() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
547 var el = document.createElement('link');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
548 el.rel = 'stylesheet';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
549 el.type = 'text/css';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
550 el.href = 'http://fonts.googleapis.com/css?family=' +
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
551 'Open+Sans:regular,semibold,italic,italicsemibold|Droid+Sans+Mono';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
552
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
553 document.body.appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
554 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
555
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
556 function addGeneralStyle() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
557 var el = document.createElement('link');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
558 el.rel = 'stylesheet';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
559 el.type = 'text/css';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
560 el.href = PERMANENT_URL_PREFIX + 'styles.css';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
561 document.body.appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
562
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
563 var el = document.createElement('meta');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
564 el.name = 'viewport';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
565 el.content = 'width=1100,height=750';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
566 document.querySelector('head').appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
567
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
568 var el = document.createElement('meta');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
569 el.name = 'apple-mobile-web-app-capable';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
570 el.content = 'yes';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
571 document.querySelector('head').appendChild(el);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
572 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
573
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
574 function makeBuildLists() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
575 for (var i = curSlide, slide; slide = slideEls[i]; i++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
576 var items = slide.querySelectorAll('.build > *');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
577 for (var j = 0, item; item = items[j]; j++) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
578 if (item.classList) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
579 item.classList.add('to-build');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
580 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
581 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
582 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
583 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
584
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
585 function handleDomLoaded() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
586 slideEls = document.querySelectorAll('section.slides > article');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
587
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
588 setupFrames();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
589
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
590 addFontStyle();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
591 addGeneralStyle();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
592 addPrettify();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
593 addEventListeners();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
594
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
595 updateSlides();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
596
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
597 setupInteraction();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
598 makeBuildLists();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
599
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
600 document.body.classList.add('loaded');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
601 };
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
602
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
603 function initialize() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
604 getCurSlideFromHash();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
605
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
606 if (window['_DEBUG']) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
607 PERMANENT_URL_PREFIX = '../';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
608 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
609
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
610 if (window['_DCL']) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
611 handleDomLoaded();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
612 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
613 document.addEventListener('DOMContentLoaded', handleDomLoaded, false);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
614 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
615 }
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
616
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
617 // If ?debug exists then load the script relative instead of absolute
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
618 if (!window['_DEBUG'] && document.location.href.indexOf('?debug') !== -1) {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
619 document.addEventListener('DOMContentLoaded', function() {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
620 // Avoid missing the DomContentLoaded event
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
621 window['_DCL'] = true
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
622 }, false);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
623
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
624 window['_DEBUG'] = true;
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
625 var script = document.createElement('script');
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
626 script.type = 'text/javascript';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
627 script.src = '../slides.js';
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
628 var s = document.getElementsByTagName('script')[0];
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
629 s.parentNode.insertBefore(script, s);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
630
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
631 // Remove this script
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
632 s.parentNode.removeChild(s);
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
633 } else {
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
634 initialize();
8370b9afbf33 add presen
e095732 <e095732@ie.u-ryukyu.ac.jp>
parents:
diff changeset
635 }