ADB-MCP:AI驱动的Adobe创意工具控制协议

项目标题与描述

ADB-MCP (Adobe AI Control via MCP Protocol) 是一个概念验证项目,旨在通过MCP协议为大型语言模型(LLM)提供接口,实现对Adobe创意工具(如Photoshop和Premiere)的AI控制。

核心架构:

rust 复制代码
AI <-> MCP Server <-> Command Proxy Server <-> Photoshop/Premiere UXP Plugin <-> Photoshop/Premiere

功能特性

  • 多Adobe应用支持:目前支持Photoshop和Premiere,设计上支持扩展更多Adobe应用
  • AI对话式操作:通过自然语言指令控制Adobe软件
  • 自动化任务:支持从简单操作到复杂工作流的自动化执行
  • 教学辅助:AI可生成操作教程并实时演示
  • 跨平台:已在Mac和Windows平台测试通过
  • 多AI客户端支持:测试支持Claude Desktop和OpenAI Agent SDK

典型用例:

  • 通过对话指导Photoshop操作(特别适合新手)
  • 自动创建Instagram帖子模板(如宝丽来风格、双重曝光效果)
  • 生成自定义Photoshop教程并演示
  • 批量处理(如统一图层命名)
  • Premiere项目自动化(预置剪辑、转场、效果和音频)

安装指南

系统要求

  • Node.js环境
  • Adobe Photoshop/Premiere(最新版)
  • Python 3.x(部分组件)

安装步骤

  1. 克隆仓库:

    bash 复制代码
    git clone https://github.com/mikechambers/adb-mcp.git
  2. 安装依赖:

    bash 复制代码
    npm install
  3. 构建可执行文件:

    bash 复制代码
    npm install -g pkg
    pkg .
  4. 启动代理服务器:

    bash 复制代码
    node server.js
  5. 安装对应的Adobe插件

使用说明

基本使用示例

连接AI客户端到MCP服务器:

javascript 复制代码
const APPLICATION = "photoshop";
const PROXY_URL = "http://localhost:3001";

socket.on('command_packet', ({ application, command }) => {
    console.log(`Command from ${socket.id} for application ${application}:`, command);
    let packet = {
        senderId:socket.id,
        application:application,
        command:command
    }
    sendToApplication(packet)
});

Photoshop自动化示例

创建黑白调整图层:

javascript 复制代码
const addAdjustmentLayerBlackAndWhite = async (command) => {
    let options = command.options;
    let layerId = options.layerId;
    let layer = findLayer(layerId);
    
    await execute(async () => {
        selectLayer(layer, true);
        let commands = [
            {
                _obj: "make",
                _target: [{ _ref: "adjustmentLayer" }],
                using: { /* 参数配置 */ }
            }
        ];
        await action.batchPlay(commands, {});
    });
};

Premiere自动化示例

导入媒体文件:

javascript 复制代码
const importMedia = async (command) => {
    let paths = command.options.filePaths;
    let project = await app.Project.getActiveProject();
    let success = await project.importFiles(paths, true, await project.getRootItem());
    return { addedProjectItems: /* 新增项目项 */ };
};

核心代码

MCP服务器核心

javascript 复制代码
// server.js
const express = require('express');
const { Server } = require('socket.io');
const io = new Server(server, {
    transports: ["websocket"],
    maxHttpBufferSize: 50 * 1024 * 1024
});

io.on('connection', (socket) => {
    socket.on('register', ({ application }) => {
        if (!applicationClients[application]) {
            applicationClients[application] = new Set();
        }
        applicationClients[application].add(socket.id);
    });

    socket.on('command_packet', ({ application, command }) => {
        let packet = { senderId:socket.id, application, command };
        sendToApplication(packet);
    });
});

function sendToApplication(packet) {
    if (applicationClients[packet.application]) {
        applicationClients[packet.application].forEach(clientId => {
            io.to(clientId).emit('command_packet', packet);
        });
    }
}

Photoshop命令处理

python 复制代码
# photoshop_mcp.py
@mcp.tool()
def call_batch_play_command(commands: list):
    """
    通过MCP执行任意Photoshop batchPlay命令
    
    参数:
        commands: 表示batchPlay描述符列表的JSON字符串
    """
    command = createCommand("batchPlay", {"commands": commands})
    return sendCommand(command)

@mcp.resource("config://get_instructions")
def get_instructions() -> str:
    """返回Photoshop和API的使用说明"""
    return """
    你是一个富有创意的Photoshop专家,乐于帮助他人学习使用Photoshop。
    
    遵循规则:
    1. 深入思考如何解决问题
    2. 始终检查你的工作
    3. 阅读API调用信息确保理解需求参数
    """
相关推荐
互联网推荐官7 小时前
物联网应用开发实战:从协议选型到平台落地的工程路径解析
人工智能
呆呆敲代码的小Y7 小时前
【Unity实战篇】| YooAsset + UOS CDN 云服务资源部署,实现正式热更流程
人工智能·游戏·unity·游戏引擎·免费游戏
ai产品老杨8 小时前
深度解析:基于异构计算的工业级AI视频中台架构,支持GB28181/RTSP接入与X86/ARM/NPU全场景部署
人工智能·架构·音视频
N串8 小时前
数字化-利益,是最硬的墙
人工智能·经验分享·产品经理
Cxiaomu8 小时前
从零搭建可落地的 RAG 基座:概念、架构设计、工程实现与实践复盘
人工智能·rag
思绪无限8 小时前
YOLOv5至YOLOv12升级:零售柜商品检测软件的设计与实现(完整代码+界面+数据集项目)
人工智能·python·深度学习·目标检测·计算机视觉·零售柜商品检测·yolov12
IT_陈寒8 小时前
Python中的这个可变默认参数陷阱我居然又踩了
前端·人工智能·后端
搞科研的小刘选手8 小时前
【 IEEE出版 】第七届大数据、人工智能与软件工程国际学术会议(ICBASE 2026)
大数据·人工智能·深度学习·机器学习·软件工程·软件开发·电子信息
AI算法沐枫8 小时前
从客服转行AI Agent:半年学习与求职复盘
人工智能·深度学习·学习·大模型·agent·智能体·ai应用开发
扬帆破浪8 小时前
免费开源的WPS AI插件 察元AI助手:installGlobalErrorLogger:启动写盘与 Vue 错误钩子
人工智能·开源·ai编程·wps