report-ppt-generator-pro

GitHub 作者 LeoYeAI/openclaw-master-skills

提供你的文稿及想要的风格示例图,会自动总结内容及风格,先通过 HTML 生成 PPT 预览,定稿后自动导出类似风格的.pptx 文件。

安装 / 下载方式

TotalClaw CLI推荐
totalclaw install github:LeoYeAI~openclaw-master-skills~report-ppt-generator-pro
cURL直接下载,无需登录
curl -fsSL https://skills.taituai.com/api/skills/github%3ALeoYeAI~openclaw-master-skills~report-ppt-generator-pro/file -o report-ppt-generator-pro.md
# PPT Generator

## ⚠️ 依赖和权限声明

### 必需依赖

| 依赖 | 用途 | 配置要求 |
|------|------|----------|
| **nanobanana-skill** | AI 配图生成(可选功能) | 需要安装此 skill |
| **支持图片识别的 LLM** | 风格分析、大纲生成 | 用户自行配置任意支持图片识别的模型 |

### 文件系统访问

| 权限 | 用途 | 说明 |
|------|------|------|
| **读取本地文件** | 读取用户提供的风格示例图、文稿文件 | 仅读取用户明确指定的文件 |
| **写入本地文件** | 保存生成的 HTML 预览、PPTX 文件、AI 配图 | 默认保存到 `~/clawd/output/` 目录 |
| **读取 skill 目录** | 读取 assets/ 和 references/ 中的模板文件 | 仅限本 skill 目录内 |

### 外部 API 调用

| API | 用途 | 凭证要求 |
|-----|------|----------|
| **Google Gemini API** | AI 配图生成(通过 nanobanana-skill) | 需要在 nanobanana-skill 中配置 `GEMINI_API_KEY` |
| **LLM API** | 风格分析、内容生成 | 用户自行配置(支持图片识别的任意模型) |

### 可选功能

| 功能 | 依赖 | 是否必需 |
|------|------|----------|
| AI 配图生成 | nanobanana-skill + Gemini API Key | ❌ 可选 |
| 风格分析 | 支持图片识别的 LLM | ✅ 必需 |
| HTML 预览 | Canvas 工具或本地服务器 | ✅ 必需 |
| PPTX 导出 | pptxgenjs (内置) | ✅ 必需 |

---

Generate professional, editable PowerPoint presentations from text manuscripts with style matching.

## Workflow

```
用户输入(文稿 + 风格示例图 + 可选图片)
              │
              ▼
    ┌─────────────────┐
    │  Step 1: 风格分析 │
    │  支持图片识别的  │
    │  LLM 模型        │
    │  提取配色/布局   │
    └────────┬────────┘
             │
             ▼
    ┌─────────────────┐
    │  用户确认/调整   │  ← 对话迭代
    └────────┬────────┘
             │
             ▼
    ┌─────────────────┐
    │  Step 2: 大纲生成 │
    │  总结文稿内容    │
    │  规划每页结构    │
    └────────┬────────┘
             │
             ▼
    ┌─────────────────┐
    │  是否需要AI配图?│  ← 可选项
    │  (Step 2.5)     │
    └────────┬────────┘
             │
    ┌────────┴────────┐
    │                 │
   是                否
    │                 │
    ▼                 │
┌─────────────┐       │
│ AI配图生成  │       │
│ nanobanana  │       │
└──────┬──────┘       │
       │              │
       └──────┬───────┘
              │
              ▼
    ┌─────────────────┐
    │  Step 3: HTML生成 │
    │  16:9 横屏页面   │
    │  应用风格        │
    └────────┬────────┘
             │
             ▼
    ┌─────────────────┐
    │  Canvas 预览     │  ← 左右翻页、对话修改
    │  用户确认        │
    └────────┬────────┘
             │
             ▼
    ┌─────────────────┐
    │  Step 4: 导出PPTX │
    │  pptxgenjs      │
    │  可编辑文件      │
    └─────────────────┘
```

## Step 1: 风格分析

### 输入
- 风格示例图:用户提供的一张或多张 PPT 截图
- 可选:用户的风格偏好说明

### 执行

使用 `sessions_spawn` 调用**支持图片识别的 LLM 模型**分析风格(使用用户配置的默认模型):

```javascript
sessions_spawn({
  model: "default",  // 使用用户配置的默认模型
  task: `分析这张 PPT 截图的视觉风格,提取以下信息:

1. 配色方案:
   - 主色(用于标题/重点)
   - 辅助色(用于副标题/装饰)
   - 背景色
   - 文字色

2. 布局结构:
   - 标题位置和样式
   - 内容区域划分
   - 留白比例

