slideit 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +7 -0
- data/.gitignore +9 -0
- data/.travis.yml +5 -0
- data/CODE_OF_CONDUCT.md +49 -0
- data/Gemfile +4 -0
- data/README.md +38 -0
- data/Rakefile +10 -0
- data/bin/slideit +34 -0
- data/lib/slideit/version.rb +3 -0
- data/lib/slideit.rb +110 -0
- data/res/reveal.js-3.3.0/.gitignore +13 -0
- data/res/reveal.js-3.3.0/.travis.yml +5 -0
- data/res/reveal.js-3.3.0/CONTRIBUTING.md +23 -0
- data/res/reveal.js-3.3.0/Gruntfile.js +176 -0
- data/res/reveal.js-3.3.0/LICENSE +19 -0
- data/res/reveal.js-3.3.0/README.md +1104 -0
- data/res/reveal.js-3.3.0/bower.json +27 -0
- data/res/reveal.js-3.3.0/css/print/paper.css +202 -0
- data/res/reveal.js-3.3.0/css/print/pdf.css +160 -0
- data/res/reveal.js-3.3.0/css/reveal.css +1331 -0
- data/res/reveal.js-3.3.0/css/reveal.scss +1411 -0
- data/res/reveal.js-3.3.0/css/theme/README.md +21 -0
- data/res/reveal.js-3.3.0/css/theme/beige.css +291 -0
- data/res/reveal.js-3.3.0/css/theme/black.css +287 -0
- data/res/reveal.js-3.3.0/css/theme/blood.css +310 -0
- data/res/reveal.js-3.3.0/css/theme/league.css +293 -0
- data/res/reveal.js-3.3.0/css/theme/moon.css +291 -0
- data/res/reveal.js-3.3.0/css/theme/night.css +285 -0
- data/res/reveal.js-3.3.0/css/theme/serif.css +287 -0
- data/res/reveal.js-3.3.0/css/theme/simple.css +287 -0
- data/res/reveal.js-3.3.0/css/theme/sky.css +294 -0
- data/res/reveal.js-3.3.0/css/theme/solarized.css +291 -0
- data/res/reveal.js-3.3.0/css/theme/source/beige.scss +39 -0
- data/res/reveal.js-3.3.0/css/theme/source/black.scss +49 -0
- data/res/reveal.js-3.3.0/css/theme/source/blood.scss +79 -0
- data/res/reveal.js-3.3.0/css/theme/source/league.scss +34 -0
- data/res/reveal.js-3.3.0/css/theme/source/moon.scss +57 -0
- data/res/reveal.js-3.3.0/css/theme/source/night.scss +35 -0
- data/res/reveal.js-3.3.0/css/theme/source/serif.scss +35 -0
- data/res/reveal.js-3.3.0/css/theme/source/simple.scss +38 -0
- data/res/reveal.js-3.3.0/css/theme/source/sky.scss +46 -0
- data/res/reveal.js-3.3.0/css/theme/source/solarized.scss +63 -0
- data/res/reveal.js-3.3.0/css/theme/source/white.scss +49 -0
- data/res/reveal.js-3.3.0/css/theme/template/mixins.scss +29 -0
- data/res/reveal.js-3.3.0/css/theme/template/settings.scss +43 -0
- data/res/reveal.js-3.3.0/css/theme/template/theme.scss +346 -0
- data/res/reveal.js-3.3.0/css/theme/white.css +287 -0
- data/res/reveal.js-3.3.0/demo.html +410 -0
- data/res/reveal.js-3.3.0/index.html +52 -0
- data/res/reveal.js-3.3.0/js/reveal.js +4744 -0
- data/res/reveal.js-3.3.0/lib/css/zenburn.css +80 -0
- data/res/reveal.js-3.3.0/lib/font/league-gothic/LICENSE +2 -0
- data/res/reveal.js-3.3.0/lib/font/league-gothic/league-gothic.css +10 -0
- data/res/reveal.js-3.3.0/lib/font/league-gothic/league-gothic.eot +0 -0
- data/res/reveal.js-3.3.0/lib/font/league-gothic/league-gothic.ttf +0 -0
- data/res/reveal.js-3.3.0/lib/font/league-gothic/league-gothic.woff +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/LICENSE +45 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-italic.eot +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-italic.ttf +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-italic.woff +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-regular.eot +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-regular.ttf +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-regular.woff +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-semibold.eot +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-semibold.ttf +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-semibold.woff +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-semibolditalic.eot +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-semibolditalic.ttf +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro-semibolditalic.woff +0 -0
- data/res/reveal.js-3.3.0/lib/font/source-sans-pro/source-sans-pro.css +39 -0
- data/res/reveal.js-3.3.0/lib/js/classList.js +2 -0
- data/res/reveal.js-3.3.0/lib/js/head.min.js +9 -0
- data/res/reveal.js-3.3.0/lib/js/html5shiv.js +7 -0
- data/res/reveal.js-3.3.0/package.json +44 -0
- data/res/reveal.js-3.3.0/plugin/highlight/highlight.js +31 -0
- data/res/reveal.js-3.3.0/plugin/markdown/example.html +129 -0
- data/res/reveal.js-3.3.0/plugin/markdown/example.md +31 -0
- data/res/reveal.js-3.3.0/plugin/markdown/markdown.js +405 -0
- data/res/reveal.js-3.3.0/plugin/markdown/marked.js +6 -0
- data/res/reveal.js-3.3.0/plugin/math/math.js +67 -0
- data/res/reveal.js-3.3.0/plugin/multiplex/client.js +13 -0
- data/res/reveal.js-3.3.0/plugin/multiplex/index.js +64 -0
- data/res/reveal.js-3.3.0/plugin/multiplex/master.js +31 -0
- data/res/reveal.js-3.3.0/plugin/multiplex/package.json +19 -0
- data/res/reveal.js-3.3.0/plugin/notes/notes.html +414 -0
- data/res/reveal.js-3.3.0/plugin/notes/notes.js +136 -0
- data/res/reveal.js-3.3.0/plugin/notes-server/client.js +65 -0
- data/res/reveal.js-3.3.0/plugin/notes-server/index.js +69 -0
- data/res/reveal.js-3.3.0/plugin/notes-server/notes.html +407 -0
- data/res/reveal.js-3.3.0/plugin/print-pdf/print-pdf.js +48 -0
- data/res/reveal.js-3.3.0/plugin/search/search.js +196 -0
- data/res/reveal.js-3.3.0/plugin/zoom-js/zoom.js +278 -0
- data/res/reveal.js-3.3.0/simple.html +90 -0
- data/res/reveal.js-3.3.0/test/examples/assets/image1.png +0 -0
- data/res/reveal.js-3.3.0/test/examples/assets/image2.png +0 -0
- data/res/reveal.js-3.3.0/test/examples/barebones.html +41 -0
- data/res/reveal.js-3.3.0/test/examples/embedded-media.html +49 -0
- data/res/reveal.js-3.3.0/test/examples/math.html +185 -0
- data/res/reveal.js-3.3.0/test/examples/slide-backgrounds.html +144 -0
- data/res/reveal.js-3.3.0/test/examples/slide-transitions.html +101 -0
- data/res/reveal.js-3.3.0/test/qunit-1.12.0.css +244 -0
- data/res/reveal.js-3.3.0/test/qunit-1.12.0.js +2212 -0
- data/res/reveal.js-3.3.0/test/test-markdown-element-attributes.html +134 -0
- data/res/reveal.js-3.3.0/test/test-markdown-element-attributes.js +46 -0
- data/res/reveal.js-3.3.0/test/test-markdown-slide-attributes.html +128 -0
- data/res/reveal.js-3.3.0/test/test-markdown-slide-attributes.js +47 -0
- data/res/reveal.js-3.3.0/test/test-markdown.html +52 -0
- data/res/reveal.js-3.3.0/test/test-markdown.js +15 -0
- data/res/reveal.js-3.3.0/test/test-pdf.html +83 -0
- data/res/reveal.js-3.3.0/test/test-pdf.js +15 -0
- data/res/reveal.js-3.3.0/test/test.html +86 -0
- data/res/reveal.js-3.3.0/test/test.js +597 -0
- data/res/reveal.js-3.3.0/test.md +31 -0
- data/slideit.gemspec +25 -0
- metadata +199 -0
@@ -0,0 +1,196 @@
|
|
1
|
+
/*
|
2
|
+
* Handles finding a text string anywhere in the slides and showing the next occurrence to the user
|
3
|
+
* by navigatating to that slide and highlighting it.
|
4
|
+
*
|
5
|
+
* By Jon Snyder <snyder.jon@gmail.com>, February 2013
|
6
|
+
*/
|
7
|
+
|
8
|
+
var RevealSearch = (function() {
|
9
|
+
|
10
|
+
var matchedSlides;
|
11
|
+
var currentMatchedIndex;
|
12
|
+
var searchboxDirty;
|
13
|
+
var myHilitor;
|
14
|
+
|
15
|
+
// Original JavaScript code by Chirp Internet: www.chirp.com.au
|
16
|
+
// Please acknowledge use of this code by including this header.
|
17
|
+
// 2/2013 jon: modified regex to display any match, not restricted to word boundaries.
|
18
|
+
|
19
|
+
function Hilitor(id, tag)
|
20
|
+
{
|
21
|
+
|
22
|
+
var targetNode = document.getElementById(id) || document.body;
|
23
|
+
var hiliteTag = tag || "EM";
|
24
|
+
var skipTags = new RegExp("^(?:" + hiliteTag + "|SCRIPT|FORM|SPAN)$");
|
25
|
+
var colors = ["#ff6", "#a0ffff", "#9f9", "#f99", "#f6f"];
|
26
|
+
var wordColor = [];
|
27
|
+
var colorIdx = 0;
|
28
|
+
var matchRegex = "";
|
29
|
+
var matchingSlides = [];
|
30
|
+
|
31
|
+
this.setRegex = function(input)
|
32
|
+
{
|
33
|
+
input = input.replace(/^[^\w]+|[^\w]+$/g, "").replace(/[^\w'-]+/g, "|");
|
34
|
+
matchRegex = new RegExp("(" + input + ")","i");
|
35
|
+
}
|
36
|
+
|
37
|
+
this.getRegex = function()
|
38
|
+
{
|
39
|
+
return matchRegex.toString().replace(/^\/\\b\(|\)\\b\/i$/g, "").replace(/\|/g, " ");
|
40
|
+
}
|
41
|
+
|
42
|
+
// recursively apply word highlighting
|
43
|
+
this.hiliteWords = function(node)
|
44
|
+
{
|
45
|
+
if(node == undefined || !node) return;
|
46
|
+
if(!matchRegex) return;
|
47
|
+
if(skipTags.test(node.nodeName)) return;
|
48
|
+
|
49
|
+
if(node.hasChildNodes()) {
|
50
|
+
for(var i=0; i < node.childNodes.length; i++)
|
51
|
+
this.hiliteWords(node.childNodes[i]);
|
52
|
+
}
|
53
|
+
if(node.nodeType == 3) { // NODE_TEXT
|
54
|
+
if((nv = node.nodeValue) && (regs = matchRegex.exec(nv))) {
|
55
|
+
//find the slide's section element and save it in our list of matching slides
|
56
|
+
var secnode = node.parentNode;
|
57
|
+
while (secnode.nodeName != 'SECTION') {
|
58
|
+
secnode = secnode.parentNode;
|
59
|
+
}
|
60
|
+
|
61
|
+
var slideIndex = Reveal.getIndices(secnode);
|
62
|
+
var slidelen = matchingSlides.length;
|
63
|
+
var alreadyAdded = false;
|
64
|
+
for (var i=0; i < slidelen; i++) {
|
65
|
+
if ( (matchingSlides[i].h === slideIndex.h) && (matchingSlides[i].v === slideIndex.v) ) {
|
66
|
+
alreadyAdded = true;
|
67
|
+
}
|
68
|
+
}
|
69
|
+
if (! alreadyAdded) {
|
70
|
+
matchingSlides.push(slideIndex);
|
71
|
+
}
|
72
|
+
|
73
|
+
if(!wordColor[regs[0].toLowerCase()]) {
|
74
|
+
wordColor[regs[0].toLowerCase()] = colors[colorIdx++ % colors.length];
|
75
|
+
}
|
76
|
+
|
77
|
+
var match = document.createElement(hiliteTag);
|
78
|
+
match.appendChild(document.createTextNode(regs[0]));
|
79
|
+
match.style.backgroundColor = wordColor[regs[0].toLowerCase()];
|
80
|
+
match.style.fontStyle = "inherit";
|
81
|
+
match.style.color = "#000";
|
82
|
+
|
83
|
+
var after = node.splitText(regs.index);
|
84
|
+
after.nodeValue = after.nodeValue.substring(regs[0].length);
|
85
|
+
node.parentNode.insertBefore(match, after);
|
86
|
+
}
|
87
|
+
}
|
88
|
+
};
|
89
|
+
|
90
|
+
// remove highlighting
|
91
|
+
this.remove = function()
|
92
|
+
{
|
93
|
+
var arr = document.getElementsByTagName(hiliteTag);
|
94
|
+
while(arr.length && (el = arr[0])) {
|
95
|
+
el.parentNode.replaceChild(el.firstChild, el);
|
96
|
+
}
|
97
|
+
};
|
98
|
+
|
99
|
+
// start highlighting at target node
|
100
|
+
this.apply = function(input)
|
101
|
+
{
|
102
|
+
if(input == undefined || !input) return;
|
103
|
+
this.remove();
|
104
|
+
this.setRegex(input);
|
105
|
+
this.hiliteWords(targetNode);
|
106
|
+
return matchingSlides;
|
107
|
+
};
|
108
|
+
|
109
|
+
}
|
110
|
+
|
111
|
+
function openSearch() {
|
112
|
+
//ensure the search term input dialog is visible and has focus:
|
113
|
+
var inputbox = document.getElementById("searchinput");
|
114
|
+
inputbox.style.display = "inline";
|
115
|
+
inputbox.focus();
|
116
|
+
inputbox.select();
|
117
|
+
}
|
118
|
+
|
119
|
+
function toggleSearch() {
|
120
|
+
var inputbox = document.getElementById("searchinput");
|
121
|
+
if (inputbox.style.display !== "inline") {
|
122
|
+
openSearch();
|
123
|
+
}
|
124
|
+
else {
|
125
|
+
inputbox.style.display = "none";
|
126
|
+
myHilitor.remove();
|
127
|
+
}
|
128
|
+
}
|
129
|
+
|
130
|
+
function doSearch() {
|
131
|
+
//if there's been a change in the search term, perform a new search:
|
132
|
+
if (searchboxDirty) {
|
133
|
+
var searchstring = document.getElementById("searchinput").value;
|
134
|
+
|
135
|
+
//find the keyword amongst the slides
|
136
|
+
myHilitor = new Hilitor("slidecontent");
|
137
|
+
matchedSlides = myHilitor.apply(searchstring);
|
138
|
+
currentMatchedIndex = 0;
|
139
|
+
}
|
140
|
+
|
141
|
+
//navigate to the next slide that has the keyword, wrapping to the first if necessary
|
142
|
+
if (matchedSlides.length && (matchedSlides.length <= currentMatchedIndex)) {
|
143
|
+
currentMatchedIndex = 0;
|
144
|
+
}
|
145
|
+
if (matchedSlides.length > currentMatchedIndex) {
|
146
|
+
Reveal.slide(matchedSlides[currentMatchedIndex].h, matchedSlides[currentMatchedIndex].v);
|
147
|
+
currentMatchedIndex++;
|
148
|
+
}
|
149
|
+
}
|
150
|
+
|
151
|
+
var dom = {};
|
152
|
+
dom.wrapper = document.querySelector( '.reveal' );
|
153
|
+
|
154
|
+
if( !dom.wrapper.querySelector( '.searchbox' ) ) {
|
155
|
+
var searchElement = document.createElement( 'div' );
|
156
|
+
searchElement.id = "searchinputdiv";
|
157
|
+
searchElement.classList.add( 'searchdiv' );
|
158
|
+
searchElement.style.position = 'absolute';
|
159
|
+
searchElement.style.top = '10px';
|
160
|
+
searchElement.style.left = '10px';
|
161
|
+
//embedded base64 search icon Designed by Sketchdock - http://www.sketchdock.com/:
|
162
|
+
searchElement.innerHTML = '<span><input type="search" id="searchinput" class="searchinput" style="vertical-align: top;"/><img src="" id="searchbutton" class="searchicon" style="vertical-align: top; margin-top: -1px;"/></span>';
|
163
|
+
dom.wrapper.appendChild( searchElement );
|
164
|
+
}
|
165
|
+
|
166
|
+
document.getElementById("searchbutton").addEventListener( 'click', function(event) {
|
167
|
+
doSearch();
|
168
|
+
}, false );
|
169
|
+
|
170
|
+
document.getElementById("searchinput").addEventListener( 'keyup', function( event ) {
|
171
|
+
switch (event.keyCode) {
|
172
|
+
case 13:
|
173
|
+
event.preventDefault();
|
174
|
+
doSearch();
|
175
|
+
searchboxDirty = false;
|
176
|
+
break;
|
177
|
+
default:
|
178
|
+
searchboxDirty = true;
|
179
|
+
}
|
180
|
+
}, false );
|
181
|
+
|
182
|
+
// Open the search when the 's' key is hit (yes, this conflicts with the notes plugin, disabling for now)
|
183
|
+
/*
|
184
|
+
document.addEventListener( 'keydown', function( event ) {
|
185
|
+
// Disregard the event if the target is editable or a
|
186
|
+
// modifier is present
|
187
|
+
if ( document.querySelector( ':focus' ) !== null || event.shiftKey || event.altKey || event.ctrlKey || event.metaKey ) return;
|
188
|
+
|
189
|
+
if( event.keyCode === 83 ) {
|
190
|
+
event.preventDefault();
|
191
|
+
openSearch();
|
192
|
+
}
|
193
|
+
}, false );
|
194
|
+
*/
|
195
|
+
return { open: openSearch };
|
196
|
+
})();
|
@@ -0,0 +1,278 @@
|
|
1
|
+
// Custom reveal.js integration
|
2
|
+
(function(){
|
3
|
+
var isEnabled = true;
|
4
|
+
|
5
|
+
document.querySelector( '.reveal .slides' ).addEventListener( 'mousedown', function( event ) {
|
6
|
+
var modifier = ( Reveal.getConfig().zoomKey ? Reveal.getConfig().zoomKey : 'alt' ) + 'Key';
|
7
|
+
|
8
|
+
var zoomPadding = 20;
|
9
|
+
var revealScale = Reveal.getScale();
|
10
|
+
|
11
|
+
if( event[ modifier ] && isEnabled ) {
|
12
|
+
event.preventDefault();
|
13
|
+
|
14
|
+
var bounds = event.target.getBoundingClientRect();
|
15
|
+
|
16
|
+
zoom.to({
|
17
|
+
x: ( bounds.left * revealScale ) - zoomPadding,
|
18
|
+
y: ( bounds.top * revealScale ) - zoomPadding,
|
19
|
+
width: ( bounds.width * revealScale ) + ( zoomPadding * 2 ),
|
20
|
+
height: ( bounds.height * revealScale ) + ( zoomPadding * 2 ),
|
21
|
+
pan: false
|
22
|
+
});
|
23
|
+
}
|
24
|
+
} );
|
25
|
+
|
26
|
+
Reveal.addEventListener( 'overviewshown', function() { isEnabled = false; } );
|
27
|
+
Reveal.addEventListener( 'overviewhidden', function() { isEnabled = true; } );
|
28
|
+
})();
|
29
|
+
|
30
|
+
/*!
|
31
|
+
* zoom.js 0.3 (modified for use with reveal.js)
|
32
|
+
* http://lab.hakim.se/zoom-js
|
33
|
+
* MIT licensed
|
34
|
+
*
|
35
|
+
* Copyright (C) 2011-2014 Hakim El Hattab, http://hakim.se
|
36
|
+
*/
|
37
|
+
var zoom = (function(){
|
38
|
+
|
39
|
+
// The current zoom level (scale)
|
40
|
+
var level = 1;
|
41
|
+
|
42
|
+
// The current mouse position, used for panning
|
43
|
+
var mouseX = 0,
|
44
|
+
mouseY = 0;
|
45
|
+
|
46
|
+
// Timeout before pan is activated
|
47
|
+
var panEngageTimeout = -1,
|
48
|
+
panUpdateInterval = -1;
|
49
|
+
|
50
|
+
// Check for transform support so that we can fallback otherwise
|
51
|
+
var supportsTransforms = 'WebkitTransform' in document.body.style ||
|
52
|
+
'MozTransform' in document.body.style ||
|
53
|
+
'msTransform' in document.body.style ||
|
54
|
+
'OTransform' in document.body.style ||
|
55
|
+
'transform' in document.body.style;
|
56
|
+
|
57
|
+
if( supportsTransforms ) {
|
58
|
+
// The easing that will be applied when we zoom in/out
|
59
|
+
document.body.style.transition = 'transform 0.8s ease';
|
60
|
+
document.body.style.OTransition = '-o-transform 0.8s ease';
|
61
|
+
document.body.style.msTransition = '-ms-transform 0.8s ease';
|
62
|
+
document.body.style.MozTransition = '-moz-transform 0.8s ease';
|
63
|
+
document.body.style.WebkitTransition = '-webkit-transform 0.8s ease';
|
64
|
+
}
|
65
|
+
|
66
|
+
// Zoom out if the user hits escape
|
67
|
+
document.addEventListener( 'keyup', function( event ) {
|
68
|
+
if( level !== 1 && event.keyCode === 27 ) {
|
69
|
+
zoom.out();
|
70
|
+
}
|
71
|
+
} );
|
72
|
+
|
73
|
+
// Monitor mouse movement for panning
|
74
|
+
document.addEventListener( 'mousemove', function( event ) {
|
75
|
+
if( level !== 1 ) {
|
76
|
+
mouseX = event.clientX;
|
77
|
+
mouseY = event.clientY;
|
78
|
+
}
|
79
|
+
} );
|
80
|
+
|
81
|
+
/**
|
82
|
+
* Applies the CSS required to zoom in, prefers the use of CSS3
|
83
|
+
* transforms but falls back on zoom for IE.
|
84
|
+
*
|
85
|
+
* @param {Object} rect
|
86
|
+
* @param {Number} scale
|
87
|
+
*/
|
88
|
+
function magnify( rect, scale ) {
|
89
|
+
|
90
|
+
var scrollOffset = getScrollOffset();
|
91
|
+
|
92
|
+
// Ensure a width/height is set
|
93
|
+
rect.width = rect.width || 1;
|
94
|
+
rect.height = rect.height || 1;
|
95
|
+
|
96
|
+
// Center the rect within the zoomed viewport
|
97
|
+
rect.x -= ( window.innerWidth - ( rect.width * scale ) ) / 2;
|
98
|
+
rect.y -= ( window.innerHeight - ( rect.height * scale ) ) / 2;
|
99
|
+
|
100
|
+
if( supportsTransforms ) {
|
101
|
+
// Reset
|
102
|
+
if( scale === 1 ) {
|
103
|
+
document.body.style.transform = '';
|
104
|
+
document.body.style.OTransform = '';
|
105
|
+
document.body.style.msTransform = '';
|
106
|
+
document.body.style.MozTransform = '';
|
107
|
+
document.body.style.WebkitTransform = '';
|
108
|
+
}
|
109
|
+
// Scale
|
110
|
+
else {
|
111
|
+
var origin = scrollOffset.x +'px '+ scrollOffset.y +'px',
|
112
|
+
transform = 'translate('+ -rect.x +'px,'+ -rect.y +'px) scale('+ scale +')';
|
113
|
+
|
114
|
+
document.body.style.transformOrigin = origin;
|
115
|
+
document.body.style.OTransformOrigin = origin;
|
116
|
+
document.body.style.msTransformOrigin = origin;
|
117
|
+
document.body.style.MozTransformOrigin = origin;
|
118
|
+
document.body.style.WebkitTransformOrigin = origin;
|
119
|
+
|
120
|
+
document.body.style.transform = transform;
|
121
|
+
document.body.style.OTransform = transform;
|
122
|
+
document.body.style.msTransform = transform;
|
123
|
+
document.body.style.MozTransform = transform;
|
124
|
+
document.body.style.WebkitTransform = transform;
|
125
|
+
}
|
126
|
+
}
|
127
|
+
else {
|
128
|
+
// Reset
|
129
|
+
if( scale === 1 ) {
|
130
|
+
document.body.style.position = '';
|
131
|
+
document.body.style.left = '';
|
132
|
+
document.body.style.top = '';
|
133
|
+
document.body.style.width = '';
|
134
|
+
document.body.style.height = '';
|
135
|
+
document.body.style.zoom = '';
|
136
|
+
}
|
137
|
+
// Scale
|
138
|
+
else {
|
139
|
+
document.body.style.position = 'relative';
|
140
|
+
document.body.style.left = ( - ( scrollOffset.x + rect.x ) / scale ) + 'px';
|
141
|
+
document.body.style.top = ( - ( scrollOffset.y + rect.y ) / scale ) + 'px';
|
142
|
+
document.body.style.width = ( scale * 100 ) + '%';
|
143
|
+
document.body.style.height = ( scale * 100 ) + '%';
|
144
|
+
document.body.style.zoom = scale;
|
145
|
+
}
|
146
|
+
}
|
147
|
+
|
148
|
+
level = scale;
|
149
|
+
|
150
|
+
if( document.documentElement.classList ) {
|
151
|
+
if( level !== 1 ) {
|
152
|
+
document.documentElement.classList.add( 'zoomed' );
|
153
|
+
}
|
154
|
+
else {
|
155
|
+
document.documentElement.classList.remove( 'zoomed' );
|
156
|
+
}
|
157
|
+
}
|
158
|
+
}
|
159
|
+
|
160
|
+
/**
|
161
|
+
* Pan the document when the mosue cursor approaches the edges
|
162
|
+
* of the window.
|
163
|
+
*/
|
164
|
+
function pan() {
|
165
|
+
var range = 0.12,
|
166
|
+
rangeX = window.innerWidth * range,
|
167
|
+
rangeY = window.innerHeight * range,
|
168
|
+
scrollOffset = getScrollOffset();
|
169
|
+
|
170
|
+
// Up
|
171
|
+
if( mouseY < rangeY ) {
|
172
|
+
window.scroll( scrollOffset.x, scrollOffset.y - ( 1 - ( mouseY / rangeY ) ) * ( 14 / level ) );
|
173
|
+
}
|
174
|
+
// Down
|
175
|
+
else if( mouseY > window.innerHeight - rangeY ) {
|
176
|
+
window.scroll( scrollOffset.x, scrollOffset.y + ( 1 - ( window.innerHeight - mouseY ) / rangeY ) * ( 14 / level ) );
|
177
|
+
}
|
178
|
+
|
179
|
+
// Left
|
180
|
+
if( mouseX < rangeX ) {
|
181
|
+
window.scroll( scrollOffset.x - ( 1 - ( mouseX / rangeX ) ) * ( 14 / level ), scrollOffset.y );
|
182
|
+
}
|
183
|
+
// Right
|
184
|
+
else if( mouseX > window.innerWidth - rangeX ) {
|
185
|
+
window.scroll( scrollOffset.x + ( 1 - ( window.innerWidth - mouseX ) / rangeX ) * ( 14 / level ), scrollOffset.y );
|
186
|
+
}
|
187
|
+
}
|
188
|
+
|
189
|
+
function getScrollOffset() {
|
190
|
+
return {
|
191
|
+
x: window.scrollX !== undefined ? window.scrollX : window.pageXOffset,
|
192
|
+
y: window.scrollY !== undefined ? window.scrollY : window.pageYOffset
|
193
|
+
}
|
194
|
+
}
|
195
|
+
|
196
|
+
return {
|
197
|
+
/**
|
198
|
+
* Zooms in on either a rectangle or HTML element.
|
199
|
+
*
|
200
|
+
* @param {Object} options
|
201
|
+
* - element: HTML element to zoom in on
|
202
|
+
* OR
|
203
|
+
* - x/y: coordinates in non-transformed space to zoom in on
|
204
|
+
* - width/height: the portion of the screen to zoom in on
|
205
|
+
* - scale: can be used instead of width/height to explicitly set scale
|
206
|
+
*/
|
207
|
+
to: function( options ) {
|
208
|
+
|
209
|
+
// Due to an implementation limitation we can't zoom in
|
210
|
+
// to another element without zooming out first
|
211
|
+
if( level !== 1 ) {
|
212
|
+
zoom.out();
|
213
|
+
}
|
214
|
+
else {
|
215
|
+
options.x = options.x || 0;
|
216
|
+
options.y = options.y || 0;
|
217
|
+
|
218
|
+
// If an element is set, that takes precedence
|
219
|
+
if( !!options.element ) {
|
220
|
+
// Space around the zoomed in element to leave on screen
|
221
|
+
var padding = 20;
|
222
|
+
var bounds = options.element.getBoundingClientRect();
|
223
|
+
|
224
|
+
options.x = bounds.left - padding;
|
225
|
+
options.y = bounds.top - padding;
|
226
|
+
options.width = bounds.width + ( padding * 2 );
|
227
|
+
options.height = bounds.height + ( padding * 2 );
|
228
|
+
}
|
229
|
+
|
230
|
+
// If width/height values are set, calculate scale from those values
|
231
|
+
if( options.width !== undefined && options.height !== undefined ) {
|
232
|
+
options.scale = Math.max( Math.min( window.innerWidth / options.width, window.innerHeight / options.height ), 1 );
|
233
|
+
}
|
234
|
+
|
235
|
+
if( options.scale > 1 ) {
|
236
|
+
options.x *= options.scale;
|
237
|
+
options.y *= options.scale;
|
238
|
+
|
239
|
+
magnify( options, options.scale );
|
240
|
+
|
241
|
+
if( options.pan !== false ) {
|
242
|
+
|
243
|
+
// Wait with engaging panning as it may conflict with the
|
244
|
+
// zoom transition
|
245
|
+
panEngageTimeout = setTimeout( function() {
|
246
|
+
panUpdateInterval = setInterval( pan, 1000 / 60 );
|
247
|
+
}, 800 );
|
248
|
+
|
249
|
+
}
|
250
|
+
}
|
251
|
+
}
|
252
|
+
},
|
253
|
+
|
254
|
+
/**
|
255
|
+
* Resets the document zoom state to its default.
|
256
|
+
*/
|
257
|
+
out: function() {
|
258
|
+
clearTimeout( panEngageTimeout );
|
259
|
+
clearInterval( panUpdateInterval );
|
260
|
+
|
261
|
+
magnify( { x: 0, y: 0 }, 1 );
|
262
|
+
|
263
|
+
level = 1;
|
264
|
+
},
|
265
|
+
|
266
|
+
// Alias
|
267
|
+
magnify: function( options ) { this.to( options ) },
|
268
|
+
reset: function() { this.out() },
|
269
|
+
|
270
|
+
zoomLevel: function() {
|
271
|
+
return level;
|
272
|
+
}
|
273
|
+
}
|
274
|
+
|
275
|
+
})();
|
276
|
+
|
277
|
+
|
278
|
+
|
@@ -0,0 +1,90 @@
|
|
1
|
+
<!doctype html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<meta charset="utf-8">
|
5
|
+
<title>Simple reveal.js Slides</title>
|
6
|
+
<link rel="stylesheet" href="css/reveal.css">
|
7
|
+
<link rel="stylesheet" href="css/theme/league.css">
|
8
|
+
</head>
|
9
|
+
<body>
|
10
|
+
<div class="reveal">
|
11
|
+
<div class="slides">
|
12
|
+
<section>Slide 1</section>
|
13
|
+
<section data-markdown>
|
14
|
+
<script type="text/template">
|
15
|
+
<!-- .slide: data-background="#ff0000" -->
|
16
|
+
## Page title
|
17
|
+
|
18
|
+
A paragraph with some text and a [link](http://hakim.se).
|
19
|
+
</script>
|
20
|
+
</section>
|
21
|
+
|
22
|
+
<section data-autoslide=false>
|
23
|
+
<section>
|
24
|
+
<img data-src="http://up.boohee.cn/house/u/boohee_web/160328/i2.jpg">
|
25
|
+
</section>
|
26
|
+
<section>
|
27
|
+
<iframe data-src="http://hakim.se"></iframe>
|
28
|
+
</section>
|
29
|
+
</section>
|
30
|
+
|
31
|
+
<section data-autoslide="2000">
|
32
|
+
<p>After 2 seconds the first fragment will be shown.</p>
|
33
|
+
<p class="fragment" data-autoslide="10000">After 10 seconds the next fragment will be shown.</p>
|
34
|
+
<p class="fragment">Now, the fragment is displayed for 2 seconds before the next slide is shown.</p>
|
35
|
+
</section>
|
36
|
+
|
37
|
+
<section data-markdown data-autoslide="3000">
|
38
|
+
<script type="text/template">
|
39
|
+
- Item 1 <!-- .element: class="fragment" data-fragment-index="1" -->
|
40
|
+
- Item 2 <!-- .element: class="fragment" data-fragment-index="2" -->
|
41
|
+
- Item 3 <!-- .element: class="fragment" data-fragment-index="3" -->
|
42
|
+
</script>
|
43
|
+
</section>
|
44
|
+
|
45
|
+
<section data-markdown data-separator="---">
|
46
|
+
<script type="text/template">
|
47
|
+
## Demo 1
|
48
|
+
Slide 1
|
49
|
+
---
|
50
|
+
## Demo 1
|
51
|
+
Slide 2
|
52
|
+
---
|
53
|
+
## Demo 1
|
54
|
+
Slide 3
|
55
|
+
</script>
|
56
|
+
</section>
|
57
|
+
|
58
|
+
<section>
|
59
|
+
<section>Vertical Slide 1</section>
|
60
|
+
<section>Vertical Slide 2</section>
|
61
|
+
<section>
|
62
|
+
Max hierarchies is two.
|
63
|
+
</section>
|
64
|
+
<section>Vertical Slide 4</section>
|
65
|
+
</section>
|
66
|
+
<section>这是非常漂亮的 PPT</section>
|
67
|
+
<section>Slide 2</section>
|
68
|
+
<section>The End</section>
|
69
|
+
</div>
|
70
|
+
</div>
|
71
|
+
|
72
|
+
<script src="lib/js/head.min.js"></script>
|
73
|
+
<script src="js/reveal.js"></script>
|
74
|
+
|
75
|
+
<script>
|
76
|
+
// More info https://github.com/hakimel/reveal.js#configuration
|
77
|
+
Reveal.initialize({
|
78
|
+
history: true,
|
79
|
+
autoSlide: false,
|
80
|
+
// More info https://github.com/hakimel/reveal.js#dependencies
|
81
|
+
dependencies: [
|
82
|
+
{ src: 'plugin/markdown/marked.js' },
|
83
|
+
{ src: 'plugin/markdown/markdown.js' },
|
84
|
+
{ src: 'plugin/notes/notes.js', async: true },
|
85
|
+
{ src: 'plugin/highlight/highlight.js', async: true, callback: function() { hljs.initHighlightingOnLoad(); } }
|
86
|
+
]
|
87
|
+
});
|
88
|
+
</script>
|
89
|
+
</body>
|
90
|
+
</html>
|
Binary file
|
Binary file
|
@@ -0,0 +1,41 @@
|
|
1
|
+
<!doctype html>
|
2
|
+
<html lang="en">
|
3
|
+
|
4
|
+
<head>
|
5
|
+
<meta charset="utf-8">
|
6
|
+
|
7
|
+
<title>reveal.js - Barebones</title>
|
8
|
+
|
9
|
+
<link rel="stylesheet" href="../../css/reveal.css">
|
10
|
+
</head>
|
11
|
+
|
12
|
+
<body>
|
13
|
+
|
14
|
+
<div class="reveal">
|
15
|
+
|
16
|
+
<div class="slides">
|
17
|
+
|
18
|
+
<section>
|
19
|
+
<h2>Barebones Presentation</h2>
|
20
|
+
<p>This example contains the bare minimum includes and markup required to run a reveal.js presentation.</p>
|
21
|
+
</section>
|
22
|
+
|
23
|
+
<section>
|
24
|
+
<h2>No Theme</h2>
|
25
|
+
<p>There's no theme included, so it will fall back on browser defaults.</p>
|
26
|
+
</section>
|
27
|
+
|
28
|
+
</div>
|
29
|
+
|
30
|
+
</div>
|
31
|
+
|
32
|
+
<script src="../../js/reveal.js"></script>
|
33
|
+
|
34
|
+
<script>
|
35
|
+
|
36
|
+
Reveal.initialize();
|
37
|
+
|
38
|
+
</script>
|
39
|
+
|
40
|
+
</body>
|
41
|
+
</html>
|
@@ -0,0 +1,49 @@
|
|
1
|
+
<!doctype html>
|
2
|
+
<html lang="en">
|
3
|
+
|
4
|
+
<head>
|
5
|
+
<meta charset="utf-8">
|
6
|
+
|
7
|
+
<title>reveal.js - Embedded Media</title>
|
8
|
+
|
9
|
+
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no">
|
10
|
+
|
11
|
+
<link rel="stylesheet" href="../../css/reveal.css">
|
12
|
+
<link rel="stylesheet" href="../../css/theme/default.css" id="theme">
|
13
|
+
</head>
|
14
|
+
|
15
|
+
<body>
|
16
|
+
|
17
|
+
<div class="reveal">
|
18
|
+
|
19
|
+
<div class="slides">
|
20
|
+
|
21
|
+
<section>
|
22
|
+
<h2>Embedded Media Test</h2>
|
23
|
+
</section>
|
24
|
+
|
25
|
+
<section>
|
26
|
+
<iframe data-autoplay width="420" height="345" src="http://www.youtube.com/embed/l3RQZ4mcr1c"></iframe>
|
27
|
+
</section>
|
28
|
+
|
29
|
+
<section>
|
30
|
+
<h2>Empty Slide</h2>
|
31
|
+
</section>
|
32
|
+
|
33
|
+
</div>
|
34
|
+
|
35
|
+
</div>
|
36
|
+
|
37
|
+
<script src="../../lib/js/head.min.js"></script>
|
38
|
+
<script src="../../js/reveal.js"></script>
|
39
|
+
|
40
|
+
<script>
|
41
|
+
|
42
|
+
Reveal.initialize({
|
43
|
+
transition: 'linear'
|
44
|
+
});
|
45
|
+
|
46
|
+
</script>
|
47
|
+
|
48
|
+
</body>
|
49
|
+
</html>
|