Commit Graph

22 Commits

Author SHA1 Message Date
root 346762499e fix: command 2025-07-11 12:00:08 +08:00
root 44a669b6fc 检查文件是否存在 2025-07-11 11:39:11 +08:00
root 766d59cdf0 fix: 播放器播放问题 2025-07-11 11:18:14 +08:00
root 074a6b7834 fix: 素材管理 2025-07-11 11:08:48 +08:00
root 9e95d73087 fix 2025-07-11 10:51:38 +08:00
root d6983ab824 模特管理 2025-07-11 10:26:05 +08:00
root 01b6603eec fix 2025-07-11 01:36:13 +08:00
root aaf96c5aed fix 2025-07-11 01:09:20 +08:00
root 010080f61e 素材分类管理 2025-07-11 00:29:09 +08:00
root e0fbb1124d fix: add template track 2025-07-10 23:06:18 +08:00
root 920b0462b5 封装jsonrpc通信机制 2025-07-10 22:26:29 +08:00
root aae64d4d04 template upgrade 2025-07-10 21:21:16 +08:00
root 04e5990376 refactor: extract common Python execution patterns into reusable shared code
- Create python_executor.rs module with unified Python command execution
- Remove duplicate execute_python_command functions from ai_video.rs and template.rs
- Eliminate 553 lines of duplicate code across both files
- Improve error handling and JSON-RPC message parsing consistency
- Fix template import 'Unknown error' issue by using unified JSON parsing
- Add configurable timeout and encoding settings
- Ensure consistent UTF-8 encoding across all Python executions
2025-07-10 20:45:54 +08:00
root c73aeb58e9 feat: 添加完整的模板管理系统
🎉 新功能:
- 批量导入模板功能,支持文件夹结构解析
- 自动解析 draft_content.json 并提取轨道/素材信息
- 智能素材管理,自动复制到统一资源目录
- 路径转换为相对路径,确保模板可移植性
- 现代化的模板管理界面,支持网格/列表视图
- 搜索和筛选功能
- 模板详情预览和删除功能

🏗️ 技术实现:
- Python: TemplateManager 核心服务类
- Rust/Tauri: 跨平台命令处理和进程管理
- React/TypeScript: 响应式前端界面
- JSON-RPC: 前后端通信协议

📁 文件结构:
- 模板存储在 attachments/templates/{uuid}/ 目录
- 素材统一管理在 resources/ 子目录
- 元数据存储在 templates.json 文件

 已测试功能:
- 批量导入多个模板
- 模板列表显示和搜索
- 模板详情查看
- 模板删除操作
- CLI 命令行接口

这个系统为视频编辑提供了强大的模板管理能力,
支持从外部导入模板并自动处理素材依赖关系。
2025-07-10 20:14:49 +08:00
root 1132cb9777 feat: 添加 AI 视频生成结果预览功能
🎬 新增功能:

1. AI 视频结果预览组件 (AIVideoResultPreview):
   - 支持单个和批量视频生成结果预览
   - 内置视频播放器,支持在线播放
   - 显示生成提示词、本地路径、在线链接
   - 批量结果支持视频选择器浏览多个视频
   - 优雅的错误处理和加载状态

2. 视频预览功能:
   - HTML5 视频播放器,支持完整控制
   - 自动使用原图作为视频封面
   - 播放失败时显示友好错误信息
   - 响应式设计,适配不同屏幕尺寸

3. 批量结果管理:
   - 显示批量处理统计信息(成功/失败数量)
   - 视频选择器,方便浏览多个生成结果
   - 每个视频显示对应的提示词和路径信息
   - 统一的操作界面和交互体验

4. 文件系统集成:
   - 新增 open_folder Tauri 命令
   - 跨平台支持(Windows/macOS/Linux)
   - 一键打开视频所在文件夹
   - 备用方案:显示完整文件路径

5. 用户界面增强:
   - 任务完成后显示 '预览视频' 按钮
   - 改进的成功状态显示,包含统计信息
   - 模态对话框形式的预览界面
   - 直观的操作按钮和状态指示

6. 操作功能:
   - 打开文件夹:直接定位到视频文件位置
   - 在新窗口打开:使用浏览器播放在线视频
   - 复制路径:方便用户获取文件信息
   - 关闭预览:返回主界面

 用户体验提升:
- 生成完成后可立即预览结果 ✓
- 批量处理结果一目了然 ✓
- 便捷的文件管理操作 ✓
- 专业的视频播放体验 ✓

现在用户可以直接在应用内预览生成的 AI 视频!
2025-07-10 13:33:11 +08:00
root 0a3b369685 fix: 修复文件选择只显示文件名的问题
🔧 问题修复:

1. 多层级文件选择策略:
   - 优先使用自定义 Tauri 命令 (select_image_file/select_folder)
   - 备用方案:使用 Tauri 插件对话框
   - 最终备用:HTML file input (带路径获取尝试)

2. HTML Input 路径处理改进:
   - 尝试获取 file.path 属性 (Tauri 环境下可用)
   - 如果只能获取文件名,显示警告提示
   - 提醒用户使用桌面应用版本

3. 详细的调试和错误处理:
   - 每个步骤都有详细的控制台日志
   - 清晰的错误信息和回退逻辑
   - 用户友好的错误提示

4. 用户界面改进:
   - 更详细的操作说明和示例
   - 清晰的文件路径格式要求
   - 分步骤的操作指导

5. Rust 命令框架:
   - 添加 select_image_file 和 select_folder 命令
   - 为未来的原生对话框实现预留接口
   - 当前返回错误以触发备用方案

 修复策略:
- 多重备用方案确保文件选择功能可用 ✓
- 详细的用户指导和错误提示 ✓
- 完整的调试信息便于问题排查 ✓
- 为未来的原生对话框实现做好准备 ✓

