Base64decode from Ajax Request

Hello,

I am trying to get an image from runwayml : https://runwayml.com/
to create some basic examples patch on how to connect runway and cables together.

I started a patch here : https://cables.gl/edit/5e81c1cb193f7c05d380a10c

This basically the depth of focus example from the byte size tutorials (which are awesome btw). I want to get a depthTexture from runway by running the denseDepth model (which is able to create a depth map from a monocular webcam) and sending the result over http.

I do the ajax request right, because I get some results. The parsing also seems alright, but I cannot get an image texture out of the base64decode op, and I don’t really get why. Can somebody point me in the right direction ? or a way to troubleshoot this ?

Thanks !

Hi b2renger,

Super interesting post. I was not aware of runwayml. It looks awesome and could make cables an even more broad tool if it is connected. I don’t have an answer for you but was just excited to hear about it. The cable patch is private by the way so could not check it out. Keeping a close eye on this thread :slight_smile:

gr! Szann

@szann thanks for your answer.

I made the patch public so you can look it up.

The output of [stringNew2Old] is this base64 string :



And I get an error

onvaluechanged exception cought DOMException: "String contains an invalid character"

Hum I probably misread the documentation, and maybe I should use another object for this purpose.

The string I provided above does decode alright with online decoders.

Is the [base64Decode] only for strings or numbers ?

hey,

your string actually is a “data uri” that goes well into the “src” of an image-tag. so this
code might work as a userop for now (does for me, given your data):

// inputs
const dataIn = op.inStringEditor("data URI","");

// outputs
const textureOut = op.outTexture("Texture");

dataIn.onChange = () => {
    var image = new Image();
    image.onload=function(e)
    {
        var tex=CGL.Texture.createFromImage(op.patch.cgl,image,{});
        textureOut.set(tex);
    };
    image.src = dataIn.get();
}

just paste your data into the string editor, and receive the image as a texture-out.

hope that helps!

greetings,
stephan/steam

1 Like

@stephan thanks that is perfect !

I had began to try the user op way with the js Image, but I was definitely far from getting the texture the right.

Thank you very much again.

@stephan, @szann

FYI I uploaded a new patch with another custom op to make httpRequest at custom time intervals, here is the link : https://cables.gl/edit/YggTG4

I works pretty nicely with live runway :slight_smile: Thanks