微信小程序 视频弹幕发送

1. 目录结构

在这里插入图片描述

2. videoDanmu
<!-- 视频区域 -->
<video src="{{src}}"
id='video'
danmu-btn
enable-danmu
danmu-list="{{ danmuList }}"
>
</video>

<!-- 弹幕发送区域 -->
<view class='sendDanmu'>
    <textarea name="" id="" cols="30" rows="10" placeholder="请输入弹幕"
    bindinput="handleDanmuContent" 
    ></textarea>
    <button type='primary' bindtap="handleSendDanmu"> 发送 </button>
</view>

<!-- 是否随机颜色 -->
<view class='selectColor'>
    <text> 随机颜色 </text>
    <switch bindchange='handleChange'></switch>
</view>

<!-- 选择默认颜色 -->

<view class='selectDefaultColor' bindtap="handleGotoSelectColor">
    <text> 选择颜色 </text>
    <view style="background: {{ defaultColor }}"></view>
</view>
/* pages/videoDanmu/videoDanmu.wxss */

#video{
    width: 100%;
    height: calc(750rpx * 225 / 300);
}

.sendDanmu{
    display: flex;
    height: 100rpx;
}

.sendDanmu textarea{
    border: 1px solid #ddd;
    height: 100rpx;
}

.selectColor{
    display: flex;
    justify-content: space-between;
    margin-top: 20rpx;
    border: 1px solid #ddd;
    align-items: center;
}

.selectDefaultColor{
    display: flex;
    justify-content: space-between;
    align-items: center;
    border: 1px solid #ddd;
    margin-top: 20rpx;
    margin-right: 30rpx;
}

.selectDefaultColor view{
    width: 50rpx;
    height: 50rpx;
    background-color: red;
}

// pages/videoDanmu/videoDanmu.js
Page({

    /**
     * 页面的初始数据
     */
    data: {
        // 视频地址
        src:"http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400&bizid=1023&hy=SH&fileparam=302c020101042530230204136ffd93020457e3c4ff02024ef202031e8d7f02030f42400204045a320a0201000400",
        danmuList:
        [{
          text: '第 1s 出现的弹幕',
          color: '#ff0000',
          time: 1
        }, {
          text: '第 3s 出现的弹幕',
          color: '#ff00ff',
          time: 3
        }],  // 初始弹幕列表
        defaultColor: 'red',  // 弹幕默认颜色
        isRandomColor: false,  // 控制弹幕是否随机颜色

    },

    // 获取弹幕内容
    handleDanmuContent(e){
        this.content = e.detail.value;

    },
    // 随机弹幕颜色
    randomColor(){
        let red = Math.random() * 255;
        let green = Math.random() * 255;
        let blue = Math.random() * 255;
        return `rgb(${red}, ${green}, ${blue})`
    },
    // 发送弹幕
    handleSendDanmu(){
        let color = '';
        // 通过状态值判断是默认颜色还是随机颜色
        if(this.data.isRandomColor){
            color = this.randomColor()
        }else{
            color = this.data.defaultColor
        }
        this.videoContext.sendDanmu({
            text: this.content,
            color
          })
    },
    // 处理弹幕是否随机颜色
    handleChange(e){
        // console.log(e.detail.value)
        this.setData({
            isRandomColor: e.detail.value
        })
    },
    // 跳转到选择颜色页面
    handleGotoSelectColor(){
        wx.navigateTo({
          url: "/pages/selectColor/selectColor",
        })
    },

    /**
     * 生命周期函数--监听页面初次渲染完成
     */
    onReady: function () {
        // 创建 video 上下文 VideoContext 对象。通过这个对象发送弹幕
        this.videoContext = wx.createVideoContext('video', this)
    }
})
3. selectColor

<view class='color-wrap'>
    <view wx:for="{{ color }}" wx:key='index'
    style="background: {{ item.number }}"
    bindtap="handleGetColor"
    data-color=" {{ item.number }} "
    >
        {{ item.color }}
    </view>
