问题分析: - 场景检测结果没有正确转换为SceneSegment结构 - create_segments_from_scenes函数逻辑有误 - 缺少对超长片段的二次切分处理 - 没有添加最后一个场景片段 解决方案: 1. 完善场景检测结果转换: - 正确获取视频总时长 - 根据场景切换点创建完整的场景片段 - 添加最后一个场景片段 - 详细的场景信息日志输出 2. 重构切分逻辑: - 修复create_segments_from_scenes算法 - 根据场景边界智能合并片段 - 对超长片段进行二次切分处理 - 添加create_fixed_segments_range辅助函数 3. 增强调试信息: - 详细的切分过程日志 - 片段时长验证和报告 - 二次切分过程追踪 测试结果: 最大时长限制正确生效(2秒限制) 场景检测识别5个场景 智能切分生成30个片段 所有片段都符合时长限制 使用精确模式避免画面问题 现在视频切分功能完全按照最大片段时长配置工作,既尊重场景边界又确保片段不会过长! |
||
|---|---|---|
| .. | ||
| public | ||
| src | ||
| src-tauri | ||
| .gitignore | ||
| README.md | ||
| index.html | ||
| package.json | ||
| postcss.config.js | ||
| tailwind.config.js | ||
| tsconfig.json | ||
| tsconfig.node.json | ||
| vite.config.ts | ||
| vitest.config.ts | ||
README.md
@mixvideo/desktop
MixVideo 桌面应用 - 基于 Tauri + React + TypeScript 构建的跨平台桌面应用。
🚀 快速开始
开发环境要求
- Node.js 18+
- Rust 1.70+
- PNPM 8+
安装依赖
pnpm install
开发模式
pnpm dev
# 或
pnpm tauri:dev
构建应用
pnpm tauri:build
📁 项目结构
apps/desktop/
├── src/ # React 前端源码
│ ├── components/ # React 组件
│ ├── pages/ # 页面组件
│ ├── hooks/ # 自定义 Hooks
│ ├── services/ # API 服务
│ ├── types/ # TypeScript 类型
│ └── utils/ # 工具函数
├── src-tauri/ # Rust 后端源码
│ ├── src/ # Rust 源码
│ ├── Cargo.toml # Rust 依赖配置
│ └── tauri.conf.json # Tauri 配置
├── public/ # 静态资源
└── package.json # 前端依赖配置
🛠️ 技术栈
- 前端: React 18 + TypeScript + Vite
- 后端: Rust + Tauri 2.0
- UI: 待定 (可选择 Ant Design、Material-UI 等)
- 状态管理: 待定 (可选择 Zustand、Redux Toolkit 等)