微信小程序 - 发送视频弹幕

微信小程序官方文档提供了发送视频弹幕的功能,参照其功能做了一些改动,实现可发送用户自定义颜色的弹幕。

function getRandomColor() {var rgb = [];for (var i = 0; i < 3; ++i) {var color = Math.floor(Math.random() * 256).toString(16);color = color.length == 1 ? '0' + color : color;rgb.push(color);}return '#' + rgb.join('');
}
Page({inputValue: '',data: {isRandomColor: true,src: '',numberColor: "#ff0000",danmuList: [{text: '第 1s 出现的红色弹幕',color: '#ff0000',time: 1}, {text: '第 2s 出现的绿色弹幕',color: '#00ff00',time: 2}]},onLoad: function onLoad() {var _this = this;wx.getSystemInfo({success: function success(res) {// video标签默认宽度300px、高度225pxvar windowWidth = res.windowWidth;                var videoHeight = 225 / 300 * windowWidth;_this.setData({videoWidth: windowWidth,videoHeight: videoHeight});}});},onReady: function onReady(res) {this.videoContext = wx.createVideoContext('myVideo');},onShow: function onShow() {var _this = this;wx.getStorage({key: 'numberColor',success: function success(res) {_this.setData({numberColor: res.data});}});},bindInputBlur: function(e) {this.inputValue = e.detail.value;},bindSendDanmu: function() {if (this.data.isRandomColor) {var color = getRandomColor();} else {var color = this.data.numberColor;}this.videoContext.sendDanmu({text: this.inputValue,color: color});},videoErrorCallback: function(e) {console.log('视频错误信息:');console.log(e.detail.errMsg);},switchChange: function(e) {this.setData({isRandomColor: e.detail.value});},//跳转到选择颜色的页面selectColor: function() {wx.navigateTo({url: '../selectColor/selectColor',success: function(res) {},fail: function fail() {},complete: function() {}});}
});
<view class="section tc"><video id="myVideo" style="height:{{videoHeight}}px;width:{{videoWidth}}px" src="http://wxsnsdy.tc.qq.com/105/20210/snsdyvideodownload?filekey=30280201010421301f0201690402534804102ca905ce620b1241b726bc41dcff44e00204012882540400&bizid=1023&hy=SH&fileparam=302c020101042530230204136ffd93020457e3c4ff02024ef202031e8d7f02030f42400204045a320a0201000400" binderror="videoErrorCallback" danmu-list="{{danmuList}}" enable-danmu danmu-btn controls></video><view class="btn-area"><view class="weui-cell weui-cell_input"><view class="weui-cell__bd"><input class="weui-input" placeholder="请输入弹幕" bindblur="bindInputBlur" /></view></view><button type="primary" style="margin:30rpx;" bindtap="bindSendDanmu">发送弹幕</button></view>
</view><view class="weui-cells weui-cells_after-title"><view class="weui-cell weui-cell_switch"><view class="weui-cell__bd">随机颜色</view><view class="weui-cell__ft"><switch checked bindchange="switchChange" /></view></view><view class="colorstyle"  bindtap="selectColor"><text>选择颜色</text><view style="height:80rpx;width:80rpx;line-height: 100rpx;margin:10rpx;background-color:{{numberColor}}"></view></view>
</view>
.weui-cells {position: relative;margin-top: 1.17647059em;background-color: #FFFFFF;line-height: 1.41176471;font-size: 17px;
}
.weui-cells:before {content: " ";position: absolute;left: 0;top: 0;right: 0;height: 1px;border-top: 1rpx solid #D9D9D9;color: #D9D9D9;
}
.weui-cells:after {content: " ";position: absolute;left: 0;bottom: 0;right: 0;height: 1px;border-bottom: 1rpx solid #D9D9D9;color: #D9D9D9;
}
.weui-cells_after-title {margin-top: 0;
}
.weui-cell__bd {-webkit-box-flex: 1;-webkit-flex: 1;flex: 1;
}
.weui-cell__ft {text-align: right;color: #999999;
}.weui-cell {padding: 10px 10px;position: relative;display: -webkit-box;display: -webkit-flex;display: flex;-webkit-box-align: center;-webkit-align-items: center;align-items: center;
}
.weui-cell:before {content: " ";position: absolute;top: 0;right: 0;height: 1px;border-top: 1rpx solid #D9D9D9;color: #D9D9D9;left: 15px;
}
.weui-cell:first-child:before {display: none;
}
.colorstyle{border-top: 2px solid #eee;border-bottom: 2px solid #eee;padding-left: 10px;padding-right: 10px;font-size: 17px;line-height: 100rpx;display: flex;flex-direction: row;justify-content:space-between;
}
.vertical {height: 40px;position: absolute;top: 50%;margin-top: -20px;
}

效果如图:

下面是选择弹幕文字颜色的页面,选择文字颜色之后跳转回发送弹幕页面

var app = getApp()
Page({data: {color: [{ 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' }],},selectColor: function (e) {var number = e.currentTarget.dataset.number;try {wx.setStorageSync('numberColor', number)} catch (e) {}wx.navigateBack({delta: 1,success: function (res) {},fail: function () {},complete: function () {}})}
})
<view class="page"><view class="page__bd"><view class="weui-grids"><block wx:for-items="{{color}}"  ><view  class="weui-grid"  data-number="{{item.number}}" bindtap="selectColor" ><view class="weui-grid__icon"  style="background:{{item.number}}"/></view></block></view></view>
</view>
.weui-grids {border-top: 1rpx solid #D9D9D9;border-left: 1rpx solid #D9D9D9;
}
.weui-grid {position: relative;float: left;padding: 20rpx 20rpx;width: 20%;box-sizing: border-box;border-right: 1rpx solid #D9D9D9;border-bottom: 1rpx solid #D9D9D9;
}
.weui-grid_active {background-color: #ccc;
}
.weui-grid__icon {display: block;width: 100rpx;height: 100rpx;margin: 0 auto;box-shadow: 3px 3px 5px #bbb;}
.weui-grid__label {margin-top: 5px;display: block;text-align: center;color: #000000;font-size: 14px;white-space: nowrap;text-overflow: ellipsis;overflow: hidden;
}

效果如图:

微信小程序 - 发送视频弹幕相关推荐

  1. 腾讯技术分享:微信小程序音视频技术背后的故事

    1.引言 微信小程序自2017年1月9日正式对外公布以来,越来越受到关注和重视,小程序上的各种技术体验也越来越丰富.而音视频作为高速移动网络时代下增长最快的应用形式之一,在微信小程序中也当然不能错过. ...

  2. 微信小程序 RTMP 音视频 通话 ffmpeg_WebRTC与微信小程序音视频互通方案设计与实现...

    背景 在之前的WebRTC实时音视频通话之语音通话设计与实践中介绍了58 TEG部门基于 WebRTC 的实时音视频通话解决方案. 考虑到腾讯微信的小程序平台提供了音视频通话与直播的支持,如果能打通基 ...

  3. 微信小程序下载视频到相册(带进度条)

    微信小程序下载视频到相册,并带进度条 <button class="desc-note my-button u-font-32" @click="toUpload( ...

  4. 腾讯技术分享:微信小程序音视频与WebRTC互通的技术思路和实践

    概述 本文来自腾讯视频云终端技术总监rexchang(常青)技术分享,内容分别介绍了微信小程序视音视频和WebRTC的技术特征.差异等,并针对两者的技术差异分享和总结了微信小程序视音视频和WebRTC ...

  5. 微信小程序--获取视频链接(Videourl)方法~~~

    微信小程序–获取视频连接(videourl)方法~~~ 如何获取音乐MV的URL地址 虾米音乐 试了很多音乐网站发现"虾米音乐"的MV的URL地址是可以获取的,并且在微信小程序播放 ...

  6. java后台接收微信小程序发送的post请求参数

    java后台接收微信小程序发送的post请求参数 // 微信端:data数据要加上JSON转换JSON.stringify() wx.request({url: 'http://127.0.0.1:8 ...

  7. php+实现群发微信模板消息_使用php实现微信小程序发送模板消息(附代码)

    本篇文章给大家带来的内容是关于使用php实现微信小程序发送模板消息(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 本章将会简单说一下微信小程序的模板消息发送,相对来说比较简 ...

  8. 微信小程序保存视频到相册wx.saveVideoToPhotosAlbum()

    一.微信小程序保存视频到相册wx.saveVideoToPhotosAlbum() 功能描述 保存视频到系统相册.支持mp4视频格式. 参数 Object object 属性 类型 默认值 必填 说明 ...

  9. 微信小程序选择视频,获取封面缩略图

    使用微信小程序选择视频,且获取其封面 使用微信小程序选择视频上传,且获取其封面 背景 名词 参考 效果图展示 结束: 使用微信小程序选择视频上传,且获取其封面 背景 又一活儿,要从小程序里选择视频,上 ...

最新文章

  1. Ubuntu 16.04下减小/释放/清理VirtualBox虚拟硬盘文件的大小
  2. Ubuntu 16.04网速慢解决方法
  3. redis队列缓存 + mysql 批量入库 + php离线整合
  4. full outer join 与full join的区别_sleep、yield、join都是干啥的? sleep与wait有啥区别?中篇[十五]...
  5. c# WebService添加SoapHeader认证
  6. linux 内核定时器精度_高精度时钟工作机制简介
  7. Impatient JavaScript 中文版校对活动期待大家的参与
  8. python可能导致异常的代码_Python程序可能导致文件系统错误?
  9. cvCalcBackProject() 直方图反向投影匹配
  10. 微软.NET平台OA办公解决方案
  11. 激活函数(activation function)的种类与应用
  12. 百位明星身份证照片被曝光
  13. 《程序员的成长课》:增加收入的 3 大方向
  14. 手把手教你搭建国产嵌入式模拟器SkyEye开发环境
  15. GPU跑TensorFlow的各种显卡下的电脑配置(1080ti)
  16. ImageNet无监督学习最佳性能一次提升7%,媲美监督学习
  17. marquee标签_html滚动文字
  18. Git实战(五)| 让工作更高效,Git的分支管理
  19. 公安部:“净网2018”侦破网络犯罪案件57519起
  20. icloud无法注销,icloud服务中keyChain钥匙串无法关闭问题的解决。

热门文章

  1. 命定的局限与挑战,读《命若琴弦》——leo鉴书(17)
  2. 手把手教你安装Spring+搭建Spring开发环境
  3. 好看的Windows Vista壁纸
  4. SIFT特征提取分析(转载)
  5. 在C语言aceg什么意思,C语言第五六次作业
  6. 什么是存储过程?使用它的优点有哪些?
  7. 增广贤文--中华蒙学经典
  8. F5服务器负载均衡测试方案
  9. Excel Day5
  10. XSS挑战第二期 Writeup