返回顶部
s

slack-gif-creatorSlack动图制作

Knowledge and utilities for creating animated GIFs optimized for Slack. Provides constraints, validation tools, and animation concepts. Use when users request animated GIFs for Slack like "make me a GIF of X doing Y for Slack.

作者: admin | 来源: ClawHub
源自
ClawHub
版本
V 1.0.0
安全检测
已通过
240
下载量
免费
免费
0
收藏
概述
安装方式
版本历史

slack-gif-creator

Slack GIF 创建工具

提供用于创建针对 Slack 优化的动画 GIF 的工具包和相关知识。

Slack 要求

尺寸:

  • - 表情符号 GIF:128x128(推荐)
  • 消息 GIF:480x480

参数:

  • - 帧率:10-30(越低文件越小)
  • 颜色数:48-128(越少文件越小)
  • 时长:表情符号 GIF 控制在 3 秒以内

核心工作流程

python
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, numcolors=48, optimizefor_emoji=True)

绘制图形

处理用户上传的图片

如果用户上传了图片,需考虑他们想要:
  • - 直接使用(例如让这个动起来、将其拆分为帧)
  • 作为灵感参考(例如制作类似的东西)

使用 PIL 加载和处理图片:
python
from PIL import Image

uploaded = Image.open(file.png)

直接使用,或仅作为颜色/风格的参考

从零开始绘制

从零开始绘制图形时,使用 PIL ImageDraw 基本绘图元素:

python
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)看起来粗糙且业余。

增加视觉深度

  • - 使用渐变背景(creategradientbackground)
  • 叠加多个形状增加复杂度(例如,大星星内含小星星)

让形状更有趣

  • - 不要只画普通圆形 - 添加高光、环或图案
  • 星星可以添加光晕(在后面绘制更大、半透明的版本)
  • 组合多个形状(星星+闪光、圆形+圆环)

注意色彩搭配

  • - 使用鲜艳的互补色
  • 增加对比度(浅色形状用深色轮廓,深色形状用浅色轮廓)
  • 考虑整体构图

对于复杂形状(心形、雪花等):

  • - 使用多边形和椭圆的组合
  • 仔细计算点以实现对称
  • 添加细节(心形可以有高光曲线,雪花有复杂的分支)

要有创意和细节!好的 Slack GIF 应该看起来精致,而不是像占位图形。

可用工具

GIFBuilder(core.gif_builder)

组装帧并针对 Slack 优化: python builder = GIFBuilder(width=128, height=128, fps=10) builder.add_frame(frame) # 添加 PIL Image builder.add_frames(frames) # 添加帧列表 builder.save(out.gif, numcolors=48, optimizeforemoji=True, removeduplicates=True)

验证器(core.validators)

检查 GIF 是否符合 Slack 要求: python from core.validators import validategif, isslack_ready

详细验证

passes, info = validategif(my.gif, isemoji=True, verbose=True)

快速检查

if isslackready(my.gif): print(准备就绪!)

缓动函数(core.easing)

实现平滑运动而非线性运动: python 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, easein, easeout, easeinout,

bounceout, elasticout, back_out

帧辅助工具(core.frame_composer)