3. 字体风格:
   - 标题字体(粗细/大小层次)
   - 正文字体

4. 装饰元素:
   - 线条/形状
   - 图标/图形
   - 其他装饰

请以 JSON 格式输出风格描述。`,
  // 图片通过会话上下文传入
})
```

### 输出格式

```json
{
  "colors": {
    "primary": "#1E3A8A",
    "secondary": "#3B82F6",
    "background": "#FFFFFF",
    "text": "#1F2937",
    "accent": "#60A5FA"
  },
  "layout": {
    "titlePosition": "top-left",
    "titleSize": "large",
    "contentArea": "center",
    "whitespaceRatio": 0.3
  },
  "typography": {
    "titleFont": "bold, 36-48px",
    "bodyFont": "regular, 18-24px",
    "hierarchy": "clear distinction between title and body"
  },
  "decorations": {
    "shapes": ["rounded rectangles", "lines"],
    "icons": "minimal, line-style",
    "other": "subtle shadows"
  }
}
```

### 用户确认

展示分析结果,询问用户:
```
我分析了您提供的风格示例,提取出以下风格:
- 主色调:#1E3A8A(深蓝)
- 背景:白色
- ...

是否符合预期?需要调整哪些方面?
```

用户可以:
- 确认使用
- 修改颜色值
- 调整布局偏好
- 提供新的风格描述

---

## Step 2: 大纲生成

### 输入
- 文稿内容(文本)
- 可选图片列表(本地路径或 URL)
- 已确认的风格

### 执行

分析文稿结构,生成 PPT 大纲:

```
1. 封面页
   - 标题:{主标题}
   - 副标题:{副标题}
   - 图片:{可选封面图}

2. 目录页
   - 章节:{章节列表}

3. 章节页 x N
   - 标题:{章节标题}
   - 内容:{要点列表,每项 1-2 行}
   - 图片:{配图路径,注明位置意图}
   - 布局建议:{左文右图/上文下图/全图等}

4. 总结页
   - 关键结论
   - 下一步行动

5. 结束页
   - 感谢语
   - 联系方式
```

### 图片处理

如果用户提供了图片:

1. **识别图片意图**:根据上下文判断图片应该放在哪页
2. **规划图片位置**:
   - 数据图表 → 右侧或中央
   - 配图/照片 → 背景或侧边
   - 图标 → 标题旁或要点前
3. **记录图片路径**:本地路径或 URL

### 用户确认

展示大纲,询问:
```
我根据您的文稿生成了 PPT 大纲:

第1页:封面 - "季度工作汇报"
第2页:目录 - 3个章节
第3页:项目进展 - 左文右图布局
...

共 N 页。确认后我开始生成 HTML 预览。
需要调整页面顺序、合并/拆分页面吗?
```

---

## Step 2.5: AI 配图生成(可选)

### 询问用户

大纲确认后,询问用户是否需要 AI 生成配图:

```
您的 PPT 大纲已生成。是否需要我为您生成 AI 配图?

选择:
1. 全部页面生成配图
2. 仅部分页面生成配图(请告诉我哪些页)
3. 不需要配图,继续下一步
```

### 配图策略

根据页面类型生成不同风格的配图:

| 页面类型 | 配图风格 | 示例提示词 |
|----------|----------|-----------|
| 封面页 | 抽象科技/城市/行业背景 | "抽象科技背景,蓝色渐变,现代化数字城市,简洁几何图形" |
| 概述页 | 概念插图/流程图风格 | "业务流程概念图,简洁扁平风格,蓝色主色调" |
| 数据页 | 数据可视化风格 | "数据分析概念插图,图表和仪表盘,科技感" |
| 总结页 | 积极向上的概念图 | "成功合作概念图,握手或团队,商务风格" |

### 执行流程

#### 1. 分析页面内容,生成提示词

```javascript
// 对每个需要配图的页面
const imagePrompt = await generateImagePrompt(slideContent, styleColors);

// 示例输出
{
  "slide": 3,
  "type": "概念插图",
  "prompt": "数字化道路概念图,智慧交通,蓝色科技风格,简洁扁平化设计,现代城市道路俯视图,带有数据流线条,16:9横幅"
}
```

#### 2. 调用 nanobanana 生成图片

```bash
python3 ${CLAUDE_PLUGIN_ROOT}/skills/nanobanana-skill/nanobanana.py \
  --prompt "数字化道路概念图,智慧交通,蓝色科技风格,简洁扁平化设计" \
  --size 1344x768 \
  --output "/path/to/output/slide-3-illustration.png"
```

#### 3. 图片参数设置

