# 弹幕组件使用说明
## 功能特性
- 固定高度200px的弹幕容器
- 支持无限滚动和单次滚动模式
- 多轨道智能分配,避免弹幕叠加
- 弹幕宽度根据文字长度自适应
- 支持用户头像显示(必显示)
- 自动清理已播放的弹幕
- 可自定义滚动速度
- 智能轨道占用管理
## 使用方法
### 基础用法
```vue
```
### Props 参数
| 参数 | 类型 | 默认值 | 说明 |
|------|------|--------|------|
| danmakuList | Array | [] | 弹幕数据列表 |
| height | Number | 200 | 容器高度(px) |
| infinite | Boolean | true | 是否无限循环 |
| speed | Number | 100 | 弹幕滚动速度(px/s) |
| trackCount | Number | 8 | 弹幕轨道数量 |
| spacing | Number | 20 | 弹幕间距 |
### 弹幕数据格式
```javascript
{
text: "弹幕文本内容",
avatar: "头像URL" // 必填,如果为null会使用默认头像
}
```
### 事件
| 事件名 | 参数 | 说明 |
|--------|------|------|
| danmakuComplete | id | 弹幕播放完成时触发 |
### 方法
组件暴露了以下方法供父组件调用:
- `addDanmaku(text, avatar)` - 动态添加弹幕
- `clearDanmakus()` - 清空所有弹幕
- `startDanmakuAnimation()` - 开始弹幕动画
- `stopDanmakuAnimation()` - 停止弹幕动画
### 无限滚动 vs 单次滚动
```vue
```
## 样式定制
弹幕组件使用8个不同的轨道,每个轨道有不同的背景色:
- track-0: 红色
- track-1: 绿色
- track-2: 蓝色
- track-3: 黄色
- track-4: 紫色
- track-5: 青色
- track-6: 橙色
- track-7: 紫罗兰色
可以通过修改CSS来自定义轨道样式。
## 新增功能说明
### 1. 自适应宽度
- 弹幕宽度根据文字长度自动调整
- 使用 `width: fit-content` 实现自适应
- 设置最小宽度确保视觉效果
### 2. 必显示头像
- 每个弹幕都会显示用户头像
- 如果没有提供头像,会使用默认头像
- 头像大小固定为32rpx,圆形显示
### 3. 智能轨道管理
- 避免弹幕在同一轨道叠加
- 避免弹幕在相邻轨道叠加
- 智能分配可用轨道,确保轨道间距
- 记录轨道占用时间,自动释放
- 如果所有轨道都被占用,选择最早释放的轨道
### 4. 弹幕消失优化
- 确保弹幕完全离开可视范围才消失
- 增加额外的消失距离,避免弹幕突然消失
- 优化弹幕播放间隔,避免过于密集
### 5. 高度自适应优化
- 根据容器高度动态调整轨道间距
- 防止弹幕超出容器边界显示不完整
- 动态调整播放间隔,避免低高度容器中弹幕叠加
- 添加边界保护,确保弹幕完全显示
### 6. 弹幕稳定性优化
- 修复弹幕在滚动过程中高度掉下来的问题
- 确保弹幕在容器边界内完全显示
- 优化轨道分配算法,避免超出容器边界
- 固定弹幕元素高度,防止滚动时变形
### 7. 弹幕显示完整性优化
- 增加弹幕消失的缓冲距离,确保完全显示后再消失
- 优化弹幕宽度计算,更精确地估算文字宽度
- 增加内边距和文字间距,确保文字显示完整
- 延长弹幕动画时间,避免过早消失
### 8. 低高度容器优化
- 针对100px等低高度容器进行特殊优化
- 增加轨道间距,避免弹幕垂直叠加
- 减少可用轨道数量,确保弹幕有足够空间
- 增加播放间隔时间,避免弹幕过于密集
- 优化时间间隔计算,确保相邻弹幕不会叠加
### 9. 彻底解决叠加问题
- 采用严格轨道分配策略,只使用完全空闲的轨道
- 当没有空闲轨道时,暂停添加新弹幕
- 进一步减少低高度容器的可用轨道数量(最多2个)
- 大幅增加播放间隔时间,确保弹幕完全分离
- 避免任何形式的弹幕叠加,保证观看体验
### 10. 修复显示问题
- 优化轨道分配策略,确保弹幕能正常显示
- 采用三级轨道选择策略:完全空闲 > 任何空闲 > 最早释放
- 调整低高度容器的可用轨道数量为3个,平衡显示和防叠加
- 优化播放间隔时间,确保弹幕流畅显示
- 修复过于严格的轨道分配导致的弹幕不显示问题
### 11. 智能安全距离算法
- 实现基于时间的安全距离计算,确保弹幕不会前后叠加
- 采用安全性评分系统,优先选择最安全的轨道
- 低高度容器使用更长的安全时间间隔(3000ms)
- 智能轨道排序:完全安全 > 部分安全 > 等待
- 大幅增加播放间隔时间,确保弹幕完全分离
- 当没有安全轨道时,暂停添加新弹幕,避免强制叠加
### 12. 平衡显示与防叠加
- 回退到更平衡的轨道分配策略,确保弹幕能正常显示
- 采用三级轨道选择策略:完全空闲 > 任何空闲 > 最早释放
- 调整低高度容器的可用轨道数量为3个,平衡显示和防叠加
- 优化播放间隔时间,确保弹幕流畅显示且减少叠加
- 在保证弹幕正常显示的前提下,尽可能避免叠加
### 13. 页面生命周期管理
- 新增 `autoStart` 属性,控制弹幕是否自动开始播放
- 支持父组件手动控制弹幕的启动和停止
- 页面显示时自动启动弹幕,页面隐藏时自动停止弹幕
- 页面卸载时自动清理弹幕资源,避免内存泄漏
- 提供 `startDanmakuAnimation()` 和 `stopDanmakuAnimation()` 方法供外部调用
### 14. 超强防叠加算法
- 实现基于时间的安全距离计算,确保弹幕不会前后叠加
- 采用安全性评分系统,优先选择最安全的轨道
- 低高度容器使用更长的安全时间间隔(4000ms)
- 智能轨道排序:完全安全 > 部分安全 > 等待
- 大幅增加播放间隔时间(5000-9000ms),确保弹幕完全分离
- 当没有安全轨道时,暂停添加新弹幕,避免强制叠加
- 进一步减少低高度容器的可用轨道数量(最多2个)
### 15. 修复显示问题
- 回退到更平衡的轨道分配策略,确保弹幕能正常显示
- 采用三级轨道选择策略:完全空闲 > 任何空闲 > 最早释放
- 调整低高度容器的可用轨道数量为3个,平衡显示和防叠加
- 优化播放间隔时间(3000-5000ms),确保弹幕流畅显示且减少叠加
- 在保证弹幕正常显示的前提下,尽可能避免叠加
- 修复过于严格的轨道分配导致的弹幕不显示问题