effect-coverflow.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. import createShadow from '../../shared/create-shadow.js';
  2. import effectInit from '../../shared/effect-init.js';
  3. import effectTarget from '../../shared/effect-target.js';
  4. export default function EffectCoverflow(_ref) {
  5. let {
  6. swiper,
  7. extendParams,
  8. on
  9. } = _ref;
  10. extendParams({
  11. coverflowEffect: {
  12. rotate: 50,
  13. stretch: 0,
  14. depth: 100,
  15. scale: 1,
  16. modifier: 1,
  17. slideShadows: true,
  18. transformEl: null
  19. }
  20. });
  21. const setTranslate = () => {
  22. const {
  23. width: swiperWidth,
  24. height: swiperHeight,
  25. slides,
  26. slidesSizesGrid
  27. } = swiper;
  28. const params = swiper.params.coverflowEffect;
  29. const isHorizontal = swiper.isHorizontal();
  30. const transform = swiper.translate;
  31. const center = isHorizontal ? -transform + swiperWidth / 2 : -transform + swiperHeight / 2;
  32. const rotate = isHorizontal ? params.rotate : -params.rotate;
  33. const translate = params.depth; // Each slide offset from center
  34. for (let i = 0, length = slides.length; i < length; i += 1) {
  35. const $slideEl = slides.eq(i);
  36. const slideSize = slidesSizesGrid[i];
  37. const slideOffset = $slideEl[0].swiperSlideOffset;
  38. const centerOffset = (center - slideOffset - slideSize / 2) / slideSize;
  39. const offsetMultiplier = typeof params.modifier === 'function' ? params.modifier(centerOffset) : centerOffset * params.modifier;
  40. let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;
  41. let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier; // var rotateZ = 0
  42. let translateZ = -translate * Math.abs(offsetMultiplier);
  43. let stretch = params.stretch; // Allow percentage to make a relative stretch for responsive sliders
  44. if (typeof stretch === 'string' && stretch.indexOf('%') !== -1) {
  45. stretch = parseFloat(params.stretch) / 100 * slideSize;
  46. }
  47. let translateY = isHorizontal ? 0 : stretch * offsetMultiplier;
  48. let translateX = isHorizontal ? stretch * offsetMultiplier : 0;
  49. let scale = 1 - (1 - params.scale) * Math.abs(offsetMultiplier); // Fix for ultra small values
  50. if (Math.abs(translateX) < 0.001) translateX = 0;
  51. if (Math.abs(translateY) < 0.001) translateY = 0;
  52. if (Math.abs(translateZ) < 0.001) translateZ = 0;
  53. if (Math.abs(rotateY) < 0.001) rotateY = 0;
  54. if (Math.abs(rotateX) < 0.001) rotateX = 0;
  55. if (Math.abs(scale) < 0.001) scale = 0;
  56. const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px) rotateX(${rotateX}deg) rotateY(${rotateY}deg) scale(${scale})`;
  57. const $targetEl = effectTarget(params, $slideEl);
  58. $targetEl.transform(slideTransform);
  59. $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;
  60. if (params.slideShadows) {
  61. // Set shadows
  62. let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');
  63. let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');
  64. if ($shadowBeforeEl.length === 0) {
  65. $shadowBeforeEl = createShadow(params, $slideEl, isHorizontal ? 'left' : 'top');
  66. }
  67. if ($shadowAfterEl.length === 0) {
  68. $shadowAfterEl = createShadow(params, $slideEl, isHorizontal ? 'right' : 'bottom');
  69. }
  70. if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;
  71. if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = -offsetMultiplier > 0 ? -offsetMultiplier : 0;
  72. }
  73. }
  74. };
  75. const setTransition = duration => {
  76. const {
  77. transformEl
  78. } = swiper.params.coverflowEffect;
  79. const $transitionElements = transformEl ? swiper.slides.find(transformEl) : swiper.slides;
  80. $transitionElements.transition(duration).find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left').transition(duration);
  81. };
  82. effectInit({
  83. effect: 'coverflow',
  84. swiper,
  85. on,
  86. setTranslate,
  87. setTransition,
  88. perspective: () => true,
  89. overwriteParams: () => ({
  90. watchSlidesProgress: true
  91. })
  92. });
  93. }