gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区

站長資訊網(wǎng)
最全最豐富的資訊網(wǎng)站

一文詳解Laravel8/LaravelS實現(xiàn)彈幕功能

本篇文章給大家?guī)砹岁P(guān)于Laravel8/LaravelS的相關(guān)知識,其中主要介紹了Laravel8基于LaravelS實現(xiàn)彈幕功能的方法步驟,感興趣的朋友,下面一起來看一下,希望對大家有幫助。

Laravel8基于LaravelS實現(xiàn)彈幕彈幕功能

簡介

Laravel8基于LaravelS實現(xiàn)彈幕彈幕功能。前面學了基于Swoole實現(xiàn)視頻彈幕功能,這篇文章就來實現(xiàn)一個基于Laravel8的視頻彈幕功能。如果對webpack不熟悉,那么在安裝vue-baberrage組件時可能會報錯卻不知如何解決。下面開始一步一步實現(xiàn)。

前面學了基于Swoole實現(xiàn)視頻彈幕功能,這篇文章就來實現(xiàn)一個基于Laravel8的視頻彈幕功能。如果對webpack不熟悉,那么在安裝vue-baberrage組件時可能會報錯卻不知如何解決。下面開始一步一步實現(xiàn)。

第一步:安裝Laravel8

composer create-project laravel/laravel labarrage
登錄后復制

第二步:Laravel8中使用vue

Laravel8如何使用vue,請參考 Laravel8中使用vue。

注意:安裝vue時請使用 php artisan ui vue –auth

第三步:安裝及安裝vue-baberrage

安裝vue及bootstrap

npm install
登錄后復制

安裝彈幕組件

npm install vue-baberrage --save
登錄后復制

運行

npm run dev
登錄后復制

如果遇到BREAKING CHANGE: webpack < 5 used to include錯誤,請參考 Laravel8使用webpack報錯的解決方法。

后續(xù)只要文件改動就需要重新編譯,后續(xù)將不再復述。

第四步:安裝LaravelS實現(xiàn)Websocket服務器

請參考 Laravel8使用laravel-s實現(xiàn)WebSocket服務器

第五步:項目中引入vue-baberrage組件

文件:resources/js/app.js 新增如下內(nèi)容

import { vueBaberrage } from 'vue-baberrage'
Vue.use(vueBaberrage)


Vue.component('danmu-component', require('./components/DanmuComponent.vue').default);
登錄后復制

第五步:編寫文彈幕組件

后續(xù)實現(xiàn)代碼根據(jù) 學院君 文章改動

位置:resources/js/components/DanmuComponent.vue

<template>
<div id="danmu">
<div class="stage">
<vue-baberrage
:isShow = "barrageIsShow"
:barrageList = "barrageList"
:loop = "barrageLoop"
:maxWordCount = "60"
>
</vue-baberrage>
</div>
<div class="danmu-control">
<div>
<select v-model="position">
<option value="top">從上</option>
<option value="abc">從右</option>
</select>
<input type="text" style="float:left" v-model="msg"/>
<button type="button" style="float:left" @click="addToList">發(fā)送</button>
</div>
</div>
</div>
</template>

<script>
import { MESSAGE_TYPE } from 'vue-baberrage'

export default {
name: 'danmu',
data () {
return {
msg: 'hello 自如初!',
position: 'top',
barrageIsShow: true,
currentId: 0,
barrageLoop: false,
barrageList: []
}
},
methods: {
removeList () {
this.barrageList = []
},
addToList () {
if (this.position === 'top') {
this.barrageList.push({
id: ++this.currentId,
msg: this.msg + this.currentId,
barrageStyle: 'top',
time: 8,
type: MESSAGE_TYPE.FROM_TOP,
position: 'top'
})
} else {
this.barrageList.push({
id: ++this.currentId,
msg: this.msg,
time: 15,
type: MESSAGE_TYPE.NORMAL
})
}
}
}
}
</script>
<style lang="scss" scoped>
#danmu {
text-align: center;
color: #2c3e50;
}
.stage {
height: 300px;
width: 100%;
background: #025d63;
margin: 0;
position: relative;
overflow: hidden;
}

h1, h2 {
font-weight: normal;
}
ul {
list-style-type: none;
padding: 0;
}
li {
display: inline-block;
margin: 0 10px;
}

a {
color: #42b983;
}

.baberrage-stage {
z-index: 5;
}

