-
-
Notifications
You must be signed in to change notification settings - Fork 3.5k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
support filters in to svg #1577
Comments
/cc @asturur |
taking a look. |
@kidzzz @kangax |
Creating |
Also there should be a 1:1 correspondence between filters you can create in fabric.js and filters in svg spec. There is no evidence that every filter will be supported by svg spec. There will be a subset of filter exportable and other not maybe. |
I appreciate all the comments. Such a great project and creators! "When we export to SVG we export the image eventually already filtered, but not any filter information" -- @asturur, are you saying the SVG should already have filters applied to the image? This is not what I am seeing. Please let me explain my situation: A user uploads a clip-art into the canvas, then he changes the background of the image to a different color. We achieve this by using the Multiply filter, so the JSON looks like this (Please note the image url isn't valid but I attach the clipart so you guys can test it out): {"objects":[{"type":"image","originX":"left","originY":"top","left":62,"top":60,"width":239,"height":298,"fill":"rgb(0,0,0)","stroke":null,"strokeWidth":1,"strokeDashArray":null,"strokeLineCap":"butt","strokeLineJoin":"miter","strokeMiterLimit":10,"scaleX":0.55,"scaleY":0.55,"angle":0,"flipX":false,"flipY":false,"opacity":1,"shadow":null,"visible":true,"clipTo":null,"backgroundColor":"","src":"http://xyz.com/clipart_sample.png","filters":[{"type":"Multiply","color":"rgb(252, 185, 19)"}],"crossOrigin":""}],"background":""} When I export the JSON to SVG, here is what I get (Please ignore the image path, I made it relative): <?xml version="1.0" encoding="UTF-8" standalone="no" ?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="244" height="362" xml:space="preserve"><desc>Created with Fabric.js 1.4.7</desc><defs></defs><g transform="translate(127.73 141.95) scale(0.55 0.55)"><image xlink:href="clipart_sample.png" style="stroke: none; stroke-width: 1; stroke-dasharray: ; stroke-linecap: butt; stroke-linejoin: miter; stroke-miterlimit: 10; fill: rgb(0,0,0); opacity: 1;" transform="translate(-119.5 -149)" width="239" height="298" preserveAspectRatio="none"></image></g></svg> So when I open this SVG file in Illustrator or IE, the background color of the clipart is not saved. Looking at the SVG string, I don't see anything indicating the Multiply filter has been applied. Hope I explain the problem well enough. Thanks a lot! |
Hey guys, Just want to see if you guys have a chance to take a look at the problem. Thanks! |
Image xlink:href is not supported at the moment, AFAIR, so we need to work on it. I'll get to it when I get time; right now still busy with work. |
mmmm so strange. with a dataurl you should solve. |
Okay guys. Thank you for the responses. |
i have some spare time i wanted to dedicate to fabricjs tonight. is there
|
Yes, I think everything is in this thread. You should be able to use the JSON and image to test the current toSVG() function. I also included a sample SVG output as a reference. Thank you! |
So i loaded the PNG of the crocodile.
Then i exported toSVG <?xml version="1.0" encoding="UTF-8" standalone="no" ?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" width="900" height="500" xml:space="preserve"><desc>Created with Fabric.js 1.4.11</desc><defs></defs><g transform="translate(341.5 267)">
<image xlink:href="" x="-119.5" y="-149" style="stroke: none; stroke-width: 1; stroke-dasharray: ; stroke-linecap: butt; stroke-linejoin: miter; stroke-miterlimit: 10; fill: rgb(0,0,0); fill-rule: source-over; opacity: 1;" width="239" height="298" preserveAspectRatio="none"></image>
</g>
</svg> That to our eyes is So, what is wrong? |
@asturur - No, nothing is wrong. I am totally aware toDataUrl() should work with the filter. I tried and it did work. It was not until @kangax mentioned filter export was not yet supported, I then realized the whole thing. What I am hoping to achieve is: <image xlink:href="clipart_sample.png" filter_information /> Since I am not familiar with image filters and their formats, I have not been able to write my own function to do the job. Any help in this regards is greatly welcome. And yes, I am running under nodejs. Thanks again. |
Hello,
I've using fabricjs for our own project. Works great!
I have an issue of converting canvas to SVG, particular with image filters. We use the Multiply filter, an example would be:
"filters":[{"type":"Multiply","color":"rgb(241, 93, 34)"}]
The current version of toSVG() doesn't support image filters in SVG format. We've looked around but have not been able to find a away to do this. We know where to modify the code but don't know how the format would look like. Any help is appreciated.
Thanks!
Want to back this issue? Post a bounty on it! We accept bounties via Bountysource.
The text was updated successfully, but these errors were encountered: