返回顶部
首页 > 资讯 > 精选 >Laravel8/LaravelS如何实现弹幕功能
  • 906
分享到

Laravel8/LaravelS如何实现弹幕功能

2023-07-05 03:07:43 906人浏览 泡泡鱼
摘要

本篇内容主要讲解“Laravel8/LaravelS如何实现弹幕功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Laravel8/LaravelS如何实现弹幕功能”吧!第一步:安装Larave

本篇内容主要讲解“Laravel8/LaravelS如何实现弹幕功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Laravel8/LaravelS如何实现弹幕功能”吧!

第一步:安装Laravel8

composer create-project laravel/laravel labarrage

第二步:Laravel8中使用vue

注意:安装Vue时请使用 PHP artisan ui vue --auth

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

安装vue及bootstrap

npm install

安装弹幕组件

npm install vue-baberrage --save

运行

npm run dev

第四步:安装LaravelS实现websocket服务器

请参考 Laravel8使用laravel-s实现WebSocket服务器

第五步:项目中引入vue-baberrage组件

文件:resources/js/app.js 新增如下内容

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


Vue.component('danmu-component', require('./components/DanmuComponent.vue').default);

第五步:编写文弹幕组件

位置: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">发送</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;
   }

   h2, h3 {
       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');
});

执行 npm run dev

第八步:编写websocket服务器

文件:App\Handlers\WEBSocketHandler.php

<?php
namespace App\Handlers;

use Hhxsv5\LaravelS\Swoole\WebSocketHandlerInterface;
use Illuminate\Support\Facades\Log;
use Swoole\Http\Request;
use Swoole\WebSocket\Frame;
use Swoole\WebSocket\Server;

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

   // 连接建立时触发
   public function onOpen(Server $server, Request $request)
   {
       Log::info('WebSocket 连接建立:' . $request->fd);
   }

   // 收到消息时触发
   public function onMessage(Server $server, Frame $frame)
   {
       // $frame->fd 是客户端 id,$frame->data 是客户端发送的数据
       Log::info("从 {$frame->fd} 接收到的数据: {$frame->data}");
       foreach($server->connections as $fd){
           if (!$server->isEstablished($fd)) {
               // 如果连接不可用则忽略
               continue;
           }
           $server->push($fd , $frame->data); // 服务端通过 push 方法向所有连接的客户端发送数据
       }
   }

   // 连接关闭时触发
   public function onClose(Server $server, $fd, $ReactorId)
   {
       Log::info('WebSocket 连接关闭:' . $fd);
   }
}

第九步:laravels.php注册

文件:config/laravels.php

'websocket' => [
   'enable' => true,
   'handler' =>  \App\Handlers\WebSocketHandler::class,
],

第十步:启动

php bin/laravels start

到此,相信大家对“Laravel8/LaravelS如何实现弹幕功能”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

--结束END--

本文标题: Laravel8/LaravelS如何实现弹幕功能

