mirror of
https://github.com/arthur-pbty/xiao.git
synced 2026-06-17 08:17:35 +02:00
Begin migrating away from stupid "Oh no, an error occurred!"
This commit is contained in:
+25
-29
@@ -31,35 +31,31 @@ module.exports = class PetCommand extends Command {
|
||||
}
|
||||
|
||||
async run(msg, { image }) {
|
||||
try {
|
||||
const { body } = await request.get(image);
|
||||
const data = await loadImage(body);
|
||||
const encoder = new GIFEncoder(112, 112);
|
||||
const canvas = createCanvas(112, 112);
|
||||
const ctx = canvas.getContext('2d');
|
||||
const stream = encoder.createReadStream();
|
||||
encoder.start();
|
||||
encoder.setRepeat(0);
|
||||
encoder.setDelay(20);
|
||||
encoder.setQuality(200);
|
||||
encoder.setTransparent('#000000');
|
||||
let squish = 0;
|
||||
for (let i = 0; i < frameCount; i++) {
|
||||
const frameID = `frame_${i.toString().padStart(2, '0')}.png`;
|
||||
const frame = await loadImage(path.join(__dirname, '..', '..', 'assets', 'images', 'pet', frameID));
|
||||
const { x, y, width, height } = centerImagePart(data, 75, 75, 27, 38);
|
||||
ctx.drawImage(data, x - (squish / 2), y + squish, width + squish, height - squish);
|
||||
ctx.drawImage(frame, 0, 0);
|
||||
encoder.addFrame(ctx);
|
||||
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
||||
if (i + 1 > frameCount / 2) squish -= 4;
|
||||
else squish += 4;
|
||||
}
|
||||
encoder.finish();
|
||||
const buffer = await streamToArray(stream);
|
||||
return msg.say({ files: [{ attachment: Buffer.concat(buffer), name: 'pet.gif' }] });
|
||||
} catch (err) {
|
||||
return msg.reply(`Oh no, an error occurred: \`${err.message}\`. Try again later!`);
|
||||
const { body } = await request.get(image);
|
||||
const data = await loadImage(body);
|
||||
const encoder = new GIFEncoder(112, 112);
|
||||
const canvas = createCanvas(112, 112);
|
||||
const ctx = canvas.getContext('2d');
|
||||
const stream = encoder.createReadStream();
|
||||
encoder.start();
|
||||
encoder.setRepeat(0);
|
||||
encoder.setDelay(20);
|
||||
encoder.setQuality(200);
|
||||
encoder.setTransparent('#000000');
|
||||
let squish = 0;
|
||||
for (let i = 0; i < frameCount; i++) {
|
||||
const frameID = `frame_${i.toString().padStart(2, '0')}.png`;
|
||||
const frame = await loadImage(path.join(__dirname, '..', '..', 'assets', 'images', 'pet', frameID));
|
||||
const { x, y, width, height } = centerImagePart(data, 75, 75, 27, 38);
|
||||
ctx.drawImage(data, x - (squish / 2), y + squish, width + squish, height - squish);
|
||||
ctx.drawImage(frame, 0, 0);
|
||||
encoder.addFrame(ctx);
|
||||
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
||||
if (i + 1 > frameCount / 2) squish -= 4;
|
||||
else squish += 4;
|
||||
}
|
||||
encoder.finish();
|
||||
const buffer = await streamToArray(stream);
|
||||
return msg.say({ files: [{ attachment: Buffer.concat(buffer), name: 'pet.gif' }] });
|
||||
}
|
||||
};
|
||||
|
||||
Reference in New Issue
Block a user