1
0
Fork 0
ARCHIVE: Converts chat logs to comics.
Find a file
2016-11-13 20:24:11 -06:00
assets First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00
helpers First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00
.gitignore First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00
comic.png First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00
index.js First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00
package.json First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00
README.md Corrected preview in readme 2016-11-13 20:24:11 -06:00
test.js First Commit, Functional and Ready for NPM 2016-11-13 20:20:37 -06:00

Blabber-Comic

Sample

Preview

How it works

Powered by Node and a node-canvas a comic can automatically be generated from a json array of users/text and some characters/backgrounds to be chosen at random.

How to use it

Generate base64Data

const blabbercomic = require('blabber-comic');
let messages = [] // Array of messages...

blabbercomic(messages).then(response => {
  console.log('Generated comic as base64 data', response);
}).catch(error => {
  throw error;
});

Save as file with fs

Example included in project. Clone then run npm run test.

const blabbercomic = require('blabber-comic');
const fs = require('fs');
let messages = [] // Array of messages...

blabbercomic(messages).then(response => {
  let base64Data = response.replace(/^data:image\/png;base64,/, '');

  fs.writeFile('./storage/comics/comic.png', base64Data, 'base64', error => {
    if (error) console.error('Uhoh...', error);
    else console.log('Saved file as `comic.png`');
  });
}).catch(error => {
  throw error;
});

Customizing characters and backgrounds

const blabbercomic = require('blabber-comic');
let backgrounds = ['./assets/backgrounds/1.png', './assets/backgrounds/2.png'];
let characters = ['./assets/characters/1.png', './assets/characters/2.png', './assets/characters/3.png']; // Provide at least 3
let comicSize = 400; // in px square

let messages = [] // Array of messages...
let config = { backgrounds, characters, comicSize };

blabbercomic(messages, config);

Special thanks to:

  • node-canvas by Cairo
  • avatars by Iulia Ardeleanu from the Noun Project
  • backgrounds by Olga Libby from Subtle Patterns