MCPcopy
hub / github.com/qq15725/modern-screenshot

github.com/qq15725/modern-screenshot @v4.7.0 sqlite

repository ↗ · DeepWiki ↗ · release v4.7.0 ↗
110 symbols 291 edges 48 files 0 documented · 0%
README

modern-screenshot

Minzip Version Downloads Issues License

使用 HTML5 canvas 和 SVG 从 DOM 节点快速生成图像

Fork from html-to-image

English | 简体中文

📦 安装

npm i modern-screenshot

🦄 使用

import { domToPng } from 'modern-screenshot'

domToPng(document.querySelector('#app')).then(dataUrl => {
  const link = document.createElement('a')
  link.download = 'screenshot.png'
  link.href = dataUrl
  link.click()
})

CDN

<script src="https://unpkg.com/modern-screenshot"></script>
<script>
  modernScreenshot.domToPng(document.querySelector('body')).then(dataUrl => {
    const link = document.createElement('a')
    link.download = 'screenshot.png'
    link.href = dataUrl
    link.click()
  })
</script>

浏览器控制台

⚠️ 由于 CORS 部分嵌入将失败

```js const script = document.createElement('script') script.src = "https://unpkg.com/modern-screenshot" document.getElementsByTagName('head')[0].appendChild(script)

script.onload = () => { modernScreenshot .domToImage(document.querySelector('body'), { debug: true, progress: (current, total) => { console.log(${ current }/${ total }) } }) .then(img => { const width = 600 const height = img.height * (width / img.width) console.log('%c ', [ padding: 0 ${ width / 2 }px;, line-height: ${ height }px;, background-image: url('${ img.src }');, background-size: 100% 100%;, ].join('')) }) } ```

方法

method(node: Node, options?: Options)

DOM 转 dataURL

DOM 转 data

DOM 转 HTMLElement

选项

请查看 options.ts

单例上下文和 web worker

通过重用上下文和 web worker,每秒快速截图

// use vite
import workerUrl from 'modern-screenshot/worker?url'
import { createContext, destroyContext, domToPng } from 'modern-screenshot'

async function screenshotsPerSecond() {
  const context = await createContext(document.querySelector('#app'), {
    workerUrl,
    workerNumber: 1,
  })
  for (let i = 0; i < 10; i++) {
    domToPng(context).then(dataUrl => {
      const link = document.createElement('a')
      link.download = `screenshot-${ i + 1 }.png`
      link.href = dataUrl
      link.click()
      if (i + 1 === 10) {
        destroyContext(context)
      }
    })
    await new Promise(resolve => setTimeout(resolve, 1000))
  }
}

screenshotsPerSecond()

请查看 context.ts

待办事项

content: counter(step);

Extension points exported contracts — how you extend this code

Logger (Interface)
(no doc)
src/create-logger.ts
Request (Interface)
(no doc)
src/context.ts
LoadMediaOptions (Interface)
(no doc)
src/utils.ts
Options (Interface)
(no doc)
src/options.ts
InternalContext (Interface)
(no doc)
src/context.ts

Core symbols most depended-on inside this repo

isElementNode
called by 10
src/utils.ts
orCreateContext
called by 10
src/create-context.ts
createImage
called by 7
src/utils.ts
isImageElement
called by 6
src/utils.ts
onResolve
called by 6
src/utils.ts
isSVGElementNode
called by 5
src/utils.ts
isHTMLElementNode
called by 5
src/utils.ts
contextFetch
called by 5
src/fetch.ts

Shape

Function 105
Interface 5

Languages

TypeScript100%

Modules by API surface

src/utils.ts42 symbols
src/clone-node.ts5 symbols
src/change-png-dpi.ts5 symbols
src/embed-web-font.ts4 symbols
src/css-url.ts4 symbols
src/create-context.ts4 symbols
src/converts/dom-to-foreign-object-svg.ts4 symbols
src/image-to-canvas.ts3 symbols
src/get-diff-style.ts2 symbols
src/fetch.ts2 symbols
src/create-logger.ts2 symbols
src/copy-pseudo-class.ts2 symbols

Dependencies from manifests, versioned

@antfu/eslint-config3.8.0 · 1×
@types/glob8.1.0 · 1×
@vitest/ui2.1.4 · 1×
bumpp9.8.1 · 1×
conventional-changelog-cli5.0.0 · 1×
eslint9.14.0 · 1×
glob11.0.0 · 1×
happy-dom15.10.1 · 1×
lint-staged15.2.10 · 1×
puppeteer23.7.0 · 1×

For agents

$ claude mcp add modern-screenshot \
  -- python -m otcore.mcp_server <graph>

⬇ download graph artifact