欧美一区二区三区,国内熟女精品熟女A片视频小说,日本av网,小鲜肉男男GAY做受XXX网站

requestanimationframe正在阻止自定義光標& # 39;s轉(zhuǎn)變

阮建安2年前9瀏覽0評論

我正在使用一個定制的光標,它可以正常工作。

我還使用requestanimationframe來制作滾動屏幕的動畫。

但是當我使用requestanimationframe時,我的自定義光標在css中的過渡是滯后的。

React Js代碼

function App() {
  const [cursorX, setCursorX] = useState();
  const [cursorY, setCursorY] = useState();
  const [mouseIn, setMouseIn] = useState(true);
  const scrollWrapRef = useRef(null);
  const contentRef = useRef(null);
 
  let offset = 0;
  let currentPos = 0;

  useEffect(() => {
    const mouse = (e) => {
      setCursorX(e.clientX);
      setCursorY(e.clientY);
    };

    window.addEventListener("mousemove", mouse);

    const scrollWrap = scrollWrapRef.current;
    const content = contentRef.current;

    const smoothScroll = () => {
      offset += (window.pageYOffset - offset) * 0.04;
      const scroll = `translateY(-${offset}px) translateZ(0)`;
      scrollWrap.style.transform = scroll;
      requestAnimationFrame(smoothScroll);
    };

    smoothScroll();

    const callDistort = () => {
      const newPos = window.pageYOffset;
      const diff = newPos - currentPos;
      const speed = diff * 0.6;
      content.style.transform = `skewY(${speed}deg)`;
      currentPos = newPos;
      requestAnimationFrame(callDistort);
    };

    callDistort();

    return () => {
      cancelAnimationFrame(callDistort);
      cancelAnimationFrame(smoothScroll);
      window.removeEventListener("mousemove", mouse);
    };
  }, []);

  return (
    <div className="App ">
       // custom cursor 
        <div
          className={cursor}
          style={{
            left: cursorX,
            top: cursorY,
          }}
        ></div>

      <div ref={scrollWrapRef}>
        <div ref={contentRef} className="section">
              <Intro />
              <About />
              <Projects />
              <Work />
              <Contact />
        </div>
      </div>
    </div>
  );
}

使用的css

//custom cursor
.cursor {
  width: 20px;
  height: 20px;
  background: rgb(255, 255, 255);
  position: fixed;
  border-radius: 50%;
  mix-blend-mode: difference;
  pointer-events: none;
  z-index: 100;
  transform: translate(-50%, -50%);

  // it works only if I don't use requestanimationframe
  transition: 0.15s linear, transform 0.8s ease-in-out;

//Scroll animation
.section {
  position: relative;
  transform-style: preserve-3d;
  transform-origin: 0% 0%;
  transition: transform 0.25s;
  will-change: transform;
}

您可以檢查輸出

僅自定義光標

僅自定義光標屏幕錄制

https://noanimation.netlify.app/

滾動動畫和自定義光標

滾動動畫和自定義光標屏幕錄制

使用requestanimationframe https://requestanimationframereact.netlify.app/

如果我使用requestanimationframe,自定義光標轉(zhuǎn)換不流暢

請幫助我。