.baberrage-stage .baberrage-item.normal{
color:#FFF;
}
.top{
border:1px solid #66aabb;
}
.danmu-control{
position: absolute;
margin: 0 auto;
width: 100%;
bottom: 300px;
top: 70%;
height: 69px;
box-sizing: border-box;
text-align: center;
display: flex;
justify-content: center;
div {
width: 300px;
background: rgba(0, 0, 0, 0.6);
padding: 15px;
border-radius: 5px;
border: 2px solid #8ad9ff;
}
input,button,select{
height:35px;
padding:0;
float:left;
background:#027fbb;
border:1px solid #CCC;
color:#FFF;
border-radius:0;
width:18%;
box-sizing: border-box;
}
select{
height:33px;
margin-top:1px;
border: 0px;
outline: 1px solid rgb(204,204,204);
}
input{
width:64%;
height:35px;
background:rgba(0,0,0,.7);
border:1px solid #8ad9ff;
padding-left:5px;
color:#FFF;
}
}
</style>
登錄后復制

第六步:視圖中使用組件

位置:resources/views/danmu.blade.php

@extends('layouts.app')

@section('content')
<danmu-component></danmu-component>
@endsection
登錄后復制

第七步:注冊路由

Route::get('/danmu', function() {
return view('danmu');
});
登錄后復制

執(zhí)行 npm run dev

第八步:編寫websocket服務器

文件:AppHandlersWebSocketHandler.php

<?php
namespace AppHandlers;

use Hhxsv5LaravelSSwooleWebSocketHandlerInterface;
use IlluminateSupportFacadesLog;
use SwooleHttpRequest;
use SwooleWebSocketFrame;
use SwooleWebSocketServer;

class WebSocketHandler implements WebSocketHandlerInterface
{
public function __construct()
{
}

// 連接建立時觸發(fā)
public function onOpen(Server $server, Request $request)
{
Log::info('WebSocket 連接建立:' . $request->fd);
}

// 收到消息時觸發(fā)
public function onMessage(Server $server, Frame $frame)
{
// $frame->fd 是客戶端 id,$frame->data 是客戶端發(fā)送的數(shù)據(jù)
Log::info("從 {$frame->fd} 接收到的數(shù)據(jù): {$frame->data}");
foreach($server->connections as $fd){
if (!$server->isEstablished($fd)) {
// 如果連接不可用則忽略
continue;
}
$server->push($fd , $frame->data); // 服務端通過 push 方法向所有連接的客戶端發(fā)送數(shù)據(jù)
}
}

// 連接關(guān)閉時觸發(fā)
public function onClose(Server $server, $fd, $reactorId)
{
Log::info('WebSocket 連接關(guān)閉:' . $fd);
}
}
登錄后復制

第九步:laravels.php注冊

文件:config/laravels.php

'websocket' => [
'enable' => true,
'handler' => AppHandlersWebSocketHandler::class,
],
登錄后復制

第十步:啟動

php bin/laravels start
登錄后復制

這樣就完成啦

推薦學習:《laravel視頻教程》

