是否启用Webrtc

插件提供了两种截图模式: webrtc 和 html2canvas 。通过enableWebRtc属性来控制,值为boolean类型,值为false则使用html2canvas来截图。

import ScreenShot from "js-web-screen-shot";

const config = { enableWebRtc: false }
const screenShotHandler = new ScreenShot(config);

注意:html2canvas模式虽然没有授权弹窗,但是它的样式兼容性比较差,不支持iframe、video、svg元素,在某些组件库中使用时可能会出现样式不一致问题。

兼容移动端

插件对触屏设备做了兼容处理,如果你是pc端的触屏设备可以支持webrtc模式,如果是移动端那么就只能使用html2canvas模式。

import ScreenShot from "js-web-screen-shot";

const config = {
    enableWebRtc: false
};
const screenShotHandler = new ScreenShot(config);
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<!--禁止移动端浏览器的缩放-->
<meta name="viewport" content="user-scalable=no">
</head>
<body>
/body>
</html>

注意:在移动端使用时,需要在head标签里禁止浏览器的缩放行为,否则就会出现在使用撤销功能时,多次双击造成界面放大问题。

自定义屏幕流数据

在electron环境下使用时,需要通过传入screenFlow参数来确定屏幕流数据,并且enableWebRtc属性需要设置为false

import ScreenShot from "js-web-screen-shot";
import { getDesktopCapturerSource } from "xxx.ts";
import { getInitStream } from "yyy.ts";

// 这里返回的是设备上的所有窗口信息
const sources = await getDesktopCapturerSource();
// 这里可以对`sources`数组下面id进行判断
// 找到当前的electron窗口, 这里为了简单直接拿了第一个
const stream = await getInitStream(sources[0]);
const config = { enableWebRtc: true, screenFlow: stream!}
const screenShotHandler = new ScreenShot(config);

注意:这里只是演示了screenFlow属性的传入方式,具体的用法请移步:Electron中使用

截图回调函数

本章节将详细介绍插件所提供的多个回调函数,这些回调函数的存在大大增强了其可用性。以下将一一列举每个回调函数的使用方法,让你能更好地利用它们。

完成回调

工具栏最右侧的对号图标点击后会将图片的base64地址与裁剪信息回传给你定义的函数,通过传入completeCallback属性来获取回调函数返回的数据,如果不传的话则会将这些数据放到sessionStorage中。

import ScreenShot from "js-web-screen-shot";

const config = {
  completeCallback: ({ base64, cutInfo }) => {
    console.log(base64, cutInfo);
  }
};
const screenShotHandler = new ScreenShot(config);

// 如果没有指定回调函数的话,可以从sessionStorage中获取
// sessionStorage.getItem("screenShotImg");

如果需要在特定条件下销毁截图容器,请传入destroyComponents属性,并将其值设为false。

关闭回调

工具栏中的关闭按钮点击时,可以通过传入closeCallback属性定义函数进行拦截。

import ScreenShot from "js-web-screen-shot";

// 截图取消时的回调函数
const closeFn = ()=>{
  console.log("截图窗口关闭");
}

const config = {
  closeCallback: closeFn
};
const screenShotHandler = new ScreenShot(config);

响应回调

  • 使用html2canvas截屏时,页面图片过多时响应会较慢
  • 使用webrtc截屏时用户点了分享,该函数为响应完成后触发的事件

基于上述原因,插件提供了回调函数来告知调用者是否加载完成,只需传入triggerCallback参数即可,它的值是一个函数类型,回调中返回一个对象,类型为:

{
    code: number,
    msg: string,
    displaySurface: string | null,
    displayLabel: string | null
}
  • code为0时代表截图加载完成
  • displaySurface返回的的是当前选择的窗口类型
  • displayLabel返回的是当前选择的标签页标识,浏览器不支持时此值为null。
import ScreenShot from "js-web-screen-shot";

const config = {
  triggerCallback: ({code, msg, displaySurface, displayLabel}) => {
    // 在此处根据实际业务需要通过参数做判断即可
  }
};
const screenShotHandler = new ScreenShot(config);

取消分享回调

使用webrtc模式截屏时,用户点了取消或者浏览器不支持时所触发的事件。传入cancelCallback参数,它的值是一个函数类型,回调中返回一个对象,类型为:

{
    code: number,
    msg: string,
    errorInfo: string
}

code为-1时代表用户未授权或者浏览器不支持webrtc。

保存截图回调

工具栏中的保存按钮点击时触发此回调。传入saveCallback参数,其值是一个函数类型,回调中返回两个参数: codemsg。 code为0时代表保存成功。

import ScreenShot from "js-web-screen-shot";

