-
Notifications
You must be signed in to change notification settings - Fork 210
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
Additional per-module image pass-through tests #1
Conversation
c214e21
to
3d43ece
Compare
OK, I'm pretty close here. The issue is that in nodejs, there's no native JavaScript Image class, so we're working with, for example, the $ var img = new Image()
$ img.onload = function() { console.log('LOADED!') }
$ img.src = "DATA URL HERE"
$ img.src
> "" Basically it doesn't let me assign This does work in a browser, and is essentially what we're trying to do here: https://github.com/publiclab/image-sequencer/blob/master/src/modules/ImageThreshold.js#L29-L33 I also tried doing: img.src = new Buffer("DATA URL HERE", "base64"); Since that's how @ccpandhare - any ideas about how to approach this? I'm looking through various other Also, more docs on |
@jywarren I'll have a look at this and let you know. |
@jywarren I had a look at the node-canvas documentation. I found out that
So I don't understand why img.src is giving an error. Am I missing out something here? |
That's my question too -- haha. Yes, if you start a console with `node`,
and use `require('canvas')` and go through these steps, you'll see that
after assigning `img.src`, then logging its value out, it comes out as ""
(at least it does for me). I'm not sure why that happens, and am trying to
find a way around it.
One thought I had was to draw it to a canvas and then get a data-url back
out, but that seems very inefficient! Or to find another image class that's
not from `node-canvas` and see if it implements things differently. I mean,
`node-canvas` mostly implemented it in order to make it possible to put
things on canvases, not as a general-purpose Image class. So perhaps they
just skipped some part of the native browser Image API since they didn't
need it. We might have better luck with more general-purpose implementation
of Image.
Thanks!
…On Mon, Mar 13, 2017 at 12:53 PM, Chinmay Pandhare (CCD) < ***@***.***> wrote:
@jywarren <https://github.com/jywarren> I had a look at the node-canvas
documentation.
Sorry, I got a bit late on doing that.
I found out that node-canvas does support the src.
This is a piece of code from the documentation:
var Canvas = require('canvas')
, Image = Canvas.Image
, canvas = new Canvas(200, 200)
, ctx = canvas.getContext('2d')
, fs = require('fs');
fs.readFile(__dirname + '/images/squid.png', function(err, squid){
if (err) throw err;
img = new Image;
img.src = squid;
ctx.drawImage(img, 0, 0, img.width / 4, img.height / 4);
});
So I don't understand why img.src is giving an error. Am I missing out
something here?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AABfJxNM2GK6TQvYSGbFGZddgW4H0Yb4ks5rlXRygaJpZM4MTKnG>
.
|
I was able to run this on my local machine successfully:
Earlier I was getting an unexpected token error, but that was because the string was in multiline. Output
|
@jywarren I was playing around with this, and realized that the I don't think the issue is with |
Also, I couldn't understand why the Travis CI Build is failing. Could you please explain that? |
Hmm, but my question was about when you assign |
The travisCI build is failing i believe because in includes tests for several modules to check that they accept an image and produce an image, but one of them is failing due to this non-browser |
Yes, I saw that. That's really odd. We needn't trigger something for that to happen.
This returns an error beacuse at the point of drawing img has 'not loaded'. So, maybe, similarly:
when the src attribute is added, Is that the case, @jywarren ? |
If I were running it in a saved script that would make sense but I ran it
sequentially, manually in a console, waiting plenty of time between each
step. But maybe it doesn't expect me to do that? What if we ran the canvas
command in between -- would that trigger the onload or something? I think
maybe we're using it in an unexpected way (to the original author).
…On Mar 14, 2017 11:27 AM, "Chinmay Pandhare (CCD)" ***@***.***> wrote:
Hmm, but my question was about when you assign img.src, then you enter
img.src in the console, it returns an empty string, even though we just
assigned it a value. Do you think we need to trigger something besides just
assigning the value?
Yes, I saw that. That's really odd. We needn't trigger something for that
to happen.
Just a thought though:
img = new Image()
ctx.drawImage(img,...)
This returns an error beacuse at the point of drawing img has 'not loaded'.
So, maybe, similarly:
img = new Image()
img.src = "something"
when the src attribute is added, img has not loaded?
Is that the case, @jywarren <https://github.com/jywarren> ?
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AABfJ5QbhAy-fEIGzs79_q-V4XxDu1ySks5rlrHCgaJpZM4MTKnG>
.
|
You are right. Also, I went through and tried out a few other npm modules for images. |
OK, found some promising possible image lib replacements: Going to be trying them out while traveling. |
and looking at: |
Yes I think it's really hard to use just node-canvas. I'll also try to have
a look at the libs.
…On मंगळ, २१, मार्च २०१७, २३:०८ Jeffrey Warren ***@***.***> wrote:
and looking at:
zhangyuanwei/node-images#62
<zhangyuanwei/node-images#62>
zhangyuanwei/node-images#91
<zhangyuanwei/node-images#91>
—
You are receiving this because you were mentioned.
Reply to this email directly, view it on GitHub
<#1 (comment)>,
or mute the thread
<https://github.com/notifications/unsubscribe-auth/AT0xnOBkgHTY7GsGYdflxwwlfiCuDtPuks5roArQgaJpZM4MTKnG>
.
|
Aha - got a pure data url based image replacement, here: var Jimp = require('jimp');
var string = '';
console.log(string);
var regex = /^data:.+\/(.+);base64,(.*)$/;
var matches = string.match(regex);
var ext = matches[1];
var data = matches[2];
var buffer = new Buffer(data, 'base64');
Jimp.read(buffer, function(err,img) {
img.invert();
img.getBase64('image/png', function(err,_img) {
console.log(_img);
});
}); Here we echo out the 'before' image, read it in, invert it, and output the 'after' image, both as data-urls. Ok, so a few more issues; it's not super efficient to pass as data urls, but it is a guarantee of parse-ability by either commandline or browser. But I'm using Jimp, which has multiple means of outputting images. I think this can be used to replace the default Image class, and think we should perhaps write a wrapper class called This raises the question of whether we should require a native browser Image object as the API, since it's not standard on nodejs. For broad compatibility we could standardize on data urls, but that's not very efficient (although that's often done in using the Canvas API in browsers). We might also want to consider allowing image buffers, which could result in better performance on larger images, in some cases. @ccpandhare -- thoughts on this as a way forward? We could start by implementing on data-urls, and get it running in node and browser, then move forward with more optimization once it's basically working? |
Note that we could explore other options too, but JIMP seems pretty solid, described as https://github.com/zhangyuanwei/node-images is the only one that seems comparable from my search. |
Actually, it occurs to me that we may just be able to get everything to pass by either:
Actually i wonder if (2) is just what |
@jywarren Yes, Jimp is standalone and pretty solid, and will have a better performance. I think we should consider using it after all!
Yes. I agree. we need a standard way of dealing with images. This would make the code much more clean and anyways, we are using 'isBrowser' at other places. Currently the functioning of image-sequencer is too browser-ish (for the lack of a better word). This would standardize things. |
I think that using |
@warren I was playing with
would be equivalent to:
Also, we wouldn't have to worry about the |
Looks like
This gives An error. (Error: mime must be a string) whereas with
works flawlessly.
Have a look at this: Jimp vs Sharp @jywarren What do you think? Am I doing something wrong in the Jimp implementation? |
I'm not sure if you're doing anything wrong, but if Sharp works for you, that's great. Do you want to try getting the basic tests in this PR running using Sharp, somehow? Not all the tests need to run, but just seeing that the system itself can be booted up in Nodejs would be great. I may have time to work on this in the coming week but I'm not sure. I really like how you show equivalent code for JIMP and browser Image implementations. That's what I'm thinking we might want to wrap in an Image adapter of some kind -- so modules don't have to think about whether it's inBrowser or not, and can use the Image adapter. Ideally it'd work the same as Image, but even if it doesn't, we could keep it as simple as possible. |
However, Sharp uses an external library -- any thoughts on the pros/cons of this? We could think about how to make it as easy as possible to use either JIMP or Sharp by having a very simple modular implementation. That might make the code more portable to different architectures. |
I am working on this. But firstly I need to have a look at |
Yes,
Possible disadvantages:
|
Should I close this now? |
OK, i'm closing it but opening a new issue requesting per-module image pass through tests: #29 |
No description provided.