react-xiguan

import { useState } from 'react';
import html2canvas from 'html2canvas';

function $(id) {
  return document.getElementById(id);
}

function useXiguan(props) {
  //  xiguan  点击按钮
  // content 截屏内容载体
  // root 移动根容器
  // sucker 移动的圈
  const { xiguan, content, root, sucker } = props;
  const btn = $(xiguan);
  const con = $(content);
  const rt = $(root);
  const sur = $(sucker);
  const [px, setPx] = useState([]);
  const [centerpx, setCenterpx] = useState([]);
  // 截屏功能
  async function handlecanvas() {
    window.pageYOffset = 0;
    document.documentElement.scrollTop = 0
    document.body.scrollTop = 0
    return await html2canvas(rt,
      {
        width: rt.offsetWidth,
        height: rt.offsetHeight,
        scale: 1,
        removeContainer: true,
        useCORS: true, // 开启跨域
        scrollY: 0,
        scrollX: 0,
        logging: false,
        ignoreElements: (el) => {
          if (el.id === `${xiguan}`) {
            return true;
          }
          return false;
        }
      })
  }
  const onClick = () => {
    //  截屏并保存图像到canvas;
    clearMove();
    handlecanvas().then((canvas) => {
      const img = new Image();
      img.src = canvas.toDataURL('image/png');
      img.width = rt.offsetWidth;
      img.height = rt.offsetHeight;
      img.onload = function () {
        const ctx2 = con.getContext("2d");
        con.width = rt.offsetWidth;
        con.height = rt.offsetHeight;
        ctx2.drawImage(img, 0, 0);
      }
      img.onerror = function () {
          btn.click();
      }
      const rw = rt.offsetWidth;
      const rh = rt.offsetHeight;
      const rlt = rt.offsetLeft;
      const rtp = rt.offsetTop;
      const sw = 55;
      rt.onmousemove = function (e) {
        console.log('move');
        if (this.time && (Date.now() - this.time) < 16) return;
        this.time = Date.now();
        let [x, y] = [e.clientX - rlt, e.clientY - rtp];
        const ctx = con.getContext('2d');
        const pxData = ctx.getImageData(x - 11, y - 11, 11, 11)?.data || [];
        const px1 = [];
        const px2 = [];
        for (let i = 0; i < 121; i++) {
          let r = pxData[4 * i + 0];
          let g = pxData[4 * i + 1];
          let b = pxData[4 * i + 2];
          let a = pxData[4 * i + 3]
          if (i === 60) { // center data
            px2.push({
              r, g, b, a
            })
          }
          // round data
          px1.push({
            r, g, b, a
          })
        }
        //定义鼠标在glass的中心 ,最大宽度减去元素本身一半。
        x = x - sw;
        y = y - sw;
        if (x < - sw / 2) {
          x = - sw / 2;//用来判断在原点位置时x轴是否会溢出,这里是左边
        }
        if (y < - sw / 2) {
          y = - sw / 2;//用来判断在原点位置时y轴是否会溢出,这里是右边
        }

        let maxX = rw + sw;

        //定义glass在X轴可运动的最大范围
        if (x > maxX) {
          x = maxX; //如果大于,就让它等于
        }
        let maxY = rh + sw;
        //定义glass在Y轴可运动的最大范围
        if (y > maxY) {
          y = maxY; //如果大于,就让它等于
        }
        [sur.style.left, sur.style.top] = [x + "px", y + "px"];
        setPx(px1);
        setCenterpx(px2);
      }
    })
  }
  function clearMove() {
    rt.onmousemove = null;
  }
  return [onClick, px, centerpx, clearMove]

}

export default useXiguan;

 

import { useState } from 'react';
import html2canvas from 'html2canvas';

function $(id) {
  return document.getElementById(id);
}

function useXiguan(props) {
  //  xiguan  点击按钮
  // content 截屏内容载体
  // root 移动根容器
  // sucker 移动的圈
  const { xiguan, content, root, sucker } = props;
  const btn = $(xiguan);
  const con = $(content);
  const rt = $(root);
  const sur = $(sucker);
  const [px, setPx] = useState([]);
  const [centerpx, setCenterpx] = useState([]);
  // 截屏功能
  async function handlecanvas() {
    window.pageYOffset = 0;
    document.documentElement.scrollTop = 0
    document.body.scrollTop = 0
    return await html2canvas(rt,
      {
        width: rt.offsetWidth,
        height: rt.offsetHeight,
        scale: 1,
        removeContainer: true,
        useCORS: true, // 开启跨域
        scrollY: 0,
        scrollX: 0,
        logging: false,
        ignoreElements: (el) => {
          if (el.id === `${xiguan}`) {
            return true;
          }
          return false;
        }
      })
  }
  const onClick = () => {
    //  截屏并保存图像到canvas;
    clearMove();
    handlecanvas().then((canvas) => {
      const img = new Image();
      img.src = canvas.toDataURL('image/png');
      img.width = rt.offsetWidth;
      img.height = rt.offsetHeight;
      img.onload = function () {
        const ctx2 = con.getContext("2d");
        con.width = rt.offsetWidth;
        con.height = rt.offsetHeight;
        ctx2.drawImage(img, 0, 0);
      }
      img.onerror = function () {
          btn.click();
      }

      rt.onmousemove = function (e) {
        window.requestAnimationFrame(move.bind(null,e));
      }
    })
  }
  function move(e) {
    const rw = rt.offsetWidth;
    const rh = rt.offsetHeight;
    const rlt = rt.offsetLeft;
    const rtp = rt.offsetTop;
    const sw = 55;
    let [x, y] = [e.clientX - rlt, e.clientY - rtp];
    const ctx = con.getContext('2d');
    const pxData = ctx.getImageData(x - 11, y - 11, 11, 11)?.data || [];
    const px1 = [];
    const px2 = [];
    for (let i = 0; i < 121; i++) {
      let r = pxData[4 * i + 0];
      let g = pxData[4 * i + 1];
      let b = pxData[4 * i + 2];
      let a = pxData[4 * i + 3]
      if (i === 60) { // center data
        px2.push({
          r, g, b, a
        })
      }
      // round data
      px1.push({
        r, g, b, a
      })
    }
    //定义鼠标在glass的中心 ,最大宽度减去元素本身一半。
    x = x - sw;
    y = y - sw;
    if (x < - sw / 2) {
      x = - sw / 2;//用来判断在原点位置时x轴是否会溢出,这里是左边
    }
    if (y < - sw / 2) {
      y = - sw / 2;//用来判断在原点位置时y轴是否会溢出,这里是右边
    }

    let maxX = rw + sw;

    //定义glass在X轴可运动的最大范围
    if (x > maxX) {
      x = maxX; //如果大于,就让它等于
    }
    let maxY = rh + sw;
    //定义glass在Y轴可运动的最大范围
    if (y > maxY) {
      y = maxY; //如果大于,就让它等于
    }
    [sur.style.left, sur.style.top] = [x + "px", y + "px"];
    setPx(px1);
    setCenterpx(px2);
  }
  function clearMove() {
    rt.onmousemove = null;
  }
  return [onClick, px, centerpx, clearMove]

}

export default useXiguan;

 

posted @ 2020-07-24 10:39  悔创阿里-杰克马  阅读(141)  评论(0编辑  收藏  举报
求投食~(点图即可)