Quantcast
Channel: Ionic Framework - Ionic Forum
Viewing all articles
Browse latest Browse all 49083

Ionic Slides with angular

$
0
0

Hi, I have a problem with my slide.
I try to do it like this https://stackblitz.com/edit/swiper-demo-13-centered?file=index.html

but when I put my slide in the container that has the “swiper-wrapper” class, it won’t let me scroll I don’t know why that happens, but if I remove it from the container that contains the “swiper-wrapper” class, some idea works normal for me. that can help me.

My constant for slide options:

const slideOpts = {
  slidesPerView: 3,
  coverflowEffect: {
    rotate: 50,
    stretch: 0,
    depth: 100,
    modifier: 1,
    slideShadows: true,
    autoplay: true
  },
  on: {
    beforeInit() {
      const swiper = this;

      swiper.classNames.push(`${swiper.params.containerModifierClass}coverflow`);
      swiper.classNames.push(`${swiper.params.containerModifierClass}3d`);

      swiper.params.watchSlidesProgress = true;
      swiper.originalParams.watchSlidesProgress = true;
    },
    setTranslate() {
      const swiper = this;
      const {
        width: swiperWidth, height: swiperHeight, slides, $wrapperEl, slidesSizesGrid, $
      } = swiper;
      const params = swiper.params.coverflowEffect;
      const isHorizontal = swiper.isHorizontal();
      const transform$$1 = swiper.translate;
      const center = isHorizontal ? -transform$$1 + (swiperWidth / 2) : -transform$$1 + (swiperHeight / 2);
      const rotate = isHorizontal ? params.rotate : -params.rotate;
      const translate = params.depth;
      // Each slide offset from center
      for (let i = 0, length = slides.length; i < length; i += 1) {
        const $slideEl = slides.eq(i);
        const slideSize = slidesSizesGrid[i];
        const slideOffset = $slideEl[0].swiperSlideOffset;
        const offsetMultiplier = ((center - slideOffset - (slideSize / 2)) / slideSize) * params.modifier;

         let rotateY = isHorizontal ? rotate * offsetMultiplier : 0;
        let rotateX = isHorizontal ? 0 : rotate * offsetMultiplier;
        // var rotateZ = 0
        let translateZ = -translate * Math.abs(offsetMultiplier);

         let translateY = isHorizontal ? 0 : params.stretch * (offsetMultiplier);
        let translateX = isHorizontal ? params.stretch * (offsetMultiplier) : 0;

         // Fix for ultra small values
        if (Math.abs(translateX) < 0.001) translateX = 0;
        if (Math.abs(translateY) < 0.001) translateY = 0;
        if (Math.abs(translateZ) < 0.001) translateZ = 0;
        if (Math.abs(rotateY) < 0.001) rotateY = 0;
        if (Math.abs(rotateX) < 0.001) rotateX = 0;

         const slideTransform = `translate3d(${translateX}px,${translateY}px,${translateZ}px)  rotateX(${rotateX}deg) rotateY(${rotateY}deg)`;

         $slideEl.transform(slideTransform);
        $slideEl[0].style.zIndex = -Math.abs(Math.round(offsetMultiplier)) + 1;
        if (params.slideShadows) {
          // Set shadows
          let $shadowBeforeEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-left') : $slideEl.find('.swiper-slide-shadow-top');
          let $shadowAfterEl = isHorizontal ? $slideEl.find('.swiper-slide-shadow-right') : $slideEl.find('.swiper-slide-shadow-bottom');
          if ($shadowBeforeEl.length === 0) {
            $shadowBeforeEl = swiper.$(`<div class="swiper-slide-shadow-${isHorizontal ? 'left' : 'top'}"></div>`);
            $slideEl.append($shadowBeforeEl);
          }
          if ($shadowAfterEl.length === 0) {
            $shadowAfterEl = swiper.$(`<div class="swiper-slide-shadow-${isHorizontal ? 'right' : 'bottom'}"></div>`);
            $slideEl.append($shadowAfterEl);
          }
          if ($shadowBeforeEl.length) $shadowBeforeEl[0].style.opacity = offsetMultiplier > 0 ? offsetMultiplier : 0;
          if ($shadowAfterEl.length) $shadowAfterEl[0].style.opacity = (-offsetMultiplier) > 0 ? -offsetMultiplier : 0;
        }
      }

       // Set correct perspective for IE10
      if (swiper.support.pointerEvents || swiper.support.prefixedPointerEvents) {
        const ws = $wrapperEl[0].style;
        ws.perspectiveOrigin = `${center}px 50%`;
      }
    },
    setTransition(duration) {
      const swiper = this;
      swiper.slides
        .transition(duration)
        .find('.swiper-slide-shadow-top, .swiper-slide-shadow-right, .swiper-slide-shadow-bottom, .swiper-slide-shadow-left')
        .transition(duration);
    }
  }
}

My Slide:

          <ion-slides class="swiper-container ios slides-ios hydrated swiper-container-initialized swiper-container-horizontal" pager="false" style="cursor: grab;" [options]="slideOpts">
                <!---->

                <div class="swiper-wrapper">
                    <ion-slide class="ios swiper-slide swiper-zoom-container hydrated swiper-slide-next">
                        <ion-card class="food-main-h-card food-card2 slide-left ios hydrated">
                            <div class="food-card2-bg ion-text-uppercase" style="background-image: url(&quot;https://images.pexels.com/photos/772513/pexels-photo-772513.png?auto=compress&amp;cs=tinysrgb&amp;dpr=3&amp;h=750&amp;w=1260&quot;);">
                                <h2 class="card2-title"> </h2>
                            </div>
                        </ion-card>
                    </ion-slide>
                    <ion-slide class="ios swiper-slide swiper-zoom-container hydrated swiper-slide-next">
                        <ion-card class="food-main-h-card food-card2 slide-left ios hydrated">
                            <div class="food-card2-bg ion-text-uppercase" style="background-image: url(&quot;https://images.pexels.com/photos/772513/pexels-photo-772513.png?auto=compress&amp;cs=tinysrgb&amp;dpr=3&amp;h=750&amp;w=1260&quot;);">
                                <h2 class="card2-title"> </h2>
                            </div>
                        </ion-card>
                    </ion-slide>
                    <ion-slide class="ios swiper-slide swiper-zoom-container hydrated swiper-slide-next">
                        <ion-card class="food-main-h-card food-card2 slide-left ios hydrated">
                            <div class="food-card2-bg ion-text-uppercase" style="background-image: url(&quot;https://images.pexels.com/photos/772513/pexels-photo-772513.png?auto=compress&amp;cs=tinysrgb&amp;dpr=3&amp;h=750&amp;w=1260&quot;);">
                                <h2 class="card2-title"> </h2>
                            </div>
                        </ion-card>
                    </ion-slide>
                    <ion-slide class="ios swiper-slide swiper-zoom-container hydrated swiper-slide-next">
                        <ion-card class="food-main-h-card food-card2 slide-left ios hydrated">
                            <div class="food-card2-bg ion-text-uppercase" style="background-image: url(&quot;https://images.pexels.com/photos/772513/pexels-photo-772513.png?auto=compress&amp;cs=tinysrgb&amp;dpr=3&amp;h=750&amp;w=1260&quot;);">
                                <h2 class="card2-title"> </h2>
                            </div>
                        </ion-card>
                    </ion-slide>
                </div>
            </ion-slides>

1 post - 1 participant

Read full topic


Viewing all articles
Browse latest Browse all 49083

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>