</view>
/* pages/selectColor/selectColor.wxss */

.color-wrap{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}

.color-wrap view{
    width: 100rpx;
    height: 100rpx;
    background-color: red;
    margin-top: 20rpx;
}
// pages/selectColor/selectColor.js
import color from './color'
Page({

    /**
     * 页面的初始数据
     */
    data: {
        color
    },
    // 获取选择的颜色
    handleGetColor(e){
        // console.log(e.currentTarget.dataset.color)
        const color = e.currentTarget.dataset.color;
        // 获取页面栈
        const pages = getCurrentPages()
        const page = pages[0]; // 上一页面
        page.setData({
            defaultColor: color
        })
        // 返回上一页面
        wx.navigateBack({
          delta: 0,
        })
    }
})
export default [
    { key: 1, color: ' 白色 ', number: '#FFFFFF' },
  
    { key: 2, color: ' 红色 ', number: '#FF0000' },
  
    { key: 3, color: ' 绿色 ', number: '#00FF00' },
  
    { key: 4, color: ' 蓝色 ', number: '#0000FF' },
  
    { key: 5, color: ' 牡丹红 ', number: '#FF00FF' },
  
    { key: 6, color: ' 青色 ', number: '#00FFFF' },
  
    { key: 7, color: ' 黄色 ', number: '#FFFF00' },
  
    { key: 8, color: ' 黑色 ', number: '#000000' },
  
    { key: 9, color: ' 海蓝 ', number: '#70DB93' },
  
    { key: 10, color: ' 巧克力色 ', number: '#5C3317' },
  
    { key: 11, color: ' 蓝紫色 ', number: '#9F5F9F' },
  
    { key: 12, color: ' 黄铜色 ', number: '#B5A642' },
  
    { key: 13, color: ' 亮金色 ', number: '#D9D919' },
  
    { key: 14, color: ' 棕色 ', number: '#A67D3D' },
  
    { key: 15, color: ' 青铜色 ', number: '#8C7853' },
  
    { key: 16, color: ' 2号青铜色 ', number: '#A67D3D' },
  
    { key: 17, color: ' 士官服蓝色 ', number: '#5F9F9F' },
  
    { key: 18, color: ' 冷铜色 ', number: '#D98719' },
  
    { key: 19, color: ' 铜色 ', number: '#B87333' },
  
    { key: 20, color: ' 珊瑚红 ', number: '#FF7F00' },
  
    { key: 21, color: ' 紫蓝色 ', number: '#42426F' },
  
    { key: 22, color: ' 深棕 ', number: '#5C4033' },
  
    { key: 23, color: ' 深绿 ', number: '#2F4F2F' },
  
    { key: 24, color: ' 深铜绿色 ', number: '#4A766E' },
  
    { key: 25, color: ' 深橄榄绿 ', number: '#4F4F2F' },
  
    { key: 26, color: ' 深兰花色 ', number: '#9932CD' },
  
    { key: 27, color: ' 深紫色 ', number: '#871F78' },
  
    { key: 28, color: ' 深石板蓝 ', number: '#6B238E' },
  
    { key: 29, color: ' 深铅灰色 ', number: '#2F4F4F' },
  
    { key: 30, color: ' 深棕褐色 ', number: '#97694F' },
  
    { key: 32, color: ' 深绿松石色 ', number: '#7093DB' },
  
    { key: 33, color: ' 暗木色 ', number: '#855E42' },
  
    { key: 34, color: ' 淡灰色 ', number: '#545454' },
  
    { key: 35, color: ' 土灰玫瑰红色 ', number: '#856363' },
  
    { key: 36, color: ' 长石色 ', number: '#D19275' },
  
    { key: 37, color: ' 火砖色 ', number: '#8E2323' },
  
    { key: 38, color: ' 森林绿 ', number: '#238E23' },
  
    { key: 39, color: ' 金色 ', number: '#CD7F32' },
  
    { key: 40, color: ' 鲜黄色 ', number: '#DBDB70' },
  
    { key: 41, color: ' 灰色 ', number: '#C0C0C0' },
  
    { key: 42, color: ' 铜绿色 ', number: '#527F76' },
  
    { key: 43, color: ' 青黄色 ', number: '#93DB70' },
  
    { key: 44, color: ' 猎人绿 ', number: '#215E21' },
  
    { key: 45, color: ' 印度红 ', number: '#4E2F2F' },
  
    { key: 46, color: ' 土黄色 ', number: '#9F9F5F' },
  
    { key: 47, color: ' 浅蓝色 ', number: '#C0D9D9' },
  
    { key: 48, color: ' 浅灰色 ', number: '#A8A8A8' },
  
    { key: 49, color: ' 浅钢蓝色 ', number: '#8F8FBD' },
  
    { key: 59, color: ' 浅木色 ', number: '#E9C2A6' },
  
    { key: 60, color: ' 石灰绿色 ', number: '#32CD32' },
  
    { key: 61, color: ' 桔黄色 ', number: '#E47833' },
  
    { key: 62, color: ' 褐红色 ', number: '#8E236B' },
  
    { key: 63, color: ' 中海蓝色 ', number: '#32CD99' },
  
    { key: 64, color: ' 中蓝色 ', number: '#3232CD' },
  
    { key: 65, color: ' 中森林绿 ', number: '#6B8E23' },
  
    { key: 66, color: ' 中鲜黄色 ', number: '#EAEAAE' },
  
    { key: 67, color: ' 中兰花色 ', number: '#9370DB' },
  
    { key: 68, color: ' 中海绿色 ', number: '#426F42' },
  
    { key: 69, color: ' 中石板蓝色 ', number: '#7F00FF' },
  
    { key: 70, color: ' 中春绿色 ', number: '#7FFF00' },
  
    { key: 71, color: ' 中绿松石色 ', number: '#70DBDB' },
  
    { key: 72, color: ' 中紫红色 ', number: '#DB7093' },
  
    { key: 73, color: ' 中木色 ', number: '#A68064' },
  
    { key: 74, color: ' 深藏青色 ', number: '#2F2F4F' },
  
    { key: 75, color: ' 海军蓝 ', number: '#23238E' },
  
    { key: 76, color: ' 霓虹篮 ', number: '#4D4DFF' },
  
    { key: 77, color: ' 霓虹粉红 ', number: '#FF6EC7' },
  
    { key: 78, color: ' 新深藏青色 ', number: '#00009C' },
  
    { key: 79, color: ' 新棕褐色 ', number: '#EBC79E' },
  
    { key: 80, color: ' 暗金黄色 ', number: '#CFB53B' },
  
    { key: 81, color: ' 橙色 ', number: '#FF7F00' },
  ];
