Update 1.2.0:
1- Change js to ts
2- Add createTriangle
3- Add addFontFamily
4- Fix some mistakes
Compiling
If you want to know the details, go here
OS |
Command |
OS X |
Using Homebrew:
brew install pkg-config cairo pango libpng jpeg giflib librsvg pixman
|
Ubuntu |
sudo apt-get install build-essential libcairo2-dev libpango1.0-dev libjpeg-dev libgif-dev librsvg2-dev |
Fedora |
sudo yum install gcc-c++ cairo-devel pango-devel libjpeg-turbo-devel giflib-devel |
Solaris |
pkgin install cairo pango pkg-config xproto renderproto kbproto xextproto |
OpenBSD |
doas pkg_add cairo pango png jpeg giflib |
Windows |
See the wiki
|
Others |
See the wiki
|
Install
npm install canvas-form --save
const { Forms } = require("canvas-form");
let form = new Forms();
Values
Key |
Type |
createCircle |
method |
createText |
method |
createImages |
method |
createLine |
method |
createRect |
method |
createRhombus |
method |
createStar |
method |
createTriangle |
method |
setCanvasSize |
method |
toBuffer |
method |
toSave |
method |
addFontFamily |
method |
Canvas |
prototype |
canvas |
prototype |
ctx |
prototype |
Rect
let rect = form.createRect(/* options: RectOptions */);
rect.draw({x:200, y:100, color:"blue", drawType:"stroke"})
rect.draw({x:500, y:100, height:110, width:110});
data:image/s3,"s3://crabby-images/c8d8f/c8d8ff282333b23d8f445caf8927a07e69e63617" alt="Rect"
Circle
let circle = form.createCircle(/* options: CircleOptions */);
circle.draw({x:200, y:100, color:"blue", drawType:"stroke"});
circle.draw({x:500, y:100, radius:60});
data:image/s3,"s3://crabby-images/4999b/4999bc4f3943b33dd3257c555fa3a8f0d0e373ff" alt="Circle"
Text
let text = form.createText(/* options: TextOptions */);
text.draw({x:200, y:100, color:"blue", drawType:"stroke", text:"Hello"});
text.draw({x:500, y:100, text:"Hi", fontFamily:"Impact", size:60, textAlign:"left", width:70});
data:image/s3,"s3://crabby-images/55b0f/55b0fae6a307e1631d82eb1d6d7b4f3610fabed3" alt="Text"
Line
let line = form.createLine(/* options: LineOptions */);
line.draw({x:200, y:100, endX:450, endY:100, color:"blue", lineWidth:3});
line.draw({x:200, y:150, endX:450, endY:150, lineWidth:5});
data:image/s3,"s3://crabby-images/1af6f/1af6f7db034fc5b5fad9f41f63ffd3ecd55ea9c5" alt="Line"
Rhombus
let rhombus = form.createRhombus(/* options: RhombusOptions */);
rhombus.draw({x:200, y:200, color:"blue", drawType:"stroke"});
rhombus.draw({x:500, y:200, height:80 ,width:90});
data:image/s3,"s3://crabby-images/c3771/c3771b923d4582920af1b56714ca6c5deec57eea" alt="Rhombus"
Star
let star = form.createStar(/* options: StarOptions */);
star.draw({x:200, y:100, color:"blue", drawType:"stroke"});
star.draw({x:500, y:100, spikes:9, innerRadius:20, outerRadius:30});
data:image/s3,"s3://crabby-images/27145/271455f9a60531a2344b0497116d0cf7670aabe1" alt="Star"
Image
let image = form.createImage(/* options: ImageOptions */);
image.draw({x:200, y:500, height:120, width:120, path:"https://cdn.discordapp.com/attachments/716228498825412690/987695097107873792/unknown.png"}).then(async img=>
{
await image.draw({x:400, y:500, isCircle:true, radius:60, path:"https://cdn.discordapp.com/attachments/716228498825412690/987695097107873792/unknown.png"});
await img.draw({x:600, y:500, height:100, width:100, path:"https://cdn.discordapp.com/attachments/716228498825412690/987695097107873792/unknown.png"});
await img.draw({x:800, y:500, isCircle:true, radius:50, path:"https://cdn.discordapp.com/attachments/716228498825412690/987695097107873792/unknown.png"});
});
data:image/s3,"s3://crabby-images/89c1b/89c1bd5b63e8b834a8f533e7f02d061a292a1e1e" alt="Image"
Triangle
let triangle = form.createTriangle(/* options: TriangleOptions */);
triangle.draw({x:200, y:100, color:"red"});
triangle.draw({x:300, y:100, color:"blue", drawType:"stroke"});
triangle.draw({x:400, y:100, color:"green", rotate:70});
triangle.draw({x:200, y:200, color:"yellow", sideAB: 20, sideAC: 10});
triangle.draw({x:300, y:200, color:"pink", sideBC: 50, rotate:20});
data:image/s3,"s3://crabby-images/f5bb1/f5bb138069c3a1a91c6f513ffad6688485aaa979" alt="Triangle"
Font Family
Warning
If you use windows os you must add font family in your windows before use addFontFamily
// Add new Font Family
form.addFontFamily(/* path: string, setName: string, options?: {style?: string, weight?: string} */) // You can add any name in setName
for examlpe:
form.addFontFamily("./Halimun.ttf","Halimun");
let text = form.createText();
text.draw({x:200, y:100, text:"Hello", fontFamily:"Halimun"});
text.draw({x:500, y:100, text:"Hello", fontFamily:"Impact"});
data:image/s3,"s3://crabby-images/a0cf9/a0cf988161c93ed315497c42bcd1d36dfc0ca220" alt="font family"
Canvas size
// change size canvas
form.setCanvasSize(height, width) // default height = 1920, width = 1080
Other method
// save Image
form.toSave(path, type); // path = "save local device without .", type = "png" | "jpeg"
// convert to Buffer
form.toBuffer() // return Buffer
One example in detail
form.createRect(/*options*/).draw({x:500, y:100, color:"red"}).draw({x:700, y:100, color:"red"}).draw({x:900, y:100, color:"red"});
OR
form.createRect({y:100, color:"red"}).draw({x:500}).draw({x:700}).draw({x:900});
OR
let rect = form.createRect(/*options*/);
rect.draw({x:500, y:100, color:"red"});
rect.draw({x:700, y:100, color:"red"});
rect.draw({x:900, y:100, color:"red"});
OR
let rect = form.createRect({color:"red", y:100});
rect.draw({x:500});
rect.draw({x:700});
rect.draw({x:900});
data:image/s3,"s3://crabby-images/98777/987778b7aa58c833182f96648b6a9c4335a9c716" alt="draws"
Options
RectOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
drawType draw
|
String |
fill |
width |
Number |
100 |
height |
Number |
100 |
CircleOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
drawType draw
|
String |
fill |
radius |
Number |
50 |
TextOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
drawType draw
|
String |
fill |
width |
Number |
100 |
text |
String |
null |
size |
Number |
50 |
fontFamily |
String |
Arial |
LineOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
lineWidth |
Number |
1 |
endX |
Number |
50 |
endY |
Number |
50 |
RhombusOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
drawType draw
|
String |
fill |
width |
Number |
100 |
height |
Number |
100 |
lineWidth |
Number |
1 |
StarOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
drawType draw
|
String |
fill |
lineWidth |
Number |
1 |
spikes |
Number |
5 |
outerRadius |
Number |
30 |
innerRadius |
Number |
15 |
ImageOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
width |
Number |
100 |
height |
Number |
100 |
path |
String |
null |
TriangleOptions
Key |
Type |
Default |
x |
Number |
0 |
y |
Number |
0 |
color |
String |
black |
drawType draw
|
String |
fill |
sideAB? |
number |
0 |
sideAC? |
number |
0 |
sideBC? |
number |
0 |
rotate? |
number |
0 |