const config = {
  saveCallback: (code, msg) => {
    // 在此处根据实际业务需要通过参数做判断即可
  }
};
const screenShotHandler = new ScreenShot(config);

截图容器层级

在实际使用时,截图容器的层级可能会低于项目内某个组件的层级。传入level参数,可调整层级。

import ScreenShot from "js-web-screen-shot";

const config = {
    level: 99999
};
const screenShotHandler = new ScreenShot(config);

截图容器销毁

默认情况下,点击工具栏的 确认截图 按钮时,截图容器会立即销毁。若需关闭此行为,请传入 destroyComponents 参数并将其值设为 false。

import ScreenShot from "js-web-screen-shot";

let screenShotHandler = null;
const config = {
    destroyContainer: false,
    completeCallback: ({ base64, cutInfo }) => {
      // todo: 在此处编写业务逻辑即可
      setTimeout(() => {
        // 4s后销毁截图容器
        plugin.destroyComponents();
      }, 4000)
    }})
};

screenShotHandler = new ScreenShot(config);

调整裁剪框颜色

在实际使用时,每个项目都有自己的设计风格。插件提供了cutBoxBdColor参数,可用来定义裁剪区域的边框像素点颜色,值为string类型。

import ScreenShot from "js-web-screen-shot";

const config = {
    cutBoxBdColor: "#A78BFA"
};
const screenShotHandler = new ScreenShot(config);

调整最大可撤销次数

画布上绘制的内容,默认只保留15步,超过后,最早的保存的内容将丢弃。你可以通过设置maxUndoNum参数来调整。

import ScreenShot from "js-web-screen-shot";

const config = {
    maxUndoNum: 30
};
const screenShotHandler = new ScreenShot(config);

是否使用等比例箭头

箭头绘制工具默认使用递增变粗的方式进行绘制,你可以通过useRatioArrow参数来调整。

import ScreenShot from "js-web-screen-shot";

const config = {
    useRatioArrow: true
};
const screenShotHandler = new ScreenShot(config);

调整画布尺寸

在某些情况下,默认的画布大小可能无法满足需求,你可以通过传入canvasWidthcanvasHeight属性来修改画布的尺寸来截取更多内容,值为number类型

import ScreenShot from "js-web-screen-shot";

const config = {
    canvasWidth: 1920    canvasHeight: 2100
};
const screenShotHandler = new ScreenShot(config);

调整容器位置

当页面内容很多时,滚动到了指定位置,需要在此处进行截图时,可以通过传入position属性来修改容器的位置,类型为:

{left?: number, top?: number}

示例代码如下:

import ScreenShot from "js-web-screen-shot";

const config = {
    position: { top: 500 }
};
const screenShotHandler = new ScreenShot(config);

单击截全屏

在真实项目中使用时,你可能希望通过单击鼠标左键就能对画布内的整个区域进行选取,可以通过传入clickCutFullScreen属性来修改实现,值为boolean类型,默认为false。

import ScreenShot from "js-web-screen-shot";

const config = {
    clickCutFullScreen: true
};
const screenShotHandler = new ScreenShot(config);

调整工具栏图标

某些情况下,你可能并不需要工具栏中提供的所有功能,可以传入hiddenToolIco参数来设置需要隐藏的图标,值为Object类型,默认为{}, 传你需要隐藏的图标名称,将值设为true即可,除关闭图标外,其他图标均可隐藏。可隐藏的key如下所示:

  • square 矩形绘制
  • round 圆形绘制
  • rightTop 箭头绘制
  • brush 涂鸦
  • mosaicPen 马赛克工具
  • text 文本工具
  • separateLine 分割线
  • save 下载图片
  • undo 撤销工具
  • confirm 保存图片
import ScreenShot from "js-web-screen-shot";

const config = {
    hiddenToolIco: {
      square: true,
      round: true,
      mosaicPen: true,
      save: true
    }
};
const screenShotHandler = new ScreenShot(config);

显示截图内容

截图组件加载完毕后,是否显示截图内容至canvas画布内,传入showScreenData属性来控制, 值为boolean类型,默认为false。

import ScreenShot from "js-web-screen-shot";

const config = {
    showScreenData: true
};
const screenShotHandler = new ScreenShot(config);

自定义画布右键事件

某些情况下,你可能需要禁止画布内的右键点击事件,只需传入customRightClickEvent属性即可,其值为Object类型,接受2个参数

  • state 是否拦截右键点击,值为boolean类型,默认为false。
  • handleFn 拦截后的事件处理函数,该属性为可选项,如果不传,默认行为是销毁组件。
import ScreenShot from "js-web-screen-shot";

