真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

javaScript+turn.js如何實(shí)現(xiàn)圖書(shū)翻頁(yè)效果

小編給大家分享一下javaScript+turn.js如何實(shí)現(xiàn)圖書(shū)翻頁(yè)效果,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

十多年的保山網(wǎng)站建設(shè)經(jīng)驗(yàn),針對(duì)設(shè)計(jì)、前端、開(kāi)發(fā)、售后、文案、推廣等六對(duì)一服務(wù),響應(yīng)快,48小時(shí)及時(shí)工作處理。營(yíng)銷型網(wǎng)站建設(shè)的優(yōu)勢(shì)是能夠根據(jù)用戶設(shè)備顯示端的尺寸不同,自動(dòng)調(diào)整保山建站的顯示方式,使網(wǎng)站能夠適用不同顯示終端,在瀏覽器中調(diào)整網(wǎng)站的寬度,無(wú)論在任何一種瀏覽器上瀏覽網(wǎng)站,都能展現(xiàn)優(yōu)雅布局與設(shè)計(jì),從而大程度地提升瀏覽體驗(yàn)。成都創(chuàng)新互聯(lián)從事“保山網(wǎng)站設(shè)計(jì)”,“保山網(wǎng)站推廣”以來(lái),每個(gè)客戶項(xiàng)目都認(rèn)真落實(shí)執(zhí)行。

首先附上個(gè)人的文件路徑

javaScript+turn.js如何實(shí)現(xiàn)圖書(shū)翻頁(yè)效果

對(duì)于css   和 js文件不需要過(guò)多的解釋   在這里要注意的是pages文件夾   這里個(gè)文件夾下放的是需要預(yù)覽的圖片文件    所以
我們想展示的資源  就放在這個(gè)目錄下面?。。。。。?nbsp;   

接下來(lái)  先給大家看一下pages下面的資源名稱

javaScript+turn.js如何實(shí)現(xiàn)圖書(shū)翻頁(yè)效果

可以看到  所有的資源都以數(shù)字命名  至于為什么  我們?cè)谥髸?huì)講解