4. 效果图

在这里插入图片描述

颜色选择
在这里插入图片描述

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
【为什么学习微信小程序?】   小程序开发为当下一种主流的开发形式,小程序开发已经不仅仅局限于互联网行业,传统行业同样也有海量的需求,掌握小程序开发不仅仅是掌握了一个新的开发技能,更可以增加大家的行业竞争力,无论是在岗位的提升,求职面试、或者个人创业都是有很大的帮助。掌握了小程序开发小程序也是一门相对比较容易上手的技术,因为小程序开发容纳了前端、后端、运维等岗位所需掌握的知识但又极为简单好理解,对于刚刚入门或者小白用户是一个可以快速掌握并成为一名程序猿的不二途径。 【推荐你学习这门课程的四大亮点】 1、完整成体系的小程序开发知识: 对于没有学习过小程序开发的同学,本课程由浅入深系统的向同学们讲解了小程序开发知识,将知识点串联起来,让同学们可以更好更快的掌握小程序开发。2、视频及相关功能开发的掌握: 借助于小程序开发使得视频方向的开发变的尤为简单,即使你是入门小白也可以熟练掌握小程序中视频的相关开发,其中涉及了视频的常规控制如播放暂停等也有比较流行的视频弹幕功能,并结合了一下视频开发中相关的性能优化问题,可以让同学们通过本课程的学习对于视频类的开发有更深层次的认识。3、打造智能闲聊小程序: 借助于网络上开放的人工智能接口,去实现智能闲聊功能,使得开发的过程不仅能够收获更多的知识也变得更加有趣。项目中虽然知识讲解了智能闲聊功能的调用,但是通过此功能的调用方法大家可以举一反三去使用更多的开发功能使得开发变得简单且有趣。4、掌握项目级开发知识及技巧: 本课程中融入了两大当前比较主流的项目实例,视频功能和人工智能。通过项目的练习不仅可以让大家掌握较为主流的项目方向且融入很多的中高级语法及项目开发知识,如ES6+的一些语法和模块化、组件化开发的知识。【课程内容设计】   设计本门课程时考虑到很多同学可能没有小程序开发相关经验,本门课程将由浅入深,渐进式的讲解知识点。我把课程分为了三个阶段分别为:初次接触、基础入门、实战提升。   1、初次接触:   主要给大家讲解小程序开发的相关知识,让大家在宏观上对向程序开发能有一定的概念。并且讲授的开发环境的搭建让大家对在开发前期做一个充分的热身。先激发起大家对线程序开发的热情,这样为下一步小程序的开发学习做一个铺垫。   2、基础入门:   这个阶段主要为入门的同学提供了一个比较全面的小程序开发基础知识知识汇总,并伴有实践的例子简单且易上手,让大家能够体验到小程序的开发乐趣,并未下一步的项目实战开发打定基础。   3、实战提升:   这个阶段为项目实践阶段,通过实战项目让大家深入了解和学习小程序开发,项目中同时融入了现在主流的视频内容,和有趣并贴近生活的智能闲聊功能,项目中涉及到的技术点也是由浅入深,同学们在掌握小程序的开发能力的同时也掌握了问题解决与深入学习的能力。 【实战项目展示】 【学习完课程你将收获】
微信小程序实时弹幕功能是指在小程序中用户可以实时发送和接收消息弹幕的功能。用户可以通过输入框输入弹幕内容,发送到服务器,然后其他用户可以实时接收到这些弹幕,从而形成实时的弹幕效果。 实现微信小程序实时弹幕功能的关键是前后端的数据交互和实时通信。首先,在小程序中,我们需要一个输入框和发送按钮,用户可以在输入框中输入弹幕内容,并通过点击发送按钮将弹幕发送到服务器。其次,服务器需要接收到这些弹幕消息,并即刻推送给其他用户。这可以通过使用 WebSocket 进行实时通信来实现。 在小程序端,我们可以使用小程序提供的 WebSocket 接口,与服务器建立 WebSocket 连接。当用户发送弹幕时,将弹幕消息通过 WebSocket 发送给服务器。服务器接收到弹幕消息后,可以将消息广播给所有已经建立 WebSocket 连接的用户。其他用户通过监听 WebSocket 的消息事件,即可接收到服务器发送弹幕消息,并将其实时展示在屏幕上。 为了保证弹幕的实时性和流畅性,我们需要在服务器端对弹幕消息进行处理和管理。比如设置弹幕消息的过期时间,只展示最新的 N 条弹幕,避免消息过多造成界面混乱。同时,为了避免弹幕内容不合法或者恶意攻击,需要对用户输入进行过滤和校验。 总结来说,微信小程序实时弹幕功能通过前后端的数据交互和实时通信实现。用户在小程序中发送弹幕消息,服务器接收并在实时广播给其他用户,实现实时弹幕的效果。这个功能可以让用户之间更好地互动和沟通,提升小程序的用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值