




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第纯编码实现微信小程序弹幕效果(非视频底)view
imagesrc="/images/background-img.png"mode="widthFix"/image
viewhidden="{{!showInput}}"
inputtype="text"confirm-type="send"bindfocus="foucusInput"focus="{{showInput}}"
bindconfirm="sendMsg"bindblur="blurInput"adjust-position="{{false}}"value="{{inputVal}}"/
buttonsize="mini"bindtap="sendMsg"发送/button
/view
imagehidden="{{showInput}}"src="/images/msg-click-btn.png"bindtap="clickSendMsg"/image
/view
view
viewwx:for="{{barrageLineCount}}"wx:for-item="count"
wx:for-index="lineIndex"data-index="{{lineIndex}}"
wx:key="*this"
viewwx:for="{{barrageMsgs[lineIndex].msgInfos}}"
wx:key="msg"
imagesrc='{{item.avatarUrl}}'/image
text{{item.msg}}/text
/view
/view
/view
constapp=getApp();
Page({
*页面的初始数据
data:{
msgInputBottom:0,
inputVal:"",
showInput:false,
barrageLineCount:10,
//拉取最新弹幕的毫秒值
barragePullMillis:0,
//最新的弹幕
barrageNewMsgs:[],
//已显示的弹幕,无新弹幕时则循环
barrageSendedMsgs:[],
//弹幕显示数据
barrageMsgs:[]
foucusInput:function(e){
this.setData({msgInputBottom:e.detail.height})
blurInput:function(e){
this.setData({inputVal:e.detail.value,msgInputBottom:0,showInput:false})
clickSendMsg:function(e){
this.setData({showInput:true})
sendMsg:function(e){
constmsg=this.data.inputVal;
if(msg=="")return;
constuserInfo=app.getUserInfo();
wx.request({
url:app.globalData.baseUrl+'/barrageMsg/',
data:{memberId:userInfo.id,msg:msg},
method:'PUT'
this.setData({inputVal:""});
*生命周期函数--监听页面加载
onLoad(options){
*生命周期函数--监听页面初次渲染完成
onReady(){
//初始化barrageLineCount个弹幕行
letbarrageMsgs=this.data.barrageMsgs;
constbarrageLineCount=this.data.barrageLineCount;
constnowTimeMillis=newDate().getTime();
for(vari=0;ibarrageLineCount;i++)
barrageMsgs.push({'showTimeMillis':newString(nowTimeMillis-
Math.round(Math.random()*barrageLineCount)*1000),msgInfos:[]});
this.setData({barrageMsgs:barrageMsgs});
//每隔2s拉取最新的弹幕
setInterval((that)={
wx.request({
url:app.globalData.baseUrl+'/barrageMsg/',
data:{timeMillis:that.data.barragePullMillis},
method:'GET',
success:res={
constdata=res.data.data;
if(data==null)return;
that.setData({barrageNewMsgs:data.barrageMsgList,
barragePullMillis:data.lastPullMillis});
},2000,this);
//动态显示弹幕
setInterval((that)={
vararrSort=[];
constbarrageLineCount=this.data.barrageLineCount;
for(vari=0;ibarrageLineCount;i++)arrSort.push(i);
arrSort.sort(()=(0.5-Math.random()));
varnowTimeMillis=newDate().getTime();
varbarrageNewMsgs=that.data.barrageNewMsgs;
if(barrageNewMsgs!=nullbarrageNewMsgs.length0){
//有最新弹幕
varbarrageMsgs=that.data.barrageMsgs;
for(varj=0;jarrSort.length;j++){
varbarrageMsg=barrageMsgs[arrSort[j]];
//获取最后发起的弹幕超过5s则跟在后面
if(nowTimeMillis-barrageMsg.showTimeMillis5000){
//显示
barrageMsg.showTimeMillis=nowTimeMillis;
constbarrageNewMsg=barrageNewMsgs[0];
barrageNewMsg.showTimeMillis=nowTimeMillis;
barrageMsg.msgInfos.push(barrageNewMsg);
barrageMsgs[arrSort[j]]=barrageMsg;
//在最新弹幕中删除此条弹幕
barrageNewMsgs.splice(0,1);
that.setData({barrageNewMsgs:barrageNewMsgs,
barrageMsgs:barrageMsgs});
break;
//回收每个超过10s的弹幕放到barrageSendedMsgs中
varbarrageMsgs=that.data.barrageMsgs;
for(vari=0;ibarrageMsgs.length;i++){
varbarrageMsg=barrageMsgs[i];
varmsgInfos=barrageMsg.msgInfos;
if(msgInfos==null||msgInfos.length==0||
nowTimeMillis-msgInfos[0].showTimeMillis=10000)continue;
varbarrageSendedMsgs=that.data.barrageSendedMsgs;
for(varj=0;jmsgInfos.length;j++){
varmsgInfo=msgInfos[j];
if(nowTimeMillis-msgInfo.showTimeMillis=10000)break;
msgInfos.splice(j,1);j--;
barrageSendedMsgs.push(msgInfo);
barrageMsg.msgInfos=msgInfos;
barrageMsgs[i]=barrageMsg;
that.setData({barrageMsgs:barrageMsgs,
barrageSendedMsgs:barrageSendedMsgs});
//新的弹幕未发完,老弹幕不循环
if(barrageNewMsgs!=nullbarrageNewMsgs.length0)return;
//从barrageSendedMsgs取开头1条进行播放后删除,由上文代码再次放入实现循环
varbarrageSendedMsgs=that.data.barrageSendedMsgs;
if(barrageSendedMsgs.length==0)return;
varbarrageSendedMsg=barrageSendedMsgs[0];
for(varj=0;jarrSort.length;j++){
varbarrageMsg=barrageMsgs[arrSort[j]];
//获取最后发起的弹幕超过5s则跟在后面
if(nowTimeMillis-barrageMsg.showTimeMillis5000){
//显示
barrageMsg.showTimeMillis=nowTimeMillis;
barrageSendedMsg.showTimeMillis=nowTimeMillis;
barrageMsg.msgInfos.push(barrageSendedMsg);
barrageMsgs[arrSort[j]]=barrageMsg;
//在已发弹幕中删除此条弹幕
barrageSendedMsgs.splice(0,1);
that.setData({barrageSendedMsgs:barrageSendedMsgs,
barrageMsgs:barrageMsgs});
break;
},500,this);
*生命周期函数--监听页面显示
onShow(){
*生命周期函数--监听页面隐藏
onHide(){
*生命周期函数--监听页面卸载
onUnload(){
*页面相关事件处理函数--监听用户下拉动作
onPullDownRefresh(){
*页面上拉触底事件的处理函数
onReachBottom(){
*用户点击右上角分享
onShareAppMessage(){
})
.index-view{
display:flex;
width:100%;
align-content:center;
justify-content:center;
.background-img{width:100%;}
.msg-input{position:absolute;width:100%;bottom:0px;
background-color:rgba(241,213,135,0.911);}
.msg-inputinput{margin:20rpx1%10rpx1%;width:75%;height:60rpx;
border:none;padding:5rpx10px5rpx10px;border-radius:8px;
background-color:#ffffff;display:inline-block;}
.msg-inputbutton{width:15%;display:inline-block;font-size:30rpx;color:
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 甘肃政法大学《工程应用软件》2023-2024学年第二学期期末试卷
- 重庆资源与环境保护职业学院《国际商务综合模拟与实训》2023-2024学年第二学期期末试卷
- 衡阳师范学院《小学教师课堂教学技能训练》2023-2024学年第二学期期末试卷
- 广西职业技术学院《趣说HR》2023-2024学年第二学期期末试卷
- 湖南女子学院《测试技术与传感器》2023-2024学年第二学期期末试卷
- 濮阳科技职业学院《工程经济与建设项目管理》2023-2024学年第二学期期末试卷
- 吉利学院《制药过程自动化技术实验》2023-2024学年第二学期期末试卷
- 大连汽车职业技术学院《媒介综合设计》2023-2024学年第二学期期末试卷
- 兰考三农职业学院《急危重症护理学实训》2023-2024学年第二学期期末试卷
- 宾馆客房促销活动方案
- 《医学影像诊断学》分章节试题库含答案大全
- 潜孔钻机的教案
- 品牌设计的法则
- 老年口腔医学 课件 老年口腔疾病流行病学、增龄变化
- 锅炉试题与答案
- 系统解剖学-肝脏、胰腺
- 2023年第四届北京市大学生模拟法庭竞赛第一轮赛题A
- GB/T 5237.1-2017铝合金建筑型材第1部分:基材
- GB/T 33289-2016馆藏砖石文物保护修复记录规范
- GB/T 20721-2006自动导引车通用技术条件
- GB/T 15256-2014硫化橡胶或热塑性橡胶低温脆性的测定(多试样法)
评论
0/150
提交评论