js实现鼠标跟随 3D 旋转动效

js实现鼠标跟随 3D 旋转动效

<div id="element"></div>
body {
        width: 100vw;
        height: 100vh;
        display: flex;
        transform-style: preserve-3d;
        perspective: 500px;
        cursor: pointer;
    }

    div {
        margin: auto;
        width: 200px;
        height: 200px;
        background: #000;
        transform-style: preserve-3d;
        transition: all .1s;
    }
const multiple = 10;
    const mouseOverContainer = document.getElementsByTagName("body")[0];
    const element = document.getElementById("element");

    function transformElement(x, y) {
    let box = element.getBoundingClientRect();
    let calcX = -(y - box.y - (box.height / 2)) / multiple;
    let calcY = (x - box.x - (box.width / 2)) / multiple;
    
    element.style.transform  = "rotateX("+ calcX +"deg) "
                            + "rotateY("+ calcY +"deg)";
    }

    mouseOverContainer.addEventListener('mousemove', (e) => {
    window.requestAnimationFrame(function(){
        transformElement(e.clientX, e.clientY);
    });
    });

    mouseOverContainer.addEventListener('mouseleave', (e) => {
    window.requestAnimationFrame(function(){
        element.style.transform = "rotateX(0) rotateY(0)";
    });
    });
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Android滑动半圆旋转动画的实现方法: 1.使用平移动画,只显示半圆: ```java // 获取ImageView控件 ImageView iv = findViewById(R.id.iv); // 设置ImageView为整个圆 iv.setImageResource(R.drawable.circle); // 移动一半位置到屏幕外面 iv.setTranslationX(-iv.getWidth() / 2); // 创建平移动画 ObjectAnimator translationAnimator = ObjectAnimator.ofFloat(iv, "translationX", 0f, -iv.getWidth() / 2); translationAnimator.setDuration(1000); // 创建旋转动画 ObjectAnimator rotationAnimator = ObjectAnimator.ofFloat(iv, "rotation", 0f, -180f); rotationAnimator.setDuration(1000); // 创建动画集合 AnimatorSet animatorSet = new AnimatorSet(); animatorSet.playTogether(translationAnimator, rotationAnimator); animatorSet.start(); ``` 2.使用属性动画,实现ImageView轮盘跟随RecyclerView滑动做旋转动画: ```java // 获取RecyclerView控件 RecyclerView recyclerView = findViewById(R.id.recyclerView); // 设置RecyclerView的滑动监听器 recyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrolled(@NonNull RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); // 获取ImageView控件 ImageView iv = findViewById(R.id.iv); // 计算旋转角度 float rotation = iv.getRotation() + dx; // 设置旋转动画 ObjectAnimator rotationAnimator = ObjectAnimator.ofFloat(iv, "rotation", iv.getRotation(), rotation); rotationAnimator.setDuration(0); rotationAnimator.start(); } }); ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值