纯js制作的3D滑动的环状旋转木马特效

所属分类: 网页特效-图片特效&上传    2024-10-26 09:57:03

纯js制作的3D滑动的环状旋转木马特效 ie兼容6
 查看演示  登录后下载 温馨提示
登录会员即可享受免费下载
 我要建站

纯js制作的3D滑动的环状旋转木马特效(共23个文件)

    • index.html

使用方法

"use strict";
const getTanFromDegrees = (deg) => Math.tan((deg * Math.PI) / 180);
const camera = document.querySelector(".camera");
const cameraHeight = camera.offsetHeight;
const swiper = document.querySelector(".swiper");
const swiperHeight = swiper.offsetHeight;
const dCarousel = document.querySelector(".d-carousel");
const dCarouselItems = dCarousel.children;
const dCarouselItemCount = dCarouselItems.length;
const dCarouselItemDeg = 360 / dCarouselItemCount;
const dCarouselItemTanDegHalf = Math.tan(getTanFromDegrees(dCarouselItemDeg / 2));
const dCarouselItemR = cameraHeight / 2 / dCarouselItemTanDegHalf;
dCarousel.style.setProperty("--d-carousel-item-r", `${dCarouselItemR}px`);
dCarousel.style.setProperty("--d-carousel-item-deg", `${dCarouselItemDeg}deg`);
Array.from(dCarouselItems).forEach((item, i) => item.style.setProperty("--i", `${i}`));
let swipeDeg = 0;
let previousDeltaY = 0;
let deltaYDelta = 0;
const manager = new Hammer.Manager(swiper);
const Pan = new Hammer.Pan({ threshold: 10 });
manager.add(Pan);
manager.on("pan", (e) => {
    const deltaY = e.deltaY;
    deltaYDelta = deltaY - previousDeltaY;
    previousDeltaY = deltaY;
    const direction = e.offsetDirection;
    if (direction === 8 || direction === 16) {
        const swipeDegDelta = (deltaYDelta / swiperHeight) * 360;
        swipeDeg -= swipeDegDelta;
        dCarousel.style.setProperty("--d-carousel-rotate-x", `${swipeDeg}deg`);
    }
    if (e.isFinal) {
        previousDeltaY = 0;
    }
});
const disableTouchMove = () => {
    document.body.addEventListener("touchmove", (e) => {
        e.preventDefault();
    }, { passive: false });
};
disableTouchMove();

站长提示:
1. 苦力吧素材官方QQ群:950875342
2. 平台上所有素材资源,需注册登录会员方能正常下载。
3. 会员用户积极反馈网站、素材资源BUG或错误问题,每次奖励2K币
4. PHP源码类素材,如需协助安装调试,或你有二次开发需求,可联系苦力吧客服。
5. 付费素材资源,需充值后方能下载,如有任何疑问可直接联系苦力吧客服
相关资源 / 图片特效&上传

jquery支持旋转的全屏弹出图片插件

一款支持360度旋转的弹出层插件,全屏响应式,非常实用。
  图片特效&上传
 7800  0

jquery上传图片剪裁插件

上传图片后即时预览到图片内容,带可控制的裁剪框,可自由调节裁剪大小。
  图片特效&上传
 2913  0

jquery带图片缩放和平移放大镜插件

一款jquery/HTML5图片缩放插件,当鼠标悬停和移动时,它可以缓速的放大和平移图片。
  图片特效&上传
 1719  0

jquery图片全屏自适应轮播特效代码

全屏自动切换轮播幻灯片特效,淡出淡入的切换动画效果,很实用。
  图片特效&上传
 7776  0

评论数(0) 回复有机会获得K币 用户协议

^_^ 还没有人评论,快来抢个沙发!
😀
  • 😀
  • 😊
  • 😂
  • 😍
  • 😑
  • 😷
  • 😵
  • 😛
  • 😣
  • 😱
  • 😋
  • 😎
  • 😵
  • 😕
  • 😶
  • 😚
  • 😜
  • 😭
发表评论