npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@huteming/util-canvas-draw

v4.0.0

Published

封装 canvas 方法,便于画图导出图片

Downloads

3

Readme

封装 canvas 方法,便于画图导出图片


例子

CanvasDraw 为构造函数。主要是解决了 canvas 在不同分辨率中显示可能模糊的问题。并封装了一些原生方法,方便调用

import { CanvasDraw } from '@huteming/util'
const instance = new CanvasDraw(375, 500)

instance.onerror(console.error)
instance.add(({ context, canvas, ratio, width, height }) => {
    instance.drawText('hello world', 24, 93)
})

const src = instance.done()

构造函数参数

| name | 描述 | 默认参数 | |------|--------|-------| | width | 设计稿上画布宽度 | | | height | 设计稿上画布高度 | | | optionsCanvas | 配置 | |

实例方法

| name | 描述 | 参数 | |------|--------|-------| | add | 执行callback前后分别执行 save, restore 方法 | Function: callbackDraw({ context, canvas, ratio, width, height }) | | onerror | 异常处理.默认为 console.error | Error | | done | 导出图片 | Object: optionsDone |

| name | 描述 | 参数 | |------|--------|-------| | drawArc | 圆形 | x, y, r, optionsArc | | drawRect | 矩形 | x, y, width, height, optionsRect | | drawText | 文本 | text, x, y, optionsText | | drawLine | 直线 | startX, startY, endX, endY, optionsLine | | drawImage | 图片 | image, x, y, width, height |

optionsDone

| 参数 | 描述 | 默认值 | |----------|----------|-----------| | type | 导出图片类型 | png |

optionsCanvas

| name | 描述 | 默认值 | |------|--------|-------| | designWidth | 设计稿标准总宽度 | 750 |

optionsArc

| 参数 | 描述 | 默认值 | |-------|----------|---------| | startDegrees | 开始角度 | 0 | | endDegrees | 结束角度 | 360 | | direction | 方向。false: 顺时针, true: 逆时针 | false | | lineWidth | 画笔宽度 | 1 | | color | 画笔颜色 | #000 | | type | 画笔类型, fill, stroke | fill |

optionsRect

| 参数 | 描述 | 默认值 | |-------|----------|---------| | r | 圆角半径 | 0 | | lineWidth | 画笔宽度 | 1 | | color | 画笔颜色 | #000 | | type | 画笔类型, fill, stroke | fill |

optionsText

| 参数 | 描述 | 默认值 | |-------|----------|---------| | prefix | 前缀 | | | suffix | 后缀 | | | fix | 过长省略时添加字符串 | '.... ' | | maxWidth | 最长宽度,会在末尾加上 fix 字符串,一般搭配前缀 后缀使用 | 0 | | style | 字体的风格 normal, italic, oblique | normal | | variant | 字体变体 normal, small-caps | normal | | weight | 字体的粗细 bold bolder lighter 100 200 300 400 500 600 700 800 900 | normal | | size | 字号 | 12 | | lineHeight | 行高 | 1 | | align | 对齐方式 start, end, center, left, right | start | | baseline | 文本基线, alphabetic, top, hanging, middle, ideographic, bottom | top | | baseline | 文本基线, alphabetic, top, hanging, middle, ideographic, bottom | top | | lineWidth | 画笔宽度 | 1 | | color | 画笔颜色 | #000 | | type | 画笔类型, fill, stroke | fill |

optionsLine

| 参数 | 描述 | 默认值 | |-------|----------|---------| | lineWidth | 画笔宽度 | 1 | | color | 画笔颜色 | #000 |