常用功能的便捷函数: python from core.frame_composer import ( createblankframe, # 纯色背景 creategradientbackground, # 垂直渐变 draw_circle, # 圆形辅助 draw_text, # 简单文本渲染 draw_star # 五角星 )

动画概念

抖动/振动

通过振荡偏移对象位置:
  • - 使用 math.sin() 或 math.cos() 配合帧索引
  • 添加小幅随机变化以获得自然感
  • 应用于 x 和/或 y 位置

脉冲/心跳

有节奏地缩放对象大小:
  • - 使用 math.sin(t frequency 2 * math.pi) 实现平滑脉冲
  • 心跳:两次快速脉冲后暂停(调整正弦波)
  • 在基础大小的 0.8 到 1.2 倍之间缩放

弹跳

对象下落并弹起:
  • - 使用 interpolate() 配合 easing=bounceout 实现落地
  • 使用 easing=easein 实现下落(加速)
  • 通过每帧增加 y 速度来应用重力

旋转

围绕中心旋转对象:
  • - PIL:image.rotate(angle, resample=Image.BICUBIC)
  • 摇摆:使用正弦波代替线性角度

淡入/淡出

逐渐出现或消失:
  • - 创建 RGBA 图像,调整 alpha 通道
  • 或使用 Image.blend(image1, image2, alpha)
  • 淡入:alpha 从 0 到 1
  • 淡出:alpha 从 1 到 0

滑动

将对象从屏幕外移动到指定位置:
  • - 起始位置:在帧边界之外
  • 结束位置:目标位置
  • 使用 interpolate() 配合 easing=easeout 实现平滑停止
  • 过冲:使用 easing=backout

缩放

缩放和定位实现缩放效果:
  • - 放大:从 0.1 倍缩放到 2.0 倍,裁剪中心
  • 缩小:从 2.0 倍缩放到 1.0 倍
  • 可添加运动模糊增加戏剧效果(PIL 滤镜)

爆炸/粒子爆发

创建向外辐射的粒子:
  • - 生成具有随机角度和速度的粒子
  • 更新每个粒子:x += vx,y += vy
  • 添加重力:vy += gravity_constant
  • 粒子随时间淡出(减少 alpha)

优化策略

仅在要求减小文件大小时,实施以下几种方法:

  1. 1. 减少帧数 - 降低帧率(10 而非 20)或缩短时长
  2. 减少颜色数 - numcolors=48 而非 128
  3. 缩小尺寸 - 128x128 而非 480x480
  4. 去除重复帧 - save() 中设置 removeduplicates=True
  5. 表情符号模式 - optimizeforemoji=True 自动优化

python

表情符号的最大优化


builder.save(
emoji.gif,
num_colors=48,
optimizeforemoji=True,
remove_duplicates=True
)

设计理念

本技能提供:

  • - 知识:Slack 的要求和动画概念
  • 工具:GIFBuilder、验证器、缓动函数
  • 灵活性:使用 PIL 基本绘图元素创建动画逻辑

本技能不提供:

  • - 固定的动画模板或预制函数
  • 表情符号字体渲染(跨平台不可靠)
  • 内置于技能中的预置图形库

关于用户上传的说明:本技能

标签

skill ai

通过对话安装

该技能支持在以下平台通过对话安装:

OpenClaw WorkBuddy QClaw Kimi Claude

方式一:安装 SkillHub 和技能

帮我安装 SkillHub 和 slack-gif-creator-anthropic-1776087550 技能

方式二:设置 SkillHub 为优先技能安装源

设置 SkillHub 为我的优先技能安装源,然后帮我安装 slack-gif-creator-anthropic-1776087550 技能

通过命令行安装

skillhub install slack-gif-creator-anthropic-1776087550

下载

⬇ 下载 slack-gif-creator v1.0.0(免费)

文件大小: 16.16 KB | 发布时间: 2026-4-15 14:26

v1.0.0 最新 2026-4-15 14:26
Initial release with utilities and guidelines for creating animated GIFs optimized for Slack.

- Provides Slack-specific requirements: dimensions, colors, duration, FPS.
- Includes a GIFBuilder class for assembling and optimizing GIFs.
- Offers validation tools to ensure GIFs meet Slack's constraints.
- Supplies animation concepts (shake, pulse, bounce, spin, particle burst, etc.) and drawing tips for polished results.
- Features helper functions for drawing and composing frames using PIL.
- Contains strategies for file size optimization and guidance for handling user-uploaded images.

Archiver·手机版·闲社网·闲社论坛·羊毛社区· 多链控股集团有限公司 · 苏ICP备2025199260号-1

Powered by Discuz! X5.0   © 2024-2025 闲社网·线报更新论坛·羊毛分享社区·http://xianshe.com

p2p_official_large
返回顶部