🚀 快速安装
复制以下命令并运行,立即安装此 Skill:
npx @anthropic-ai/skills install anthropics/skills/slack-gif-creator
💡 提示:需要 Node.js 和 NPM
Slack GIF 创建工具
一个提供实用程序和知识的工具包,用于创建针对 Slack 优化的动画 GIF。
Slack 要求
尺寸:
- 表情符号 GIF:128×128(推荐)
- 消息 GIF:480×480
参数:
- 帧率:10-30(越低文件越小)
- 颜色数:48-128(越少文件越小)
- 时长:表情符号 GIF 请保持在 3 秒以内
核心工作流程
from core.gif_builder import GIFBuilder
from PIL import Image, ImageDraw
# 1. 创建构建器
builder = GIFBuilder(width=128, height=128, fps=10)
# 2. 生成帧
for i in range(12):
frame = Image.new('RGB', (128, 128), (240, 248, 255))
draw = ImageDraw.Draw(frame)
# 使用 PIL 基本图形绘制您的动画
# (圆形、多边形、线条等)
builder.add_frame(frame)
# 3. 保存并优化
builder.save('output.gif', num_colors=48, optimize_for_emoji=True)
绘制图形
处理用户上传的图片
如果用户上传了图片,请考虑他们想要:
- 直接使用它(例如,“将此动画化”、“将其拆分为帧”)
- 将其作为灵感(例如,“制作类似这样的东西”)
使用 PIL 加载和处理图片:
from PIL import Image
uploaded = Image.open('file.png')
# 直接使用,或仅作为颜色/样式的参考
从头开始绘制
从头绘制图形时,请使用 PIL ImageDraw 基本图形:
from PIL import ImageDraw
draw = ImageDraw.Draw(frame)
# 圆形/椭圆
draw.ellipse([x1, y1, x2, y2], fill=(r, g, b), outline=(r, g, b), width=3)
# 星形、三角形、任何多边形
points = [(x1, y1), (x2, y2), (x3, y3), ...]
draw.polygon(points, fill=(r, g, b), outline=(r, g, b), width=3)
# 线条
draw.line([(x1, y1), (x2, y2)], fill=(r, g, b), width=5)
# 矩形
draw.rectangle([x1, y1, x2, y2], fill=(r, g, b), outline=(r, g, b), width=3)
不要使用: 表情符号字体(跨平台不可靠)或假定此技能中存在预打包的图形。
让图形看起来更好看
图形应该看起来精致且富有创意,而不是基础。方法如下:
使用更粗的线条 – 对于轮廓和线条,始终设置 width=2 或更高。细线(width=1)看起来参差不齐且业余。
增加视觉深度:
- 对背景使用渐变(
create_gradient_background) - 叠加多个形状以增加复杂度(例如,一个星星里面有一个较小的星星)
让形状更有趣:
- 不要只画一个普通的圆——添加高光、环或图案
- 星星可以有光晕(在后面绘制更大、半透明的版本)
- 组合多个形状(星星+火花,圆圈+环)
注意颜色:
- 使用鲜艳、互补的颜色
- 增加对比度(深色形状上用浅色轮廓,浅色形状上用深色轮廓)
- 考虑整体构图
对于复杂形状(心形、雪花等):
- 使用多边形和椭圆的组合
- 仔细计算点以实现对称
- 添加细节(心形可以有高光曲线,雪花有复杂的分支)
要富有创意和细致!一个好的 Slack GIF 应该看起来精致,而不像占位图形。
可用工具
GIFBuilder (core.gif_builder)
组装帧并为 Slack 优化:
builder = GIFBuilder(width=128, height=128, fps=10)
builder.add_frame(frame) # 添加 PIL 图像
builder.add_frames(frames) # 添加帧列表
builder.save('out.gif', num_colors=48, optimize_for_emoji=True, remove_duplicates=True)
验证器 (core.validators)
检查 GIF 是否符合 Slack 要求:
from core.validators import validate_gif, is_slack_ready
# 详细验证
passes, info = validate_gif('my.gif', is_emoji=True, verbose=True)
# 快速检查
if is_slack_ready('my.gif'):
print("已就绪!")
缓动函数 (core.easing)
实现平滑运动而非线性:
from core.easing import interpolate
# 进度从 0.0 到 1.0
t = i / (num_frames - 1)
# 应用缓动
y = interpolate(start=0, end=400, t=t, easing='ease_out')
# 可用类型:linear, ease_in, ease_out, ease_in_out,
# bounce_out, elastic_out, back_out
帧助手 (core.frame_composer)
满足常见需求的便捷函数:
from core.frame_composer import (
create_blank_frame, # 纯色背景
create_gradient_background, # 垂直渐变
draw_circle, # 圆形助手
draw_text, # 简单文本渲染
draw_star # 五角星
)
动画概念
抖动/振动
通过振荡偏移对象位置:
- 使用
math.sin()或math.cos()配合帧索引 - 添加小的随机变化以获得自然感
- 应用于 x 和/或 y 位置
脉搏/心跳
有节奏地缩放对象大小:
- 对于平滑脉搏,使用
math.sin(t * frequency * 2 * math.pi) - 对于心跳:两次快速跳动然后暂停(调整正弦波)
- 在基础大小的 0.8 到 1.2 之间缩放
弹跳
物体下落并弹起:
- 对于着陆,使用带有
easing='bounce_out'的interpolate() - 对于下落(加速),使用
easing='ease_in' - 通过每帧增加 y 速度来应用重力
旋转
围绕中心旋转对象:
- PIL:
image.rotate(angle, resample=Image.BICUBIC) - 对于摆动:使用正弦波设置角度,而非线性
淡入/淡出
逐渐出现或消失:
- 创建 RGBA 图像,调整 alpha 通道
- 或使用
Image.blend(image1, image2, alpha) - 淡入:alpha 从 0 到 1
- 淡出:alpha 从 1 到 0
滑动
将对象从屏幕外移动到位置:
- 起始位置:在帧边界之外
- 结束位置:目标位置
- 使用带有
easing='ease_out'的interpolate()实现平滑停止 - 对于过冲:使用
easing='back_out'
缩放
通过缩放和定位实现缩放效果:
- 放大:从 0.1 缩放到 2.0,裁剪中心
- 缩小:从 2.0 缩放到 1.0
- 可以添加运动模糊以增强戏剧效果(PIL 滤镜)
爆炸/粒子爆发
创建向外辐射的粒子:
- 生成具有随机角度和速度的粒子
- 更新每个粒子:
x += vx,y += vy - 添加重力:
vy += gravity_constant - 随时间淡出粒子(减少 alpha)
优化策略
仅在要求减小文件大小时,实施以下几种方法:
- 更少的帧 – 降低帧率(10 代替 20)或缩短时长
- 更少的颜色 –
num_colors=48代替 128 - 更小的尺寸 – 128×128 代替 480×480
- 移除重复帧 – 在 save() 中设置
remove_duplicates=True - 表情符号模式 –
optimize_for_emoji=True自动优化
# 为表情符号进行最大优化
builder.save(
'emoji.gif',
num_colors=48,
optimize_for_emoji=True,
remove_duplicates=True
)
设计理念
此技能提供:
- 知识:Slack 的要求和动画概念
- 实用工具:GIFBuilder、验证器、缓动函数
- 灵活性:使用 PIL 基本图形创建动画逻辑
它不提供:
- 固定的动画模板或预制函数
- 表情符号字体渲染(跨平台不可靠)
- 内置到此技能中的预打包图形库
关于用户上传的说明:此技能不包含预构建的图形,但如果用户上传了图片,请使用 PIL 加载并处理它——根据他们的请求判断是直接使用还是仅作为灵感。
要富有创意!结合概念(弹跳+旋转,脉搏+滑动等)并充分利用 PIL 的全部功能。
依赖项
pip install pillow imageio numpy
📄 原始文档
完整文档(英文):
https://skills.sh/anthropics/skills/slack-gif-creator
💡 提示:点击上方链接查看 skills.sh 原始英文文档,方便对照翻译。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

评论(0)