```javascript
const imageConfig = {
  // 横版配图(适合 PPT)
  size: "1344x768",  // 16:9 横幅
  
  // 方形配图(适合图标、小插图)
  sizeSquare: "1024x1024",
  
  // 默认模型
  model: "gemini-3-pro-image-preview",
  
  // 快速模型(可选)
  modelFast: "gemini-2.5-flash-image",
  
  // 分辨率
  resolution: "1K"
};
```

### 配图提示词模板

#### 封面配图

```
{主题}概念背景图,{风格描述},{主色调}渐变,
现代化{行业}场景,简洁几何图形装饰,
专业商务风格,适合PPT封面,16:9横幅
```

#### 内容页配图

```
{页面主题}概念插图,{具体描述},
扁平化设计风格,{主色调}主色调,
简洁专业,适合PPT内容页,16:9横幅
```

#### 数据/图表配图

```
数据分析可视化概念图,{具体描述},
科技感设计,{主色调}配色,
简洁现代,适合PPT数据展示页,16:9横幅
```

### 配图风格指南

根据提取的风格调整配图:

```javascript
function adaptPromptToStyle(basePrompt, extractedStyle) {
  const colorWords = {
    "#003366": "深蓝色",
    "#3366CC": "蓝色",
    "#1E3A8A": "海军蓝",
    "#22C55E": "绿色",
    "#F97316": "橙色"
  };
  
  const primaryColorWord = colorWords[extractedStyle.colors.primary] || "蓝色";
  
  return `${basePrompt},${primaryColorWord}主色调,与PPT风格协调`;
}
```

### 生成后的处理

1. **保存图片**到工作目录
2. **更新大纲**中的图片路径
3. **展示预览**给用户确认
4. **可选调整**:用户可以说"重新生成第3页配图"

---

## Step 3: HTML 生成

### 16:9 页面规格

```css
.slide {
  width: 1920px;
  height: 1080px;
  aspect-ratio: 16 / 9;
  /* 或响应式: */
  width: 100%;
  aspect-ratio: 16 / 9;
}
```

### 模板参考

使用 `assets/html-template/` 中的模板:

```html
<!DOCTYPE html>
<html>
<head>
  <link rel="stylesheet" href="base.css">
  <style>
    /* 注入用户风格 */
    :root {
      --primary-color: {{colors.primary}};
      --secondary-color: {{colors.secondary}};
      --background-color: {{colors.background}};
      --text-color: {{colors.text}};
    }
  </style>
</head>
<body>
  <div class="slide" id="slide-1">
    <!-- 内容 -->
  </div>
</body>
</html>
```

### 布局类型

参考 `references/work-report-layouts.md` 中的布局模板:
- 封面布局
- 标题+正文布局
- 左文右图布局
- 对比布局
- 数据展示布局

### 图片嵌入

```html
<!-- AI生成的配图 -->
<img src="/path/to/ai-generated-illustration.png" alt="配图描述">

<!-- 用户提供的图片 -->
<img src="/local/path/to/image.png" alt="描述">

<!-- 网络图片 -->
<img src="https://example.com/image.png" alt="描述">

<!-- 样式:自动缩放适配 -->
<style>
.slide img {
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}
</style>
```

---

## Step 4: Canvas 预览

### 展示方式

使用 `canvas` 工具或本地服务器展示 HTML:

```javascript
// 方式1: canvas(需要 node)
canvas({
  action: "present",
  url: "file:///path/to/slides.html"
})

// 方式2: 本地服务器
// 启动服务器后用浏览器预览
```

### 交互功能

用户可以:
- **翻页**:点击左右箭头或按钮
- **对话修改**:说"把标题改成蓝色"、"调整第3页布局"
- **预览截图**:查看渲染效果

### 迭代修改

接收用户修改指令,更新 HTML,刷新预览。

---

## Step 5: 导出 PPTX

### 使用 pptxgenjs

```javascript
import pptxgen from "pptxgenjs";

let pres = new pptxgen();
pres.layout = "LAYOUT_16x9";

// 应用风格
pres.theme = {
  headFontFace: "Microsoft YaHei",
  bodyFontFace: "Microsoft YaHei"
};

// 添加幻灯片
let slide = pres.addSlide();

// 添加文本
slide.addText("标题", {
  x: 0.5, y: 0.5, w: "90%", h: 1,
  fontSize: 36, color: "1E3A8A", bold: true
});

// 添加 AI 生成的配图
slide.addImage({
  path: "/path/to/ai-generated-illustration.png",
  x: 6, y: 2, w: 4, h: 3
});

// 保存
pres.writeFile({ fileName: "output.p