const config = {
    customRightClickEvent: {
      state: true,
      handleFn: () => {
         // 自定义右键事件
      }
    }
};
const screenShotHandler = new ScreenShot(config);

自定义截图内容

如果你已经通过其他方式获取到了屏幕内容(例如electron环境),那么可以通过imgSrc属性将获取到的内容传入,此时插件将使用你传进来的图片,值为string类型(可以为图片url地址或者base64),默认为null。

import ScreenShot from "js-web-screen-shot";

const config = {
    imgSrc: "",
    enableWebRtc: false
};
const screenShotHandler = new ScreenShot(config);

注意:自定义截图内容时,一定要关闭webrtc模式,否则不会生效。

开启图片自适应

当你传入 imgSrc 参数时,默认情况下图片在画布上的展示并不会铺满,如果你需要图片以自适应的形式铺满画布,则需要传入imgAutoFit参数来实现,默认值为false

import ScreenShot from "js-web-screen-shot";

const config = {
    imgSrc: "",
    enableWebRtc: false,
    imgAutoFit: true
};
const screenShotHandler = new ScreenShot(config);

加载跨域图片

使用html2canvas模式进行截图时,如果出现了图片区域是空白的情况,你可以尝试传入loadCrossImgproxyUrl属性,开启跨域资源的加载以及代理服务器地址的设置。

import ScreenShot from "js-web-screen-shot";

const config = {
    loadCrossImg: true,
    proxyUrl: ""
};
const screenShotHandler = new ScreenShot(config);

注意:loadCrossImg的类型是boolean类型,传入proxyUrl属性时,loadCrossImg的值必须为true。imgSrc是url时,如果图片资源跨域了,必须让图片服务器允许跨域才能正常加载。同样的loadCrossImg设置为true时,图片资源跨域了也需要让图片服务器允许跨域。

设置截图容器

使用html2canvas模式进行截图时,默认使用的是body作为容器,你可以通过传入screenShotDom属性,来指定容器,值为HTMLElement类型。

import ScreenShot from "js-web-screen-shot";

const config = {
    screenShotDom: document.getElementById("app")
};
const screenShotHandler = new ScreenShot(config);

初始化裁剪框

在某些使用场景中,你可能希望截图组件加载时能够设置一个初始区域,通过传入cropBoxInfo属性即可实现,值为{ x: number; y: number; w: number; h: number }类型,默认不加载。

import ScreenShot from "js-web-screen-shot";

const config = {
    cropBoxInfo: {x: 100, y: 300, w: 500, h: 500}
};
const screenShotHandler = new ScreenShot(config);

调整响应时长

使用webrtc模式进行截图时,默认的响应时间为500ms,如果你需要修改此响应时间可以通过传入wrcReplyTime属性来实现,值为number类型。

import ScreenShot from "js-web-screen-shot";

const config = {
    wrcReplyTime: 800
};
const screenShotHandler = new ScreenShot(config);

注意:响应时间如果设置的太小会出现截取内容为空的情况。

输入流图像裁剪

使用webrtc模式进行截图时,你可以通过传入wrcImgPosition对捕获到的图像进行裁剪,值为{ x: number; y: number; w: number; h: number }类型,默认不裁剪。

import ScreenShot from "js-web-screen-shot";

const config = {
    wrcImgPosition: {x: 12, y: 20, w:1920, h: 1080}
};
const screenShotHandler = new ScreenShot(config);

截图容器可滚动

默认情况下,截图容器是可以滚动的,你可以通过传入noScroll属性来调整,值为boolean类型。

import ScreenShot from "js-web-screen-shot";

const config = {
    noScroll: false
};
const screenShotHandler = new ScreenShot(config);

调整蒙层颜色

在某些场景下,可能需要对截图容器的蒙层颜色进行调整,你可以通过传入maskColor属性来实现,值为{ r: number; g: number; b: number; a: number }类型,默认颜色为:{ r: 0; g: 0; b: 0; a: 0.6 }

import ScreenShot from "js-web-screen-shot";

const config = {
    maskColor: { r: 12; g: 0; b: 55; a: 0.6 }
};
const screenShotHandler = new ScreenShot(config);

调整工具栏展示位置

工具栏的默认展示位置是居中于截图容器的,你可以通过传入toolPosition属性来修改,值为string类型。提供三个选项:left左对齐于裁剪框,center居中对齐于裁剪框,right右对齐于裁剪框。

import ScreenShot from "js-web-screen-shot";

const config = {
    toolPosition: "left"
};
const screenShotHandler = new ScreenShot(config);

关闭剪切版写入

默认情况下完成截图时,内容会被写入剪切版,你可以通过传入writeBase64属性来修改,值为boolean类型。