贊(0)
分享到: 更多 (0)
網(wǎng)站地圖   滬ICP備18035694號-2    滬公網(wǎng)安備31011702889846號
gmnon.cn-疯狂蹂躏欧美一区二区精品,欧美精品久久久久a,高清在线视频日韩欧美,日韩免费av一区二区
欧美大片在线播放| 国产成人在线综合| 久久免费看毛片| 91精品91久久久中77777老牛| 中文字幕在线视频一区二区| 中文字幕22页| 可以看污的网站| 五月天激情视频在线观看| 成人综合视频在线| 国产亚洲天堂网| 黄色av网址在线播放| 一区二区传媒有限公司| 免费观看国产精品视频| heyzo亚洲| 国产中文字幕免费观看| www日韩视频| 亚洲少妇久久久| 想看黄色一级片| 三日本三级少妇三级99| 亚洲av综合色区| 成年人看的毛片| 免费大片在线观看| 日本中文字幕精品—区二区| 色噜噜狠狠永久免费| 国产四区在线观看| 91黄色在线看| 大香煮伊手机一区| 性久久久久久久久久久久久久| 超碰91在线播放| 国产免费一区二区视频| 欧美黄色一级片视频| 永久av免费在线观看| 97超碰在线人人| 在线看免费毛片| 国产人妻777人伦精品hd| 天天操天天爱天天爽| 免费看av软件| 日本在线视频www| 天天综合中文字幕| 欧美丰满熟妇xxxxx| 中文字幕av久久| 欧美xxxxx在线视频| 天堂av在线中文| 婷婷激情四射五月天| 国产高清www| 手机在线观看日韩av| 国产成人综合一区| 日b视频免费观看| 色噜噜狠狠一区二区三区狼国成人| 成人一级生活片| 久久久久久久高清| 国内自拍视频一区| 日韩欧美不卡在线| 最新视频 - x88av| 久久国产精品国产精品| 六月丁香激情网| 污污污污污污www网站免费| 亚洲少妇久久久| 亚洲人成无码www久久久| 久久这里只有精品23| 可以在线看黄的网站| 亚洲va综合va国产va中文| 久久精品国产精品亚洲色婷婷| 日韩中文在线字幕| 99久re热视频精品98| 日日干日日操日日射| www.涩涩涩| 性生活免费在线观看| 簧片在线免费看| 国产视频一区二区三区在线播放 | 国产成人三级视频| 亚洲免费av一区| 亚洲va综合va国产va中文| 日本www.色| 一区二区免费av| 中文字幕第22页| 中国一级大黄大黄大色毛片| 特级黄色片视频| 久久福利一区二区| 国产资源在线免费观看| 久久久久久www| 九色在线视频观看| 国产日韩成人内射视频| 激情视频免费网站| 欧美成人手机在线视频| 亚洲一区二区图片| 国产 日韩 亚洲 欧美| 69堂免费视频| 国产高潮免费视频| 艳母动漫在线观看| 亚洲中文字幕无码av永久| 欧美污视频网站| 天天操精品视频| 人人妻人人澡人人爽欧美一区双| www在线观看免费| 国产九九在线观看| 五月天六月丁香| 日av中文字幕| 四虎4hu永久免费入口| 日韩网址在线观看| 国产成年人在线观看| 99爱视频在线| 日本美女久久久| 日韩 欧美 高清| 天天操夜夜操很很操| 国产视频九色蝌蚪| 天天干天天曰天天操| 久久精品99国产| 男人c女人视频| 九九九九九国产| 可以在线看的黄色网址| 国产又黄又爽免费视频| 亚洲激情在线观看视频| 青青草视频在线免费播放| 日韩av自拍偷拍| 杨幂毛片午夜性生毛片| 欧美综合在线播放| 在线观看污视频| 激情在线观看视频| 久久午夜夜伦鲁鲁一区二区| 日本a视频在线观看| xxxxxx在线观看| 久久精品久久99| 中文字幕视频三区| 欧美亚洲日本在线观看| 欧美一区二区三区爽大粗免费| 日本三级中文字幕在线观看| 一区二区三区四区毛片| 国产wwwxx| 中文字幕av专区| 激情网站五月天| 超碰av在线免费观看| 少妇高清精品毛片在线视频| 日本精品免费在线观看| 免费看日本毛片| 啊啊啊一区二区| 黄页网站在线观看视频| 和岳每晚弄的高潮嗷嗷叫视频| 中文精品无码中文字幕无码专区| 欧美aaa在线观看| 欧美aaa在线观看| 成人免费a级片| 欧美牲交a欧美牲交| 欧美 日韩 国产在线观看| 国产毛片视频网站| 男人天堂成人在线| 在线观看日本www| 在线播放 亚洲| 国内少妇毛片视频| 青娱乐自拍偷拍| 五月婷婷丁香色| 热久久最新网址| 国产 日韩 亚洲 欧美| 天天碰免费视频| 国产精品嫩草影视| 青青青青草视频| 午夜激情在线观看视频| 亚洲欧美一区二区三区不卡| 69sex久久精品国产麻豆| 亚洲熟妇av一区二区三区| 久久久精品三级| 老司机午夜免费福利视频| 成 年 人 黄 色 大 片大 全| 欧美丰满熟妇xxxxx| 欧美一级黄色录像片| 国产av人人夜夜澡人人爽麻豆 | 日本黄网站免费| 一级黄色免费在线观看| www国产精品内射老熟女| 999久久久精品视频| 被灌满精子的波多野结衣| 国产成人黄色网址| 成年人看的毛片| 91高清国产视频| 成人在线免费观看av| 不卡的在线视频| 日本福利视频在线| 国产高清免费在线| 日韩av资源在线| 日本人妻伦在线中文字幕| 狠狠热免费视频| 日韩少妇内射免费播放| 嫩草影院中文字幕| 亚洲一区在线不卡| 拔插拔插海外华人免费| 一本色道久久亚洲综合精品蜜桃| 麻豆tv在线播放| 欧美性猛交内射兽交老熟妇| 日韩欧美在线免费观看视频| 青青草精品视频在线| 永久免费看av| 午夜视频在线网站| 性欧美极品xxxx欧美一区二区| 亚洲国产精品无码观看久久| 国产成人精品免费看在线播放| 欧美三级理论片| 国产精品久久久毛片| 成人精品视频一区二区| 男人亚洲天堂网| 日韩欧美一区三区|