把录音的模块尝试过之后就想着微信小程序的视频播放会不会更有趣?

果然,微信小程序视频自带弹幕.是不是很爽,跟我一起来看看.

微信小程序开发之录音机 音频播放 动画 (真机可用)

先上gif:

再上几张图:

1.视频播放器

2.选择弹幕颜色

3.弹幕来了...

1.视频播放器

微信已经封装的非常好.我这里只用了很简单的几个属性

由于以前没做过弹幕,看到danmu-list就激动了.而且只需要将弹幕内容加入集合即可.

弹幕列表的元素:

{
        text: '第 1s 出现的红色弹幕',//文本
        color: '#ff0000',//颜色
        time: 1//发送的时间
      }

其他的属性就不说了,以后遇到再细细研究.

2.选择弹幕颜色

从上面的弹幕列表元素可以看出,微信并没有给开发者太多的自定义空间.文本?时间?颜色?

也就颜色还能玩出点花样吧.

于是我就简单的做了个常用颜色的列表.算是自定义弹幕颜色吧

上代码:

ps:代码没整理,很烂,凑活着看吧.

1.index.wxml

<!--index.wxml-->
<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 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>

2.index.wxss

(从别的项目粘过来的.哈哈)

/**index.wxss**/
.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;
}

3.index.js

//index.js
function getRandomColor() {let rgb = []for (let i = 0; i < 3; ++i) {let color = Math.floor(Math.random() * 256).toString(16)color = color.length == 1 ? '0' + color : colorrgb.push(color)}return '#' + rgb.join('')
}Page({onLoad: function () {var _this = this;//获取屏幕宽高  wx.getSystemInfo({success: function (res) {var windowWidth = res.windowWidth;//video标签认宽度300px、高度225px,设置宽高需要通过wxss设置width和height。var videoHeight = (225 / 300) * windowWidth//屏幕高宽比  console.log('videoWidth: ' + windowWidth)console.log('videoHeight: ' + videoHeight)_this.setData({videoWidth: windowWidth,videoHeight: videoHeight})}})},onReady: function (res) {this.videoContext = wx.createVideoContext('myVideo')},onShow: function () {var _this = this;//获取年数wx.getStorage({key: 'numberColor',success: function (res) {console.log(res.data + "numberColor----")_this.setData({numberColor: res.data,})}})},inputValue: '',data: {isRandomColor: true,//默认随机src: '',numberColor: "#ff0000",//默认黑色danmuList: [{text: '第 1s 出现的红色弹幕',color: '#ff0000',time: 1},{text: '第 2s 出现的绿色弹幕',color: '#00ff00',time: 2}]},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)},//选择颜色页面selectColor: function () {wx.navigateTo({url: '../selectColor/selectColor',success: function (res) {// success},fail: function () {// fail},complete: function () {// complete}})},//switch是否选中switchChange: function (e) {this.setData({isRandomColor: e.detail.value})}
})

4.selectColor.wxml

<!--selectColor.wxml-->
<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>

5.selectColor.wxss

/**selectColor.wxss**/
.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;
}

6.selectColor.js

/selectColor.js
//获取应用实例
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' },],},onLoad: function () {},//点击后关闭选色页面selectColor: function (e) {var number = e.currentTarget.dataset.number;console.log("number: " + number)try {wx.setStorageSync('numberColor', number)} catch (e) {}wx.navigateBack({delta: 1, // 回退前 delta(默认为1) 页面success: function (res) {// success},fail: function () {// fail},complete: function () {// complete}})}
})

demo代码下载

我的博客: http://blog.csdn.net/qq_31383345
欢迎批评!

