KS
Killer-Skills

slack-gif-creator — how to use slack-gif-creator how to use slack-gif-creator, slack gif creator setup guide, slack gif builder python, slack-gif-creator vs giphy, slack optimized gif parameters, slack-gif-creator install, what is slack-gif-creator, slack-gif-creator alternative, PIL create slack gif

Verified
v1.0.0
GitHub

About this Skill

Perfect for Python-based Content Creation Agents needing Slack-optimized animated GIF generation. slack-gif-creator is an AI agent skill providing a toolkit with utilities and knowledge for creating animated GIFs optimized for Slack. It offers specific constraints, validation tools, and a core workflow using GIFBuilder and the Python Imaging Library (PIL).

Features

Provides Slack-specific dimension requirements (128x128 for emoji GIFs, 480x480 for message GIFs)
Configures GIF parameters including FPS (10-30) and color palette (48-128 colors)
Enforces duration constraints (under 3 seconds for emoji GIFs) for optimal file size
Includes a core GIFBuilder utility for programmatic GIF creation
Integrates with Python's PIL (Pillow) library for image manipulation

# Core Topics

anthropics anthropics
[85.1k]
[8974]
Updated: 3/6/2026

Quality Score

Top 5%
71
Excellent
Based on code quality & docs
Installation
SYS Universal Install (Auto-Detect)
Cursor IDE Windsurf IDE VS Code IDE
> npx killer-skills add anthropics/skills/slack-gif-creator

Agent Capability Analysis

The slack-gif-creator MCP Server by anthropics is an open-source Categories.official integration for Claude and other AI agents, enabling seamless task automation and capability expansion. Optimized for how to use slack-gif-creator, slack gif creator setup guide, slack gif builder python.

Ideal Agent Persona

Perfect for Python-based Content Creation Agents needing Slack-optimized animated GIF generation.

Core Value

Empowers agents to create animated GIFs specifically optimized for Slack's platform requirements using PIL (Pillow) and custom GIF building utilities. Provides dimension constraints (128x128 for emojis, 480x480 for messages), FPS optimization (10-30 range), and color reduction techniques (48-128 colors) for optimal file size and performance.

Capabilities Granted for slack-gif-creator MCP Server

Generating Slack emoji GIFs with precise 128x128 dimensions
Creating message-embedded GIFs at 480x480 resolution
Optimizing animation parameters for minimal file size
Validating GIF specifications against Slack's requirements

! Prerequisites & Limits

  • Requires PIL (Pillow) library installation
  • Limited to Python-based GIF generation workflows
  • Focuses exclusively on Slack platform optimization
  • Requires manual animation concept implementation
Project
SKILL.md
7.4 KB
.cursorrules
1.2 KB
package.json
240 B
Ready
UTF-8
SKILL.md
Readonly

Slack GIF Creator

A toolkit providing utilities and knowledge for creating animated GIFs optimized for Slack.

Slack Requirements

Dimensions:

  • Emoji GIFs: 128x128 (recommended)
  • Message GIFs: 480x480

Parameters:

  • FPS: 10-30 (lower is smaller file size)
  • Colors: 48-128 (fewer = smaller file size)
  • Duration: Keep under 3 seconds for emoji GIFs

Core Workflow

python
1from core.gif_builder import GIFBuilder 2from PIL import Image, ImageDraw 3 4# 1. Create builder 5builder = GIFBuilder(width=128, height=128, fps=10) 6 7# 2. Generate frames 8for i in range(12): 9 frame = Image.new('RGB', (128, 128), (240, 248, 255)) 10 draw = ImageDraw.Draw(frame) 11 12 # Draw your animation using PIL primitives 13 # (circles, polygons, lines, etc.) 14 15 builder.add_frame(frame) 16 17# 3. Save with optimization 18builder.save('output.gif', num_colors=48, optimize_for_emoji=True)

Drawing Graphics

Working with User-Uploaded Images

If a user uploads an image, consider whether they want to:

  • Use it directly (e.g., "animate this", "split this into frames")
  • Use it as inspiration (e.g., "make something like this")

Load and work with images using PIL:

python
1from PIL import Image 2 3uploaded = Image.open('file.png') 4# Use directly, or just as reference for colors/style

Drawing from Scratch

When drawing graphics from scratch, use PIL ImageDraw primitives:

python
1from PIL import ImageDraw 2 3draw = ImageDraw.Draw(frame) 4 5# Circles/ovals 6draw.ellipse([x1, y1, x2, y2], fill=(r, g, b), outline=(r, g, b), width=3) 7 8# Stars, triangles, any polygon 9points = [(x1, y1), (x2, y2), (x3, y3), ...] 10draw.polygon(points, fill=(r, g, b), outline=(r, g, b), width=3) 11 12# Lines 13draw.line([(x1, y1), (x2, y2)], fill=(r, g, b), width=5) 14 15# Rectangles 16draw.rectangle([x1, y1, x2, y2], fill=(r, g, b), outline=(r, g, b), width=3)

Don't use: Emoji fonts (unreliable across platforms) or assume pre-packaged graphics exist in this skill.

Making Graphics Look Good

Graphics should look polished and creative, not basic. Here's how:

Use thicker lines - Always set width=2 or higher for outlines and lines. Thin lines (width=1) look choppy and amateurish.

Add visual depth:

  • Use gradients for backgrounds (create_gradient_background)
  • Layer multiple shapes for complexity (e.g., a star with a smaller star inside)

Make shapes more interesting:

  • Don't just draw a plain circle - add highlights, rings, or patterns
  • Stars can have glows (draw larger, semi-transparent versions behind)
  • Combine multiple shapes (stars + sparkles, circles + rings)

