From 672ac9cbe9f4342e48970ee2b2b38dbc2c9e2468 Mon Sep 17 00:00:00 2001 From: Dragon Fire Date: Sat, 23 Mar 2024 21:36:52 -0400 Subject: [PATCH] Add back danny-devito --- .gitignore | 1 - commands/edit-face/danny-devito.js | 58 ++++++++++++++++++++++++++++++ 2 files changed, 58 insertions(+), 1 deletion(-) create mode 100644 commands/edit-face/danny-devito.js diff --git a/.gitignore b/.gitignore index 1bfa58fb..b5183735 100644 --- a/.gitignore +++ b/.gitignore @@ -24,5 +24,4 @@ tf_models/ .DS_Store # In-Development Commands -commands/edit-face/danny-devito.js commands/edit-face/emoji-face.js diff --git a/commands/edit-face/danny-devito.js b/commands/edit-face/danny-devito.js new file mode 100644 index 00000000..84b7f950 --- /dev/null +++ b/commands/edit-face/danny-devito.js @@ -0,0 +1,58 @@ +const Command = require('../../framework/Command'); +const request = require('node-superfetch'); +const { createCanvas, loadImage } = require('canvas'); +const path = require('path'); + +module.exports = class DannyDevitoCommand extends Command { + constructor(client) { + super(client, { + name: 'danny-devito', + aliases: ['devito'], + group: 'edit-face', + memberName: 'danny-devito', + description: 'Draws Danny Devito\'s face onto the faces in an image.', + throttling: { + usages: 1, + duration: 60 + }, + credit: [ + { + name: 'Danny DeVito', + url: 'https://twitter.com/dannydevito', + reason: 'Himself' + } + ], + args: [ + { + key: 'image', + prompt: 'What face would you like to scan?', + type: 'image-or-avatar' + } + ] + }); + } + + async run(msg, { image }) { + const danny = await loadImage(path.join(__dirname, '..', '..', 'assets', 'images', 'danny-devito.png')); + const imgData = await request.get(image); + const faces = await this.client.detectFaces(imgData.body); + if (!faces) return msg.reply('There are no faces in this image.'); + if (faces === 'size') return msg.reply('This image is too large.'); + const base = await loadImage(imgData.body); + const canvas = createCanvas(base.width, base.height); + const ctx = canvas.getContext('2d'); + ctx.drawImage(base, 0, 0); + for (const face of faces) { + const ratio = face.box.width / danny.width; + const height = danny.height * ratio; + ctx.drawImage( + danny, + face.box.xMin - (face.box.width * 0.25), + face.box.yMin - (height / 2) - (height * 0.25), + face.box.width * 1.5, + height * 1.5 + ); + } + return msg.say({ files: [{ attachment: canvas.toBuffer(), name: 'danny-devito.png' }] }); + } +};