本文链接: https://lsjlt.com/news/349142.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Laravel8/LaravelS如何实现弹幕功能
    本篇内容主要讲解“Laravel8/LaravelS如何实现弹幕功能”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Laravel8/LaravelS如何实现弹幕功能”吧!第一步:安装Larave...
    99+
    2023-07-05
  • js怎么实现弹幕功能
    js实现弹幕功能的方法:1、创建html文件;2、添加html代码架构;3、在body标签中使用div、input、button标签分给页面设计效果显示框、输入框、弹幕提交按钮;4、添加script标签并写入js代码来实现弹幕效果;5、通过...
    99+
    2024-04-02
  • iOS 弹幕功能的实现思路图解
    先来看一张效果图(LICEcap录制的有点卡, 凑合看) 理一下大概流程: 接下来实现: 弹幕视图从底部弹上来, 依次动画向上滚动, 出屏幕就移除加入重用队列, 下次使用. 定义...
    99+
    2022-06-01
    iOS 弹幕
  • JavaScript css3实现简单视频弹幕功能
    本文尝试写了一个demo模拟了最简单的视频弹幕功能。 思路: 设置一个<div>和所播放的video的大小一致,把这个div标签蒙在video上面用于放置弹幕。在vide...
    99+
    2024-04-02
  • jquery如何实现弹窗功能
    这篇文章主要介绍jquery如何实现弹窗功能,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!效果图:代码如下:<!DOCTYPE HTML> <html&g...
    99+
    2024-04-02
  • jQuery如何实现弹幕APP
    这篇文章主要介绍了jQuery如何实现弹幕APP,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。今天闲着无聊,写了个弹幕APP,主要实现以下几...
    99+
    2024-04-02
  • Python实现直播弹幕自动发送功能
    目录前言发送请求循环发弹幕最后看看效果怎么样前言 今天制作的这一款能在B站能指定直播间、自动发弹幕的功能的脚本,因为没做那么多的功能,所以代码很简单,适合刚入门的同学学习 先打开一个...
    99+
    2024-04-02
  • 使用CSS3怎么实现一个弹幕功能
    本篇文章给大家分享的是有关使用CSS3怎么实现一个弹幕功能,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1.首先创建弹幕区域<div class="b...
    99+
    2023-06-08
  • jQuery如何实现弹出框功能
    本篇内容介绍了“jQuery如何实现弹出框功能”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!在我们构建网站或应用程序时,经常需要使用弹出框来...
    99+
    2023-07-06
  • jQuery如何实现弹幕效果
    这篇文章主要为大家展示了“jQuery如何实现弹幕效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“jQuery如何实现弹幕效果”这篇文章吧。效果如下:代码如下...
    99+
    2024-04-02
  • canvas如何实现弹幕效果
    这篇文章主要介绍canvas如何实现弹幕效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!代码如下<!DOCTYPE html> <html l...
    99+
    2024-04-02
  • Android实现炫酷的网络直播弹幕功能
    现在网络直播越来越火,网络主播也逐渐成为一种新兴职业,对于网络直播,弹幕功能是必须要有的,如下图: 首先来分析一下,这个弹幕功能是怎么实现的,首先在最下面肯定是一个游戏界面V...
    99+
    2022-06-06
    直播 Android
  • 使用css3怎么实现一个蒙版弹幕功能
    今天就跟大家聊聊有关使用css3怎么实现一个蒙版弹幕功能,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。css是什么意思css是一种用来表现HTML或XML等文件样式的计算机语言,主要...
    99+
    2023-06-08
  • 怎么在HTML5中实现一个视频弹幕功能
    这篇文章给大家介绍怎么在HTML5中实现一个视频弹幕功能,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1>html代码展示<div class="barrage">&nb...
    99+
    2023-06-09
  • Python怎么实现直播弹幕自动发送功能
    这篇文章主要讲解了“Python怎么实现直播弹幕自动发送功能”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python怎么实现直播弹幕自动发送功能”吧!前言先打开一个直播间按F12打开开发者...
    99+
    2023-06-29
  • Android 实现仿网络直播弹幕功能详解及实例
    Android 网络直播弹幕             &...
    99+
    2022-06-06
    直播 Android
  • 怎么在html5中利用canvas实现一个弹幕功能
    本篇文章为大家展示了怎么在html5中利用canvas实现一个弹幕功能,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。(function () {   ...
    99+
    2023-06-09
  • 如何使用JavaScript实现弹幕效果
    这篇文章主要为大家展示了“如何使用JavaScript实现弹幕效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用JavaScript实现弹幕效果”这篇文...
    99+
    2024-04-02
  • 如何使用css3实现弹幕效果
    这篇文章主要介绍如何使用css3实现弹幕效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!如何通过css3实现弹幕首先来看如何通过css的方法实现一个最简单的弹幕:首先在html中定...
    99+
    2024-04-02
  • 前端html如何实现弹幕效果
    这篇文章给大家分享的是有关前端html如何实现弹幕效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。之前在一个移动端的抽奖页面中,在抽奖结果的展示窗口需要弹幕轮播显示,之前踩过一些小坑,现在总结一下前端弹幕效果的...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作