Salvar imagem no dropbox com dados da tela

Estou tentando gravar dados da tela como uma imagem (png) na minha caixa de depósito. Consigo obter os dados da tela e salvar um arquivo no dropbox, mas o arquivo não é um arquivo de imagem que é costurado.

De acordo com a documentação, os dados da imagem devem ser convertidos em um arrayBuffer. Estou usando uma função encontrada aqui no Stackoverflow, mas algo parece não funcionar. Alguém sabe o que estou fazendo de errado?

function _str2ab(str) {
    var buf = new ArrayBuffer(str.length*2); // 2 bytes for each char
    var bufView = new Uint16Array(buf);
    for (var i=0, strLen=str.length; i<strLen; i++) {
        bufView[i] = str.charCodeAt(i);
    }
    return buf;
}

function _savePicture () {

    //Get data from canvas
    var imageSringData = canvas.toDataURL('image/png');
    //Convert it to an arraybuffer
    var imageData = _str2ab(imageSringData);

    client.writeFile('/Public/the_image.png', imageData, function(error, stat) {
    if (error) {
        console.log('Error: ' + error);
    } else {
        console.log('File written successfully!');
    }
});

Aqui está uma documentação do dropbox.https://github.com/dropbox/dropbox-js/blob/stable/guides/snippets.md

questionAnswers(1)

yourAnswerToTheQuestion