微信小程序开发之视频播放器 Video 弹幕 弹幕颜色自定义相关推荐

  1. 微信小程序开发之大转盘 仿天猫超市抽奖

    天猫超市翻牌的转盘经常用,以前做Android,没啥想法,现在尝试微信小程序,看到别人家APP里有啥好玩的,就想去做一个. 上GIF看效果: 简要的说一下. 1.外面一圈闪烁的小球是用js控制的样式. ...

  2. 010 - 微信小程序开发之大转盘 仿天猫超市抽奖

    天猫超市翻牌的转盘经常用,以前做Android,没啥想法,现在尝试微信小程序,看到别人家APP里有啥好玩的,就想去做一个. 上GIF看效果: 简要的说一下. 1.外面一圈闪烁的小球是用js控制的样式. ...

  3. 01.微信小程序开发之环境搭建

    在开发之前你要有微信开发者工具,下载地址:https://mp.weixin.qq.com/debug/wxadoc/dev/devtools/download.html 这里我要假设大家有已经拿到了 ...

  4. 《微信小程序》微信小程序开发实例

    wx-gesture-lock  微信小程序的手势密码 WXCustomSwitch 微信小程序自定义 Switch 组件模板 WeixinAppBdNovel 微信小程序demo:百度小说搜索 sh ...

  5. 微信小程序开发video播放问题

    问题1:微信小程序开发中,如果请求接口为本地数据,真机测试的时候video无法播放,开发工具可以正常播放 解决: 真机测试的时候需要打开控制台vconsel 问题2:video组件的播放按钮显示设置无 ...

  6. 微信小程序 开发 “婚礼邀请函” 微信小程序入门可看

    成品展示: 5个页面 我们来讲解哈(上面地图位置随便定的点) 1.首页开发 一开始进来显示首页  然后默认开始播放背景音乐,这个背景音乐点击右上角图标可以暂停(有动画),然后点击新郎和新娘文字可以调到 ...

  7. 【微信小程序宝典】从零开始做微信小程序开发

    开发前必读简要 基于大量无效开发,无法上线的案例,所以开发前部分知识十分重要:| 链接 微信小程序个人注册简单步骤 打开mp.weixin.qq.com,点击右上角立即注册,进入小程序注册| 链接 微 ...

  8. WordPress版微信小程序开发系列(二):安装使用问答

    自WordPress版微信小程序发布开源以来,受关注的程度超过我原来的想象.这套程序主要面对的用户是wordpress网站的站长,如果wordpress站想在微信的生态圈得到推广,小程序成为一种重要的 ...

  9. 奇遇网:WordPress版微信小程序开发:安装使用问题

    原文:WordPress版微信小程序开发:安装使用问题 自WordPress版微信小程序发布开源以来,受关注的程度超过我原来的想象.这套程序主要面对的用户是wordpress网站的站长,如果wordp ...

最新文章

  1. 如何快速的给你的项目添加icon图标
  2. 1010.在线视频—开源网管Nagios(三)使用Nagios监控服务器
  3. ListView图片不显示 Application.EnableVisualStyle bug
  4. 实验一缓冲区溢出漏洞实验
  5. OpenGL采样贴图显示不出来
  6. Tomcat 9安装配置教程
  7. 83页XX市高速智慧公路总体建设方案
  8. [深度学习]卷积神经网络CNN - 一张图理解滤波器/层数/深度
  9. Android外挂开发探索
  10. iOS APP运行时Crash自动修复系统
  11. MFC应用程序“生死因果”内幕
  12. Sublime Text 崇高文本 ----最性感的编辑器(程序员必备)
  13. 目标检测0-02:YOLO V3-网络结构输入输出解析
  14. centos开机启动后只是一条横杠
  15. EAS提示对不起当前对象正在被其他操作锁定问题处理
  16. 三星服务器内存条型号区分,三星内存铭牌详解|三星内存条标签内存参数详解...
  17. storm风暴英雄 tempo_Tempo Storm的风暴英雄观赛指南和结果预测
  18. java全栈系列之JavaSE--Arrays类详解027
  19. 这届95后,国庆节不想出游了?
  20. 棋盘游戏(匈牙利算法)

热门文章

  1. 【初码干货】记一次分布式B站爬虫任务系统的完整设计和实施
  2. CNBC对话投资人:什么事物可以代币化?代币的上限在哪里?
  3. JUnit5学习之三:Assertions类,字节跳动视频面试分钟
  4. 05-Jmeter添加断言Assertions
  5. iPhone12最新信息高调曝光
  6. Java Sort排序总结
  7. 数据中心网络运维一指禅
  8. 补习系列(6)-SpringBoot 整合Shiro 一指禅
  9. 【业务模型】AARRR模型(海盗模型)
  10. 弘辽科技:拼多多礼品包怎么发?如何操作?