Pay attention to colors:

  • Use vibrant, complementary colors
  • Add contrast (dark outlines on light shapes, light outlines on dark shapes)
  • Consider the overall composition

For complex shapes (hearts, snowflakes, etc.):

  • Use combinations of polygons and ellipses
  • Calculate points carefully for symmetry
  • Add details (a heart can have a highlight curve, snowflakes have intricate branches)

Be creative and detailed! A good Slack GIF should look polished, not like placeholder graphics.

Available Utilities

GIFBuilder (core.gif_builder)

Assembles frames and optimizes for Slack:

python
1builder = GIFBuilder(width=128, height=128, fps=10) 2builder.add_frame(frame) # Add PIL Image 3builder.add_frames(frames) # Add list of frames 4builder.save('out.gif', num_colors=48, optimize_for_emoji=True, remove_duplicates=True)

Validators (core.validators)

Check if GIF meets Slack requirements:

python
1from core.validators import validate_gif, is_slack_ready 2 3# Detailed validation 4passes, info = validate_gif('my.gif', is_emoji=True, verbose=True) 5 6# Quick check 7if is_slack_ready('my.gif'): 8 print("Ready!")

Easing Functions (core.easing)

Smooth motion instead of linear:

python
1from core.easing import interpolate 2 3# Progress from 0.0 to 1.0 4t = i / (num_frames - 1) 5 6# Apply easing 7y = interpolate(start=0, end=400, t=t, easing='ease_out') 8 9# Available: linear, ease_in, ease_out, ease_in_out, 10# bounce_out, elastic_out, back_out

Frame Helpers (core.frame_composer)

Convenience functions for common needs:

python
1from core.frame_composer import ( 2 create_blank_frame, # Solid color background 3 create_gradient_background, # Vertical gradient 4 draw_circle, # Helper for circles 5 draw_text, # Simple text rendering 6 draw_star # 5-pointed star 7)

Animation Concepts

Shake/Vibrate

Offset object position with oscillation:

  • Use math.sin() or math.cos() with frame index
  • Add small random variations for natural feel
  • Apply to x and/or y position

Pulse/Heartbeat

Scale object size rhythmically:

  • Use math.sin(t * frequency * 2 * math.pi) for smooth pulse
  • For heartbeat: two quick pulses then pause (adjust sine wave)
  • Scale between 0.8 and 1.2 of base size

Bounce

Object falls and bounces:

  • Use interpolate() with easing='bounce_out' for landing
  • Use easing='ease_in' for falling (accelerating)
  • Apply gravity by increasing y velocity each frame

Spin/Rotate

Rotate object around center:

  • PIL: image.rotate(angle, resample=Image.BICUBIC)
  • For wobble: use sine wave for angle instead of linear

Fade In/Out

Gradually appear or disappear:

  • Create RGBA image, adjust alpha channel
  • Or use Image.blend(image1, image2, alpha)
  • Fade in: alpha from 0 to 1
  • Fade out: alpha from 1 to 0

Slide

Move object from off-screen to position:

  • Start position: outside frame bounds
  • End position: target location
  • Use interpolate() with easing='ease_out' for smooth stop
  • For overshoot: use easing='back_out'

Zoom

Scale and position for zoom effect:

  • Zoom in: scale from 0.1 to 2.0, crop center
  • Zoom out: scale from 2.0 to 1.0
  • Can add motion blur for drama (PIL filter)

Explode/Particle Burst

Create particles radiating outward:

  • Generate particles with random angles and velocities
  • Update each particle: x += vx, y += vy
  • Add gravity: vy += gravity_constant
  • Fade out particles over time (reduce alpha)

Optimization Strategies

Only when asked to make the file size smaller, implement a few of the following methods:

  1. Fewer frames - Lower FPS (10 instead of 20) or shorter duration
  2. Fewer colors - num_colors=48 instead of 128
  3. Smaller dimensions - 128x128 instead of 480x480
  4. Remove duplicates - remove_duplicates=True in save()
  5. Emoji mode - optimize_for_emoji=True auto-optimizes
python
1# Maximum optimization for emoji 2builder.save( 3 'emoji.gif', 4 num_colors=48, 5 optimize_for_emoji=True, 6 remove_duplicates=True 7)

Philosophy

This skill provides:

  • Knowledge: Slack's requirements and animation concepts
  • Utilities: GIFBuilder, validators, easing functions
  • Flexibility: Create the animation logic using PIL primitives

It does NOT provide:

  • Rigid animation templates or pre-made functions
  • Emoji font rendering (unreliable across platforms)
  • A library of pre-packaged graphics built into the skill

Note on user uploads: This skill doesn't include pre-built graphics, but if a user uploads an image, use PIL to load and work with it - interpret based on their request whether they want it used directly or just as inspiration.

Be creative! Combine concepts (bouncing + rotating, pulsing + sliding, etc.) and use PIL's full capabilities.

Dependencies

bash
1pip install pillow imageio numpy

Related Skills

Looking for an alternative to slack-gif-creator or building a Categories.official AI Agent? Explore these related open-source MCP Servers.

View All

flags

Logo of facebook
facebook

flags is a feature flag management system that enables developers to check flag states, compare channels, and debug feature behavior differences across release channels.

243.6k
0
Design

extract-errors

Logo of facebook
facebook

extract-errors is a skill that assists in extracting and managing error codes in React applications using yarn extract-errors command.

243.6k
0
Design

fix

Logo of facebook
facebook

fix is a technical skill that resolves lint errors, formatting issues, and ensures code quality in declarative, frontend, and UI projects

243.6k
0
Design

flow

Logo of facebook
facebook

Flow is a type checking system for JavaScript, used to validate React code and ensure consistency across applications

243.6k
0
Design