现在用户应该能够通过多种方式获得完整的文件路径!
2025-07-10 12:22:18 +08:00
root 253d0ccdd1 fix: 修复文件选择功能 - 添加 Tauri 对话框支持
🔧 主要修复:

1. Tauri 插件配置:
   - 添加 tauri-plugin-dialog 依赖
   - 添加 tauri-plugin-fs 依赖
   - 在 Rust 中注册对话框和文件系统插件
   - 清理重复的依赖项

2. 文件选择功能增强:
   - 使用 Tauri 原生文件对话框 API
   - 支持图片格式过滤 (jpg, jpeg, png, bmp, gif, tiff, webp)
   - 添加详细的调试日志
   - 改进错误处理和用户提示

3. 用户体验优化:
   - 文件选择失败时提供备用方案
   - 添加手动输入路径选项
   - 显示选中文件的文件名
   - 为所有按钮添加工具提示

4. 兼容性处理:
   - 处理对话框返回值的不同格式 (string | string[])
   - 保留 HTML input 作为备用方案
   - 添加详细的错误信息和解决建议

 修复效果:
- 图片文件选择:原生对话框 ✓
- 文件夹选择:原生目录选择 ✓
- 输出目录选择:原生对话框 ✓
- 手动路径输入:备用方案 ✓
- 错误处理:友好提示 ✓

现在用户可以通过原生文件对话框轻松选择文件和文件夹!
2025-07-10 11:40:23 +08:00
root 614ed61790 feat: 增强 AI 视频生成错误诊断和调试功能
🔍 问题分析:
- 原始错误信息过于简单 (Unknown error)
- 缺乏详细的错误追踪和调试信息
- Python 模块相对导入问题

🛠️ 解决方案:

1. 全面错误处理增强:
   - Python 模块:添加详细错误类型、消息和堆栈跟踪
   - Rust 命令:增加执行日志和错误详情
   - 前端服务:完整的错误信息传递和显示

2. 环境诊断工具:
   - 新增 test_ai_video_environment 命令
   - 检查 Python 版本、模块导入、依赖包
   - 前端环境测试按钮和结果显示

3. 导入问题修复:
   - 修复相对导入在直接运行时的问题
   - 添加 fallback 机制支持独立脚本运行
   - 统一模块导入逻辑

4. 调试功能:
   - 详细的执行日志输出
   - 错误分类和追踪
   - 前端控制台错误详情

 测试结果:
- Python 模块可正常导入 ✓
- 脚本可独立运行 ✓
- 云存储上传成功 ✓
- API 任务提交成功 ✓
- 错误信息详细可追踪 ✓

现在可以精确定位 AI 视频生成过程中的具体问题!
2025-07-10 11:10:32 +08:00
root d6c53b6570 fix: 优化事件循环处理,解决 tao 警告
🔧 问题分析:
- tao 事件循环警告:NewEvents/RedrawEventsCleared 顺序问题
- 自定义标题栏事件处理过于频繁
- React 组件状态更新导致过多重绘

🛠️ 优化措施:
1. 标题栏事件优化:
   - 添加事件防抖和节流
   - 改善拖拽事件处理时机
   - 优化窗口状态监听频率

2. 状态管理优化:
   - AI 视频 store 添加更新节流
   - 防止快速进度更新导致的重绘

3. 日志配置优化:
   - 过滤 tao 事件循环警告
   - 调整日志级别减少噪音

4. 性能 Hook:
   - 新增 useDebounce/useThrottle hooks
   - 防止组件过度渲染

 效果:
- 减少事件循环警告
- 提升 UI 响应性能
- 优化窗口操作体验
2025-07-10 10:58:55 +08:00
root 5f31df6851 fix: 修复 Rust 编译错误
🔧 修复内容:
- 添加缺失的 execute_python_command 函数
- 移除未使用的导入 (tauri::Manager, tauri::State)
- 统一 Python 命令执行逻辑

 编译状态:
- Rust 编译成功 ✓
- 前端构建成功 ✓
- 所有警告已清除 ✓

现在 AI 视频生成功能可以正常编译和运行了!
2025-07-10 10:49:15 +08:00
root 96e166725b feat: 集成 AI 视频生成功能到 MixVideo V2
🎬 主要功能:
-  完整的 AI 视频生成模块 (Python)
-  图片转视频 API 集成 (字节跳动 Seedance)
-  云存储支持 (腾讯云 COS)
-  单张图片和批量处理模式
-  现代化 React 界面组件
-  Tauri 桥接通信

🛠️ 技术实现:
- Python 模块:VideoGenerator, CloudStorage, APIClient
- Rust 命令:generate_ai_video, batch_generate_ai_videos
- React 组件:AIVideoGenerator, AIVideoPage
- 状态管理:useAIVideoStore (Zustand)
- 路由集成:/ai-video 页面

�� 新增文件:
- python_core/ai_video/ - AI 视频生成核心模块
- src/components/AIVideoGenerator.tsx - 主要 UI 组件
- src/pages/AIVideoPage.tsx - AI 视频生成页面
- src/stores/useAIVideoStore.ts - 状态管理

🎯 功能特性:
- 支持 Lite (720p) 和 Pro (1080p) 模型
- 可配置视频时长 (5秒/10秒)
- 实时进度跟踪和任务管理
- 批量处理多张图片
- 云存储自动上传下载
- 错误处理和重试机制

🔗 界面集成:
- 侧边栏导航添加 'AI 视频' 入口
- 首页快速操作卡片
- 完整的用户引导和帮助文档

这是从原始 Tkinter GUI 到现代 Web 应用的完整迁移!
2025-07-10 10:43:40 +08:00
root 7d72e07639 first commit 2025-07-10 09:41:40 +08:00