<link href="//netdna.bootstrapcdn.com/bootstrap/3.0.0/css/bootstrap.min.css" rel="stylesheet" id="bootstrap-css">
<script src="//netdna.bootstrapcdn.com/bootstrap/3.0.0/js/bootstrap.min.js"></script>
<script src="//code.jquery.com/jquery-1.11.1.min.js"></script>
<!------ Include the above in your HEAD tag ---------->
<div class="bg">
<center><div class="openbook">
<img class="bookbg" src="">
<div class="book">
<br>
<div class="container">
<div id="myCarousel" class="carousel slide" data-ride="carousel">
<!-- Indicators -->
<ol class="carousel-indicators">
<li data-target="#myCarousel" data-slide-to="0" class="active"></li>
<li data-target="#myCarousel" data-slide-to="1"></li>
<li data-target="#myCarousel" data-slide-to="2"></li>
</ol>
<!-- Wrapper for slides -->
<div class="carousel-inner">
<div class="item active">
<img src="https://cdn1.edgedatg.com/aws/v2/abc/OnceUponaTimeinWonderland/showimages/8fb90328a66a06d06bac379ebee66901/640x180-Q100_8fb90328a66a06d06bac379ebee66901.png" width="170" height="110">
<br><br>
<TextArea rows="7" cols="22">Wonderland...if all the world is a stage, your mind is a forst of wonder. A place of pine an oak. A world of Fanstasy and punder...lets explore the foarst of your mind. Follow me.. </TextArea>
</div>
<div class="item">
<img src="https://fthmb.tqn.com/-A6-7wthLkhovD8Brc5H_DT4EVc=/768x0/filters:no_upscale()/about/Alice-in-Wonderland-58f77dcc3df78ca1593f2ba3.jpg" width="170" height="110">
<br><br>
<TextArea rows="7" cols="22">Wonderland...if all the world is a stage, your mind is a forst of wonder. A place of pine an oak. A world of Fanstasy and punder...lets explore the foarst of your mind. Follow me.. </TextArea>
</div>
<div class="item">
<img src="http://www.deepintolove.com/wp-content/uploads/2012/07/rodney_matthews_alice-in-wonderland_the-mock-turtles-story.jpg" width="170" height="110">
<br><br>
<TextArea rows="7" cols="22">Wonderland...if all the world is a stage, your mind is a forst of wonder. A place of pine an oak. A world of Fanstasy and punder...lets explore the foarst of your mind. Follow me.. </TextArea>
</div>
</div>
<!-- Left and right controls -->
<a class="left carousel-control" href="#myCarousel" data-slide="prev">
<span class="glyphicon glyphicon-chevron-left"></span>
<span class="sr-only">Previous</span>
</a>
<a class="right carousel-control" href="#myCarousel" data-slide="next">
<span class="glyphicon glyphicon-chevron-right"></span>
<span class="sr-only">Next</span>
</a>
</div>
</div>
<section class="demos">
<!-- Using divs for the demo, for formatting... you can use images if you want! -->
<div class="demo-image first" data-image="http://tholman.com/intense-images/img/h1_small.jpg" data-title="Beautiful fields" data-caption="With lots of wheaty puffs. Love those puffs."></div>
<div class="demo-image second" data-image="http://tholman.com/intense-images/img/v1_small.jpg" data-title="Fantastic cliffs" data-caption="Longing for exploration. Explore me!"></div>
</section>
<img id="cover" class="cover"
src="https://thomaskinkade.com/wp-content/uploads/2016/03/alicew.jpg" width="640" height="480">
<div class="spine"></div>
</div>
</div></center></div>
.bg {
background-image: url("https://i.stack.imgur.com/s4YBx.jpg");
background-size: 100.6%;
}
.openbook {
;
}
.book img {
background-color:white;
}
.bookWrap {
margin:25px auto;
height:546px;
width:430px;
-webkit-perspective: 1200px;
-moz-perspective: 1200px;
perspective: 1200px;
}
.book {
background-image: url("https://catabbottbadmp.files.wordpress.com/2012/04/book2.png");
background-size: cover;
background-repeat: no-repeat;
background-position: 100%;
height:346px;
width:230px;
top:0;
-webkit-transform-style: preserve-3d;
-moz-transform-style: preserve-3d;
transform-style: preserve-3d;
-webkit-transition: -webkit-transform .5s ease 0s;
-moz-transition: -moz-transform .5s ease 0s;
transition: transform .5s ease 0s;
-webkit-border-radius: 0 7px 7px 0;
-moz-border-radius: 0 7px 7px 0;
border-radius: 0 7px 7px 0;
-webkit-perspective: 1200px;
-moz-perspective: 1200px;
perspective: 1200px;
}
.bookIntro {
-webkit-transform: rotateY(30deg);
-moz-transform: rotateY(30deg);
transform: rotateY(30deg);
}
.cover {
left:0;
top:0;
position: absolute;
height: 100%;
width: 230px;
max-width: 430px;
max-height: 346px;
-webkit-border-radius: 0 4px 4px 0;
-moz-border-radius: 0 4px 4px 0;
border-radius: 0 4px 4px 0;
-webkit-transition: -webkit-transform .5s ease 0s, width .5s ease 0s;
-moz-transition: -moz-transform .5s ease 0s, width .5s ease 0s;
transition: transform .5s ease 0s, width .5s ease 0s;
-webkit-transform-origin: 0;
-moz-transform-origin: 0;
transform-origin: 0;
}
.cover:hover {
width:910px;
-webkit-transform: rotateY(-120deg);
-moz-transform: rotateY(-120deg);
transform: rotateY(-120deg);
transition: ease 1s; /*delay 1s*/
}
.spine {
width: 40px;
height: 344px;
position: absolute;
top: 0;
left:0;
background-image: url("https://s-media-cache-ak0.pinimg.com/736x/1e/38/7d/1e387d71c96920689df2eab503c16796.jpg");
background-size: cover;
-webkit-transform: rotateY(90deg);
-moz-transform: rotateY(90deg);
transform: rotateY(90deg);
-webkit-transform-origin: 0;
-moz-transform-origin: 0;
transform-origin: 0;
}
$(document).ready(function() {
// Pause just a moment
setTimeout(function() {
var $book = $('.book');
// Apply the intro classes that will
// appear to turn the book,
// revealing its spine
$book.addClass('bookIntro');
// pause another moment, then turn back
setTimeout(function() {
$book.removeClass('bookIntro');
}, 2000);
}, 1000);
});
$('button').each(function() {
var maxWidth = 600; // Max width for the image
var maxHeight = 600; // Max height for the image
var ratio = 0; // Used for aspect ratio
var width = $(this).width(); // Current image width
var height = $(this).height(); // Current image height
// Check if the current width is larger than the max
if(width > maxWidth){
ratio = maxWidth / width; // get ratio for scaling image
$(this).css("width", maxWidth); // Set new width
$(this).css("height", height * ratio); // Scale height based on ratio
height = height * ratio; // Reset height to match scaled image
width = width * ratio; // Reset width to match scaled image
}
// Check if current height is larger than max
if(height > maxHeight){
ratio = maxHeight / height; // get ratio for scaling image
$(this).css("height", maxHeight); // Set new height
$(this).css("width", width * ratio); // Scale width based on ratio
width = width * ratio; // Reset width to match scaled image
}
});
window.requestAnimFrame = (function(){
return window.requestAnimationFrame ||
window.webkitRequestAnimationFrame ||
window.mozRequestAnimationFrame ||
function( callback ){
window.setTimeout(callback, 1000 / 60);
};
})();
window.cancelRequestAnimFrame = ( function() {
return window.cancelAnimationFrame ||
window.webkitCancelRequestAnimationFrame ||
window.mozCancelRequestAnimationFrame ||
window.oCancelRequestAnimationFrame ||
window.msCancelRequestAnimationFrame ||
clearTimeout
} )();
var Intense = (function() {
'use strict';
var KEYCODE_ESC = 27;
// Track both the current and destination mouse coordinates
// Destination coordinates are non-eased actual mouse coordinates
var mouse = { xCurr:0, yCurr:0, xDest: 0, yDest: 0 };
var horizontalOrientation = true;
// Holds the animation frame id.
var looper;
// Current position of scrolly element
var lastPosition, currentPosition = 0;
var sourceDimensions, target;
var targetDimensions = { w: 0, h: 0 };
var container;
var containerDimensions = { w: 0, h:0 };
var overflowArea = { x: 0, y: 0 };
// Overflow variable before screen is locked.
var overflowValue;
/* -------------------------
/* UTILS
/* -------------------------*/
// Soft object augmentation
function extend( target, source ) {
for ( var key in source )
if ( !( key in target ) )
target[ key ] = source[ key ];
return target;
}
// Applys a dict of css properties to an element
function applyProperties( target, properties ) {
for( var key in properties ) {
target.style[ key ] = properties[ key ];
}
}
// Returns whether target a vertical or horizontal fit in the page.
// As well as the right fitting width/height of the image.
function getFit(
source ) {
var heightRatio = window.innerHeight / source.h;
if( (source.w * heightRatio) > window.innerWidth ) {
return { w: source.w * heightRatio, h: source.h * heightRatio, fit: true };
} else {
var widthRatio = window.innerWidth / source.w;
return { w: source.w * widthRatio, h: source.h * widthRatio, fit: false };
}
}
/* -------------------------
/* APP
/* -------------------------*/
function startTracking( passedElements ) {
var i;
// If passed an array of elements, assign tracking to all.
if ( passedElements.length ) {
// Loop and assign
for( i = 0; i < passedElements.length; i++ ) {
track( passedElements[ i ] );
}
} else {
track( passedElements );
}
}
function track( element ) {
// Element needs a src at minumun.
if( element.getAttribute( 'data-image') || element.src ) {
element.addEventListener( 'click', function() {
init( this );
}, false );
}
}
function start() {
loop();
}
function stop() {
cancelRequestAnimFrame( looper );
}
function loop() {
looper = requestAnimFrame(loop);
positionTarget();
}
// Lock scroll on the document body.
function lockBody() {
overflowValue = document.body.style.overflow;
document.body.style.overflow = 'hidden';
}
// Unlock scroll on the document body.
function unlockBody() {
document.body.style.overflow = overflowValue;
}
function createViewer( title, caption ) {
/*
* Container
*/
var containerProperties = {
'backgroundColor': 'rgba(0,0,0,0.8)',
'width': '100%',
'height': '100%',
'position': 'fixed',
'top': '0px',
'left': '0px',
'overflow': 'hidden',
'zIndex': '999999',
'margin': '0px',
'webkitTransition': 'opacity 150ms cubic-bezier( 0, 0, .26, 1 )',
'MozTransition': 'opacity 150ms cubic-bezier( 0, 0, .26, 1 )',
'transition': 'opacity 150ms cubic-bezier( 0, 0, .26, 1 )',
'opacity': '0'
}
container = document.createElement( 'figure' );
container.appendChild( target );
applyProperties( container, containerProperties );
var imageProperties = {
'cursor': 'url( "" ) 25 25, auto'
}
applyProperties( target, imageProperties );
/*
* Caption Container
*/
var captionContainerProperties = {
'fontFamily': 'Georgia, Times, "Times New Roman", serif',
'position': 'fixed',
'bottom': '0px',
'left': '0px',
'padding': '20px',
'color': '#fff',
'wordSpacing': '0.2px',
'webkitFontSmoothing': 'antialiased',
'textShadow': '-1px 0px 1px rgba(0,0,0,0.4)'
}
var captionContainer = document.createElement( 'figcaption' );
applyProperties( captionContainer, captionContainerProperties );
/*
* Caption Title
*/
if ( title ) {
var captionTitleProperties = {
'margin': '0px',
'padding': '0px',
'fontWeight': 'normal',
'fontSize': '40px',
'letterSpacing': '0.5px',
'lineHeight': '35px',
'textAlign': 'left'
}
var captionTitle = document.createElement( 'h1' );
applyProperties( captionTitle, captionTitleProperties );
captionTitle.innerHTML = title;
captionContainer.appendChild( captionTitle );
}
if ( caption ) {
var captionTextProperties = {
'margin': '0px',
'padding': '0px',
'fontWeight': 'normal',
'fontSize': '20px',
'letterSpacing': '0.1px',
'maxWidth': '500px',
'textAlign': 'left',
'background': 'none',
'marginTop': '5px'
}
var captionText = document.createElement( 'h2' );
applyProperties( captionText, captionTextProperties );
captionText.innerHTML = caption;
captionContainer.appendChild( captionText );
}
container.appendChild( captionContainer );
setDimensions();
mouse.xCurr = mouse.xDest = window.innerWidth / 2;
mouse.yCurr = mouse.yDest = window.innerHeight / 2;
document.body.appendChild( container );
setTimeout( function() {
container.style[ 'opacity' ] = '1';
}, 10);
}
function removeViewer() {
unlockBody();
unbindEvents();
document.body.removeChild( container );
}
function setDimensions() {
// Manually set height to stop bug where
var imageDimensions = getFit( sourceDimensions );
target.width = imageDimensions.w;
target.height = imageDimensions.h;
horizontalOrientation = imageDimensions.fit;
targetDimensions = { w: target.width, h: target.height };
containerDimensions = { w: window.innerWidth, h: window.innerHeight };
overflowArea = {x: containerDimensions.w - targetDimensions.w, y: containerDimensions.h - targetDimensions.h};
}
function init( element ) {
var imageSource = element.getAttribute( 'data-image') || element.src;
var title = element.getAttribute( 'data-title');
var caption = element.getAttribute( 'data-caption');
var img = new Image();
img.onload = function() {
sourceDimensions = { w: img.width, h: img.height }; // Save original dimensions for later.
target = this;
createViewer( title, caption );
lockBody();
bindEvents();
loop();
}
img.src = imageSource;
}
function bindEvents() {
container.addEventListener( 'mousemove', onMouseMove, false );
container.addEventListener( 'touchmove', onTouchMove, false );
window.addEventListener( 'resize', setDimensions, false );
window.addEventListener( 'keyup', onKeyUp, false );
target.addEventListener( 'click', removeViewer, false );
}
function unbindEvents() {
container.removeEventListener( 'mousemove', onMouseMove, false );
container.removeEventListener( 'touchmove', onTouchMove, false);
window.removeEventListener( 'resize', setDimensions, false );
window.removeEventListener( 'keyup', onKeyUp, false );
target.removeEventListener( 'click', removeViewer, false )
}
function onMouseMove( event ) {
mouse.xDest = event.clientX;
mouse.yDest = event.clientY;
}
function onTouchMove( event ) {
event.preventDefault(); // Needed to keep this event firing.
mouse.xDest = event.touches[0].clientX;
mouse.yDest = event.touches[0].clientY;
}
// Exit on excape key pressed;
function onKeyUp( event ) {
event.preventDefault();
if ( event.keyCode === KEYCODE_ESC ) {
removeViewer();
}
}
function positionTarget() {
mouse.xCurr += ( mouse.xDest - mouse.xCurr ) * 0.05;
mouse.yCurr += ( mouse.yDest - mouse.yCurr ) * 0.05;
if ( horizontalOrientation === true ) {
// HORIZONTAL SCANNING
currentPosition += ( mouse.xCurr - currentPosition );
if( mouse.xCurr !== lastPosition ) {
var position = parseFloat( currentPosition / containerDimensions.w );
position = overflowArea.x * position;
target.style[ 'webkitTransform' ] = 'translate3d(' + position + 'px, 0px, 0px)';
target.style[ 'MozTransform' ] = 'translate3d(' + position + 'px, 0px, 0px)';
target.style[ 'msTransform' ] = 'translate3d(' + position + 'px, 0px, 0px)';
lastPosition = mouse.xCurr;
}
} else if ( horizontalOrientation === false ) {
// VERTICAL SCANNING
currentPosition += ( mouse.yCurr - currentPosition );
if( mouse.yCurr !== lastPosition ) {
var position = parseFloat( currentPosition / containerDimensions.h );
position = overflowArea.y * position;
target.style[ 'webkitTransform' ] = 'translate3d( 0px, ' + position + 'px, 0px)';
target.style[ 'MozTransform' ] = 'translate3d( 0px, ' + position + 'px, 0px)';
target.style[ 'msTransform' ] = 'translate3d( 0px, ' + position + 'px, 0px)';
lastPosition = mouse.yCurr;
}
}
}
function main( element ) {
// Parse arguments
if ( !element ) {
throw 'You need to pass an element!';
}
startTracking( element );
}
return extend( main, {
resize: setDimensions,
start: start,
stop: stop
});
})();