import ScreenShot from "js-web-screen-shot";

const config = {
    writeBase64: false
};
const screenShotHandler = new ScreenShot(config);

启用窗口截图模式

默认情况下使用当前标签页进行截图,如果标签页截图的内容有滚动条或者底部有空缺,可以考虑启用此模式。传入wrcWindowMode属性来修改,值为boolean类型。

import ScreenShot from "js-web-screen-shot";

const config = {
    wrcWindowMode: true
};
const screenShotHandler = new ScreenShot(config);

除了启用窗口模式进行截图外,你还可以传入hiddenScrollBar参数来隐藏滚动条,值为Object类型,有5个属性:

  • state: boolean 启用状态, 默认为false
  • fillState?: boolean 填充状态,默认为false
  • color?: string 填充层颜色,滚动条隐藏后可能会出现空缺,需要进行填充,默认填充色为黑色。
  • fillWidth?: number 填充层宽度,默认为截图容器的宽度
  • fillHeight?: number 填充层高度,默认为空缺区域的高度
import ScreenShot from "js-web-screen-shot";

const config = {
    hiddenScrollBar: {
      state: true,
      fillState: true,
      color: "#FFFFFF"
    }
};
const screenShotHandler = new ScreenShot(config);

注意:使用当前标签页进行截图相对而言用户体验是最好的,但是因为chrome 112版本的bug会造成页面内容挤压导致截取到的内容不完整,因此只能采用其他方案来解决此问题了。wrcWindowMode和hiddenScrollBar都可以解决这个问题。

  • wrcWindowMode方案会更完美些,但是用户授权时会出现其他的应用程序选项,用户体验会差一些
  • hiddenScrollBar方案还是采用标签页截图,但是会造成内容挤压,底部出现空白。

两种方案的优点与缺点讲完了,最好的办法还是希望chrome能在之后的版本更新中修复此问题。

额外提供的API

插件暴露了一些内部变量出来,便于调用者根据自己的需求进行修改。

  • getCanvasController 该函数用于获取截图容器的DOM,返回值为HTMLCanvasElement类型。如果截图容器尚未加载完毕,获取到的内容可能为null。

示例代码:

import ScreenShot from "js-web-screen-shot";

const screenShotHandler = new ScreenShot();
const canvasDom = screenShotHandler.getCanvasController();
  • destroyComponents 该函数用于销毁截图容器,无返回值。

示例代码:

import ScreenShot from "js-web-screen-shot";

const screenShotHandler = new ScreenShot();
screenShotHandler.destroyComponents()
  • completeScreenshot 该函数用于将框选区域的截图内容写入剪切版,无返回值。 该方法可以跟cropBoxInfo参数结合起来实现指定位置的自动截图,截图内容默认写入剪切版内,如果你想拿到截取到的base64内容可以通过completeCallback参数拿到,或者直接从sessionStorage中获取。

该回调函数中返回的参数格式如下所示:

  • base64
  • cutInfo 裁剪框位置参数
    • startX
    • startY
    • width
    • height

示例代码:

import ScreenShot from "js-web-screen-shot";

const plugin = new ScreenShot({
  clickCutFullScreen: true,
  wrcWindowMode: true,
  cropBoxInfo: { x: 350, y: 20, w: 300, h: 300 },
  completeCallback: ({ base64, cutInfo }) => {
    console.log(base64, cutInfo);
  },
  triggerCallback: () => {
    // 截图组件加载完毕调用此方法来完成框选区域的截图
    plugin.completeScreenshot();
  }
});

快捷键监听

截图容器监听了三个快捷键,如下所示:

  • Esc,按下键盘上的esc键时,等同于点了工具栏的关闭图标。
  • Enter,按下键盘上的enter键时,等同于点了截图工具栏的确认图标。
  • Ctrl/Command + z按下这两个组合键时,等同于点了截图工具栏的撤销图标。

工具栏图标定制

如果你需要修改截图工具栏的图标,可以通过覆盖元素css类名的方式实现,插件内所有图标的css类名如下所示:

  • square 矩形绘制图标
  • round 圆形绘制图标
  • right-top 箭头绘制图标
  • brush 画笔工具
  • mosaicPen 马赛克工具
  • text 文本工具
  • save 保存
  • close 关闭
  • undo 撤销
  • confirm 确认

square为例,要修改它的图标,只需要将下述代码添加进你项目代码的样式中即可。

  .square {
    background-image: url("你的图标路径") !important;

    &:hover {
      background-image: url("你的图标路径") !important;
    }

    &:active {
      background-image: url("你的图标路径") !important;
    }
 }