接下來(lái)  我們開(kāi)始使將turn.js結(jié)合到我們自己的項(xiàng)目中  先附上index.html中的代碼

 
 
 
 
 Using turn.js and the new zoom feature 
  
  
  
  
  
  
  
  
  
  
 
 
 
  
  
 
              
   
                        function loadApp() {    $('#canvas').fadeIn(1000);    var flipbook = $('.magazine');    // Check if the CSS was already loaded    if (flipbook.width() == 0 || flipbook.height() == 0) {    setTimeout(loadApp, 10);    return;    }    // 創(chuàng)建flipbook    flipbook.turn({    width: 1200,    height: 781,    duration: 1000, //翻頁(yè)速度,值越小越快    // Hardware acceleration    acceleration: !isChrome(),    // Enables gradients    gradients: true,    // Auto center this flipbook    autoCenter: true,    // Elevation from the edge of the flipbook when turning a page    elevation: 50,    // The number of pages    pages: 8,    // Events    when: {     turning: function (event, page, view) {     var book = $(this),      currentPage = book.turn('page'),      pages = book.turn('pages');     // Update the current URI     Hash.go('page/' + page).update();     // Show and hide navigation buttons     disableControls(page);     },     turned: function (event, page, view) {     disableControls(page);     $(this).turn('center');     if (page == 1) {      $(this).turn('peel', 'br');     }     },     missing: function (event, pages) {     // Add pages that aren't in the magazine     for (var i = 0; i < pages.length; i++)      addPage(pages[i], $(this));     }    }    });    // Zoom.js    $('.magazine-viewport').zoom({    flipbook: $('.magazine'),    max: function () {     return largeMagazineWidth() / $('.magazine').width();    },    when: {     swipeLeft: function () {     $(this).zoom('flipbook').turn('next');     },     swipeRight: function () {     $(this).zoom('flipbook').turn('previous');     },     resize: function (event, scale, page, pageElement) {     if (scale == 1)      loadSmallPage(page, pageElement);     else      loadLargePage(page, pageElement);     },     zoomIn: function () {     $('.made').hide();     $('.magazine').removeClass('animated').addClass('zoom-in');     $('.zoom-icon').removeClass('zoom-icon-in').addClass('zoom-icon-out');     if (!window.escTip && !$.isTouch) {      escTip = true;      $('', {'class': 'exit-message'}).      html('
Press ESC to exit
').      appendTo($('body')).      delay(2000).      animate({opacity: 0}, 500, function () {      $(this).remove();      });     }     },     zoomOut: function () {     $('.exit-message').hide();     $('.thumbnails').fadeIn();     $('.made').fadeIn();     $('.zoom-icon').removeClass('zoom-icon-out').addClass('zoom-icon-in');     setTimeout(function () {      $('.magazine').addClass('animated').removeClass('zoom-in');      resizeViewport();     }, 0);     }    }    });    // Zoom event    if ($.isTouch)    $('.magazine-viewport').bind('zoom.doubleTap', zoomTo);    else    $('.magazine-viewport').bind('zoom.tap', zoomTo);    // Using arrow keys to turn the page    $(document).keydown(function (e) {    var previous = 37, next = 39, esc = 27;    switch (e.keyCode) {     case previous:     // left arrow     $('.magazine').turn('previous');     e.preventDefault();     break;     case next:     //right arrow     $('.magazine').turn('next');     e.preventDefault();     break;     case esc:     $('.magazine-viewport').zoom('zoomOut');     e.preventDefault();     break;    }    });    // URIs - Format #/page/1    Hash.on('^page\/([0-9]*)$', {    yep: function (path, parts) {     var page = parts[1];     if (page !== undefined) {     if ($('.magazine').turn('is'))      $('.magazine').turn('page', page);     }    },    nop: function (path) {     if ($('.magazine').turn('is'))     $('.magazine').turn('page', 1);    }    });    $(window).resize(function () {    resizeViewport();    }).bind('orientationchange', function () {    resizeViewport();    });    // Events for thumbnails    $('.thumbnails').click(function (event) {    var page;    if (event.target && (page = /page-([0-9]+)/.exec($(event.target).attr('class')))) {     $('.magazine').turn('page', page[1]);    }    });    $('.thumbnails li').    bind($.mouseEvents.over, function () {    $(this).addClass('thumb-hover');    }).bind($.mouseEvents.out, function () {    $(this).removeClass('thumb-hover');    });    if ($.isTouch) {    $('.thumbnails').    addClass('thumbanils-touch').    bind($.mouseEvents.move, function (event) {     event.preventDefault();    });    } else {    $('.thumbnails ul').mouseover(function () {     $('.thumbnails').addClass('thumbnails-hover');    }).mousedown(function () {     return false;    }).mouseout(function () {     $('.thumbnails').removeClass('thumbnails-hover');    });    }    // Regions    if ($.isTouch) {    $('.magazine').bind('touchstart', regionClick);    } else {    $('.magazine').click(regionClick);    }    // Events for the next button    $('.next-button').bind($.mouseEvents.over, function () {    $(this).addClass('next-button-hover');    }).bind($.mouseEvents.out, function () {    $(this).removeClass('next-button-hover');    }).bind($.mouseEvents.down, function () {    $(this).addClass('next-button-down');    }).bind($.mouseEvents.up, function () {    $(this).removeClass('next-button-down');    }).click(function () {    $('.magazine').turn('next');    setTimeout(function () {     setArrows();    }, 300);    });    // Events for the next button    $('.previous-button').bind($.mouseEvents.over, function () {    $(this).addClass('previous-button-hover');    }).bind($.mouseEvents.out, function () {    $(this).removeClass('previous-button-hover');    }).bind($.mouseEvents.down, function () {    $(this).addClass('previous-button-down');    }).bind($.mouseEvents.up, function () {    $(this).removeClass('previous-button-down');    }).click(function () {    $('.magazine').turn('previous');    setTimeout(function () {     setArrows();    }, 300);    });    resizeViewport();    $('.magazine').addClass('animated');   }   // Zoom icon   $('.zoom-icon').bind('mouseover', function () {    if ($(this).hasClass('zoom-icon-in'))    $(this).addClass('zoom-icon-in-hover');    if ($(this).hasClass('zoom-icon-out'))    $(this).addClass('zoom-icon-out-hover');   }).bind('mouseout', function () {    if ($(this).hasClass('zoom-icon-in'))    $(this).removeClass('zoom-icon-in-hover');    if ($(this).hasClass('zoom-icon-out'))    $(this).removeClass('zoom-icon-out-hover');   }).bind('click', function () {    if ($(this).hasClass('zoom-icon-in'))    $('.magazine-viewport').zoom('zoomIn');    else if ($(this).hasClass('zoom-icon-out'))    $('.magazine-viewport').zoom('zoomOut');   });   $('#canvas').hide();   // Load the HTML4 version if there's not CSS transform   yepnope({    test: Modernizr.csstransforms,    yep: ['js/turn.js'],    nope: ['js/turn.html4.min.js'],    both: ['js/zoom.min.js', 'js/magazine.js', 'css/magazine.css'],    complete: loadApp   });                  

一:在其中值得注意的是:對(duì)于js的引用 有兩處! 

1:是開(kāi)頭這里引用了css和js

 
 
 
 
 
 
 

2:則是index.html的最下方,這里極容易被忽視?。?!切記路徑不可錯(cuò)誤,不然報(bào)錯(cuò)?。。?!

// Load the HTML4 version if there's not CSS transform 
yepnope({ 
 test: Modernizr.csstransforms, 
 yep: ['js/turn.js'], 
 nope: ['js/turn.html4.min.js'], 
 both: ['js/zoom.min.js', 'js/magazine.js', 'css/magazine.css'], 
 complete: loadApp 
});

二:js中的magazine.js  這個(gè)js值整個(gè)功能實(shí)現(xiàn)的支柱   在這里提供了所有的函數(shù)。

/* 
 * Magazine sample 
*/ 
//這里是對(duì)前頁(yè)后頁(yè)的位置設(shè)定 
function setArrows() { 
 /*var width = $(window).width(); 
 //alert("chushihua"+width); 
 var height = $(window).height(); 
 var bookWidth = $(".magazine").width(); 
 var bookHeight = $(".magazine").height(); 
 //alert("chushihua"+bookWidth); 
 var arrowSize = $(".next-button").width(); 
 //alert(arrowSize); 
 alert($(".magazine").offset().left+"\n"+$('.next-button').offset().left); 
 var LeftArrowLeft = - ( width - bookWidth ) / 4 + 'px' ; 
 //alert(LeftArrowLeft); 
 var RightArrowLeft = - ( width - bookWidth+ arrowSize*2) / 4 + 'px' ; 
 //alert(RightArrowLeft); 
 //alert(RightArrowLeft); 
 //alert("zhihou"+bookWidth); 
 $('.next-button').css( "right",RightArrowLeft ); 
 $('.previous-button').css( "left", LeftArrowLeft );*/ 
 setTimeout(function(){ 
 var width = $(window).width(); 
 var bookWidth = $(".magazine").width(); 
 var arrowSize = $(".next-button").width(); 
 var magaLeft=$(".magazine").offset().left; 
 var nextLeft= (width-bookWidth-magaLeft-60)/2; 
 //alert("width "+width +"\nbookWidth :"+bookWidth +"\nmagaLeft:"+magaLeft+"\nnextLeft:"+nextLeft); 
 $('.next-button').animate({ "right":nextLeft},300); 
 $('.previous-button').animate({ "left":nextLeft},300); 
 },100); 
} 
//這是用于加載所有的待展示資源 
function addPage(page, book) { 
 var id, pages = book.turn('pages'); 
 // Create a new element for this page 
 var element = $('', {}); 
 // Add the page to the flipbook 
 if (book.turn('addPage', element, page)) { 
 // Add the initial HTML 
 // It will contain a loader indicator and a gradient 
 element.html(''); 
 // Load the page 
 loadPage(page, element); 
 } 
} 
function loadPage(page, pageElement) { 
 // Create an image element 
 var img = $(''); 
 img.mousedown(function(e) { 
 e.preventDefault(); 
 }); 
 img.load(function() { 
 // Set the size 
 $(this).css({ 
  width: '100%', 
  height: '100%' 
 }); 
 // Add the image to the page after loaded 
 $(this).appendTo(pageElement); 
 // Remove the loader indicator 
 pageElement.find('.loader').remove(); 
 }); 
 // Load the page 
 img.attr('src', 'pages/' + page + '.png');//這里就是指向展示資源路徑,pages/即之前提及的pages文件夾,根據(jù)需要可更換。 
 loadRegions(page, pageElement); 
} 
// 這里是識(shí)別預(yù)覽大圖還是小圖的模式1為大圖 
function zoomTo(event) { 
 setTimeout(function() { 
 if ($('.magazine-viewport').data().regionClicked) { 
  $('.magazine-viewport').data().regionClicked = false; 
 } else { 
  if ($('.magazine-viewport').zoom('value') == 1) { 
  $('.magazine-viewport').zoom('zoomIn', event); 
  } else { 
  $('.magazine-viewport').zoom('zoomOut'); 
  } 
 } 
 }, 
 1); 
} 
// 不需了解 
function loadRegions(page, element) { 
 $.getJSON('pages/' + page + '-regions.json').done(function(data) { 
 $.each(data, 
 function(key, region) { 
  addRegion(region, element); 
 }); 
 }); 
} 
// 不需了解 
function addRegion(region, pageElement) { 
 var reg = $('', { 
 'class': 'region ' + region['class'] 
 }), 
 options = $('.magazine').turn('options'), 
 pageWidth = options.width / 2, 
 pageHeight = options.height; 
 reg.css({ 
 top: Math.round(region.y / pageHeight * 100) + '%', 
 left: Math.round(region.x / pageWidth * 100) + '%', 
 width: Math.round(region.width / pageWidth * 100) + '%', 
 height: Math.round(region.height / pageHeight * 100) + '%' 
 }).attr('region-data', $.param(region.data || '')); 
 reg.appendTo(pageElement); 
} 
function regionClick(event) { 
 var region = $(event.target); 
 if (region.hasClass('region')) { 
 $('.magazine-viewport').data().regionClicked = true; 
 setTimeout(function() { 
  $('.magazine-viewport').data().regionClicked = false; 
 }, 
 100); 
 var regionType = $.trim(region.attr('class').replace('region', '')); 
 return processRegion(region, regionType); 
 } 
} 
// 不需了解 
function processRegion(region, regionType) { 
 data = decodeParams(region.attr('region-data')); 
 switch (regionType) { 
 case 'link': 
 window.open(data.url); 
 break; 
 case 'zoom': 
 var regionOffset = region.offset(), 
 viewportOffset = $('.magazine-viewport').offset(), 
 pos = { 
  x: regionOffset.left - viewportOffset.left, 
  y: regionOffset.top - viewportOffset.top 
 }; 
 $('.magazine-viewport').zoom('zoomIn', pos); 
 break; 
 case 'to-page': 
 $('.magazine').turn('page', data.page); 
 break; 
 } 
} 
// 加載大圖 
function loadLargePage(page, pageElement) { 
 var img = $(''); 
 img.load(function() { 
 var prevImg = pageElement.find('img'); 
 $(this).css({ 
  width: '100%', 
  height: '100%' 
 }); 
 $(this).appendTo(pageElement); 
 prevImg.remove(); 
 }); 
 // Loadnew page 
 img.attr('src', 'pages/' + page + '-large.png');//這里指向大圖路徑,當(dāng)點(diǎn)擊預(yù)覽大圖的時(shí)候,加載該路徑,可根據(jù)需要更換。 
} 
// 加載小圖 
function loadSmallPage(page, pageElement) { 
 var img = pageElement.find('img'); 
 img.css({ 
 width: '100%', 
 height: '100%' 
 }); 
 img.unbind('load'); 
 // Loadnew page 
 img.attr('src', 'pages/' + page + '.png');//指向小圖路徑,同上 
} 
// 判斷瀏覽器 
function isChrome() { 
 return navigator.userAgent.indexOf('Chrome') != -1; 
} 
function disableControls(page) { 
 if (page == 1) $('.previous-button').hide(); 
 else $('.previous-button').show(); 
 if (page == $('.magazine').turn('pages')) $('.next-button').hide(); 
 else $('.next-button').show(); 
} 
// 為圖書(shū)設(shè)置寬高 
function resizeViewport() { 
 var width = $(window).width(), 
 height = $(window).height(), 
 options = $('.magazine').turn('options'); 
 $('.magazine').removeClass('animated'); 
 $('.magazine-viewport').css({ 
 width: width, 
 height: height 
 }).zoom('resize'); 
 setArrows() ; 
 if ($('.magazine').turn('zoom') == 1) { 
 var bound = calculateBound({ 
  width: options.width, 
  height: options.height, 
  boundWidth: Math.min(options.width, width), 
  boundHeight: Math.min(options.height, height) 
 }); 
 if (bound.width % 2 !== 0) bound.width -= 1; 
 if (bound.width != $('.magazine').width() || bound.height != $('.magazine').height()) { 
  $('.magazine').turn('size', bound.width, bound.height); 
  if ($('.magazine').turn('page') == 1) $('.magazine').turn('peel', 'br'); 
 } 
 $('.magazine').css({ 
  top: -bound.height / 2, 
  left: -bound.width / 2 
 }); 
 } 
 var magazineOffset = $('.magazine').offset(), 
 boundH = height - magazineOffset.top - $('.magazine').height(), 
 marginTop = (boundH - $('.thumbnails > div').height()) / 2; 
 if (marginTop < 0) { 
 $('.thumbnails').css({ 
  height: 1 
 }); 
 } else { 
 $('.thumbnails').css({ 
  height: boundH 
 }); 
 $('.thumbnails > div').css({ 
  marginTop: marginTop 
 }); 
 } 
 if (magazineOffset.top < $('.made').height()) $('.made').hide(); 
 else $('.made').show(); 
 $('.magazine').addClass('animated'); 
} 
//這里用于返回待預(yù)覽資源的個(gè)數(shù)(即書(shū)本的頁(yè)數(shù)) 
function numberOfViews(book) { 
 return book.turn('pages') / 2 + 1; 
} 
// 當(dāng)前頁(yè) 
function getViewNumber(book, page) { 
 return parseInt((page || book.turn('page')) / 2 + 1, 10); 
} 
// 記錄寬度 
function largeMagazineWidth() { 
 return 2214; 
} 
function decodeParams(data) { 
 var parts = data.split('&'), 
 d, 
 obj = {}; 
 for (var i = 0; i < parts.length; i++) { 
 d = parts[i].split('='); 
 obj[decodeURIComponent(d[0])] = decodeURIComponent(d[1]); 
 } 
 return obj; 
} 
function calculateBound(d) { 
 var bound = { 
 width: d.width, 
 height: d.height 
 }; 
 if (bound.width > d.boundWidth || bound.height > d.boundHeight) { 
 var rel = bound.width / bound.height; 
 if (d.boundWidth / rel > d.boundHeight && d.boundHeight * rel <= d.boundWidth) { 
  bound.width = Math.round(d.boundHeight * rel); 
  bound.height = d.boundHeight; 
 } else { 
  bound.width = d.boundWidth; 
  bound.height = Math.round(d.boundWidth / rel); 
 } 
 } 
 return bound; 
}

在掌握到這些后  便可使用turn.js

以上是“javaScript+turn.js如何實(shí)現(xiàn)圖書(shū)翻頁(yè)效果”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


本文標(biāo)題:javaScript+turn.js如何實(shí)現(xiàn)圖書(shū)翻頁(yè)效果
鏈接地址:http://weahome.cn/article/pjjpgg.html

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部