mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-12 08:14:47 +02:00
Avatar Fusion Command
This commit is contained in:
@@ -0,0 +1,60 @@
|
||||
const Command = require('../../structures/Command');
|
||||
const { createCanvas, loadImage } = require('canvas');
|
||||
const snekfetch = require('snekfetch');
|
||||
|
||||
module.exports = class AvatarFusionCommand extends Command {
|
||||
constructor(client) {
|
||||
super(client, {
|
||||
name: 'avatar-fusion',
|
||||
aliases: ['avatar-fuse', 'ava-fuse'],
|
||||
group: 'avatar-edit',
|
||||
memberName: 'avatar-fusion',
|
||||
description: 'Draws a a user\'s avatar over a user\'s avatar.',
|
||||
throttling: {
|
||||
usages: 1,
|
||||
duration: 30
|
||||
},
|
||||
clientPermissions: ['ATTACH_FILES'],
|
||||
args: [
|
||||
{
|
||||
key: 'overlay',
|
||||
prompt: 'Which user would you like to put over the base?',
|
||||
type: 'user'
|
||||
},
|
||||
{
|
||||
key: 'base',
|
||||
prompt: 'Which user would you like to be the base?',
|
||||
type: 'user',
|
||||
default: ''
|
||||
}
|
||||
]
|
||||
});
|
||||
}
|
||||
|
||||
async run(msg, args) {
|
||||
const { overlay } = args;
|
||||
const base = args.base || msg.author;
|
||||
const baseAvatarURL = base.displayAvatarURL({
|
||||
format: 'png',
|
||||
size: 256
|
||||
});
|
||||
const overlayAvatarURL = overlay.displayAvatarURL({
|
||||
format: 'png',
|
||||
size: 256
|
||||
});
|
||||
try {
|
||||
const canvas = createCanvas(256, 256);
|
||||
const ctx = canvas.getContext('2d');
|
||||
const baseAvatarData = await snekfetch.get(baseAvatarURL);
|
||||
const baseAvatar = await loadImage(baseAvatarData);
|
||||
const overlayAvatarData = await snekfetch.get(overlayAvatarURL);
|
||||
const overlayAvatar = await loadImage(overlayAvatarData);
|
||||
ctx.globalAlpha = 0.5;
|
||||
ctx.drawImage(baseAvatar, 0, 0, 256, 256);
|
||||
ctx.drawImage(overlayAvatar, 0, 0, 256, 256);
|
||||
return msg.say({ files: [{ attachment: canvas.toBuffer(), name: 'avatar-fusion.png' }] });
|
||||
} catch (err) {
|
||||
return msg.say(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
}
|
||||
}
|
||||
};
|
||||
+1
-1
@@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "xiaobot",
|
||||
"version": "38.2.1",
|
||||
"version": "38.3.0",
|
||||
"description": "Your personal server companion.",
|
||||
"main": "Shard.js",
|
||||
"scripts": {
|
||||
|
||||
Reference in New Issue
Block a user