弹幕组件使用说明
功能特性
- 固定高度200px的弹幕容器
 
- 支持无限滚动和单次滚动模式
 
- 多轨道智能分配,避免弹幕叠加
 
- 弹幕宽度根据文字长度自适应
 
- 支持用户头像显示(必显示)
 
- 自动清理已播放的弹幕
 
- 可自定义滚动速度
 
- 智能轨道占用管理
 
使用方法
基础用法
<template>
  <danmakuManager 
    :danmakuList="danmakuList" 
    :height="200" 
    :infinite="true"
    :speed="80"
    @danmakuComplete="onDanmakuComplete"
  ></danmakuManager>
</template>
<script setup>
import danmakuManager from "@/components/danmakuManager/danmakuManager.vue"
const danmakuList = ref([
  {
    text: "晨曦微露,阳光洒满大地",
    avatar: "头像URL"
  },
  {
    text: "守护果树,收获美好",
    avatar: null
  }
])
const onDanmakuComplete = (id) => {
  console.log('弹幕播放完成:', id)
}
</script>
Props 参数
| 参数 | 
类型 | 
默认值 | 
说明 | 
| danmakuList | 
Array | 
[] | 
弹幕数据列表 | 
| height | 
Number | 
200 | 
容器高度(px) | 
| infinite | 
Boolean | 
true | 
是否无限循环 | 
| speed | 
Number | 
100 | 
弹幕滚动速度(px/s) | 
| trackCount | 
Number | 
8 | 
弹幕轨道数量 | 
| spacing | 
Number | 
20 | 
弹幕间距 | 
弹幕数据格式
{
  text: "弹幕文本内容",
  avatar: "头像URL" // 必填,如果为null会使用默认头像
}
事件
| 事件名 | 
参数 | 
说明 | 
| danmakuComplete | 
id | 
弹幕播放完成时触发 | 
方法
组件暴露了以下方法供父组件调用:
addDanmaku(text, avatar) - 动态添加弹幕 
clearDanmakus() - 清空所有弹幕 
startDanmakuAnimation() - 开始弹幕动画 
stopDanmakuAnimation() - 停止弹幕动画 
无限滚动 vs 单次滚动
<!-- 无限滚动 -->
<danmakuManager :infinite="true" :danmakuList="danmakuList"></danmakuManager>
<!-- 单次滚动 -->
<danmakuManager :infinite="false" :danmakuList="danmakuList"></danmakuManager>
样式定制
弹幕组件使用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),确保弹幕流畅显示且减少叠加
 
- 在保证弹幕正常显示的前提下,尽可能避免叠加
 
- 修复过于严格的轨道分配导致的弹幕不显示问题