弹幕功能通常用于实时显示当前视频或者文档的评论内容,在上快速飞过的方式呈现,看起来比较酷炫。

这种典型的多用户实时交互的功能,很适合使用SignalR实现,通过SignalR提供后台的服务推送功能,客户端接收消息后呈现出来。

弹幕功能实现起来有点类似聊天室的功能,只是消息的展示方式不同,所以结合SignalR的推送功能,比较容易实现一个简单的弹幕功能。

实现过程

一、服务端

服务端的操作很简单,只是服务消息的推送,需要注意的是,服务端仅仅将消息推送给非当前连接客户端

step1:

创建一个Empty类型的ASP.NET 4.5的站点

step2:

引入SignalR的nuget包,将自动引入相关的关联包

Install-Package Microsoft.AspNet.SignalR

完成之后将自动创建相关的Scripts

step3:

新建一个SignalR Persistent Connection Class类

将代码改成如下

public class BulletScreenConnection : PersistentConnection
{
       protected override Task OnReceived(IRequest request, string connectionId, string data)
       {
            return Connection.Broadcast(data, connectionId);
       }
}

step4:

新建一个startup类,用于配置SingalR

将代码改成如下

public class Startup
{
       public void Configuration(IAppBuilder app)
       {
            app.MapSignalR<BulletScreenConnection>("/bulletScreenConnection");
       }

}

到这一步已经完成了服务端需要的代码。

二、客户端

step 1

新建一个Html页面,引入如下js脚本

<script src="Scripts/jquery-1.6.4.min.js"></script>
<script src="Scripts/jquery.signalR-2.2.0.min.js"></script>

完整html代码(相关的css代码在文档附件中有)

<!DOCTYPE html>
<html>
<head>
    <title>SignalR实现的弹幕效果</title>
    <meta charset="utf-8" />
    <link href="BulletScreen.css" type="text/css" rel="stylesheet"/>
</head>
<body>
    <a href="#" id="click_screen">点击弹幕</a>
    <!--screen start-->
    <div class="screen">
        <!--s_dm start-->
        <div class="s_dm">
            <a href="#" class="s_close">退出弹幕</a>
            <div class="mask"></div>
            <div class="s_show"></div>
        </div>
        <!--end s_dm-->
        <!--send start-->
        <div class="send">
            <div class="s_con">
                <input type="text" class="s_userName" placeholder="用户名"/>
                <input type="text" class="s_txt" placeholder="评论" /><input type="button" class="s_btn" value="发表评论" />
            </div>
        </div>
        <!--end send-->
    </div>
    <!--end screen-->
    <script src="Scripts/jquery-1.6.4.min.js"></script>
    <script src="Scripts/jquery.signalR-2.2.0.min.js"></script>
    <script src="Scripts/BulletScreen.js"></script>
</body>
</html>

step 2

在Scripts目录下创建BulletScreen.js

$(function () {
    var clickScreen = $("#click_screen");
    var screen = $(".screen");
    var userNameBox = $(".s_userName");
    var commentBox = $(".s_txt");
    var bulletArea = $(".s_show");
    var commentButton = $(".s_btn");
    var connection = null;

// 点击展开弹幕
    clickScreen.click(function () {
        // 创建连接
        connection = $.connection("/bulletScreenConnection");
        connection.start().done(function () {
            screen.toggle(600);
        });
        connection.received(function (data) {
            var bulletObj = JSON.parse(data);
            // 接收服务器推送过来的弹幕消息
            addBullet(bulletObj.userName, bulletObj.comment);
        });
        return false;
    });

// 点击关闭弹幕
    $(".s_close").click(function () {
        if (connection != null) {
            // 关闭服务器连接
            connection.stop(true, true);
            connection = null;
        }
        screen.toggle(600);
        return false;
    });

// 发表评论
    commentButton.click(function () {
        var userName = userNameBox.val();
        var comment = commentBox.val();
        if (userName == "" && comment == "") {
            alert("请输入用户名和评论");
            return false;
        }
        addBullet(userName, comment);
        connection.send({ userName: userName, comment: comment });
    });

// 按回车发表评论
    commentBox.keydown(function () {
        var code = window.event.keyCode;
        if (code == 13)//回车键按下时,输出到弹幕
        {
            commentButton.click();
        }
    });

function addBullet(userName, comment) {
        bulletArea.append("<div>" + userName + ":" + comment + "</div>");
        refreshBullets();
    }

// 下面部分代码参考自http://www.zyfun.cn/2015/04/81/
    // 刷新显示弹幕
    function refreshBullets() {
        var _top = 0;

bulletArea.find("div").show().each(function () {
            var bullet = $(this);
            var _left = $(window).width() - bullet.width();
            var _height = $(window).height();

_top = _top + 80;

if (_top > _height - 100) {
                _top = 80;
            }

var time = 10000;
            if (bullet.index() % 2 == 0) {
                time = 20000;
            }
            //设定文字的初始化位置
            bullet.css({ left: _left, top: _top, color: getRandomColor() });
            bullet.animate({ left: "-" + _left + "px" }, time, function () {
                bullet.remove();
            });
        });
    }

//随机获取颜色值
    function getRandomColor() {
        return '#' + (function (h) {
            return new Array(7 - h.length).join("0") + h
        })((Math.random() * 0x1000000 << 0).toString(16))
    }
});

上述代码关键部分

1.创建连接

connection = $.connection("/bulletScreenConnection");

2.接收服务器推送过来的其他用户提交的评论

connection.received(function (data) {
            var bulletObj = JSON.parse(data);
            // 接收服务器推送过来的弹幕消息
            addBullet(bulletObj.userName, bulletObj.comment);
});

3.发表评论同时将评论内容发送给服务端
  commentButton.click(function () {
      var userName = userNameBox.val();
      var comment = commentBox.val();
      if (userName == "" && comment == "") {
          alert("请输入用户名和评论");
          return false;
      }
      addBullet(userName, comment);
      connection.send({ userName: userName, comment: comment });
  });

4.显示弹幕动画效果

functoin refreshBullets {

……………………….

}

三、最终效果

完整代码下载

用SignalR实现的弹幕功能的更多相关文章

  1. Asp.NET MVC 使用 SignalR 实现推送功能二(Hubs 在线聊天室 获取保存用户信息)

    简单介绍 关于SignalR的简单实用 请参考 Asp.NET MVC 使用 SignalR 实现推送功能一(Hubs 在线聊天室) 在上一篇中,我们只是介绍了简单的消息推送,今天我们来修改一下,实现 ...

  2. 【Swift 2.0】实现简单弹幕功能

    前言 简单实现弹幕功能,表跟我谈效率,但也有用队列控制同时弹的数量. 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over ...

  3. MVC 中使用 SignalR 实现推送功能

    MVC 中使用 SignalR 实现推送功能 一,简介 Signal 是微软支持的一个运行在 Dot NET 平台上的 html websocket 框架.它出现的主要目的是实现服务器主动推送(Pus ...

  4. Android弹幕功能实现,模仿斗鱼直播的弹幕效果

    转载出处:http://blog.csdn.net/sinyu890807/article/details/51933728 本文同步发表于我的微信公众号,扫一扫文章底部的二维码或在微信搜索 郭霖 即 ...

  5. 在 Asp.NET MVC 中使用 SignalR 实现推送功能 [转]

    在 Asp.NET MVC 中使用 SignalR 实现推送功能 罗朝辉 ( http://blog.csdn.net/kesalin ) CC许可,转载请注明出处 一,简介 Signal 是微软支持 ...

  6. 史上最全面的SignalR系列教程-3、SignalR 实现推送功能-集线器类实现方式

    1.概述 通过前两篇 史上最全面的SignalR系列教程-1.认识SignalR 史上最全面的SignalR系列教程-2.SignalR 实现推送功能-永久连接类实现方式 文章对SignalR的介绍, ...

  7. 使用 SignalR 实现推送功能

    百度搜索:使用 SignalR 实现推送功能

  8. 使用SignalR实现即时通讯功能

    教程简介 SignalR的好处是可以让多个客户端之间进行互动,比如这篇教程就展示了当你在页面上拖动矩形方块的同时,其它打开这个页面的用户也将会看到你拖动的轨迹以及最终的结果,当然他们也可以通过拖动该方 ...

  9. Asp.NET MVC 使用 SignalR 实现推送功能一(Hubs 在线聊天室)

    简介       ASP .NET SignalR 是一个ASP .NET 下的类库,可以在ASP .NET 的Web项目中实现实时通信.什么是实时通信的Web呢?就是让客户端(Web页面)和服务器端 ...

随机推荐

  1. >>> 主页推荐链接

    Apple专区 App Store 排行榜 App Store 排行榜 - 中国区 PC6苹果网 威锋网 第三方 环信 - 即时通讯云领导者 腾讯Bugly - Android Crash | iOS ...

  2. Ext.data.SimpleStore的使用方法

    Ext.data.SimpleStore简单数据存储器 参数:data:Array数组类型.fields:数组对应的字段名称.var data1=[1,"订单1","16 ...

  3. mysql 查询行号

    SELECT @rowno:=@rowno+1 as rowno,r.* from t_zg_loanee_apply r,(select @rowno:=0) t;

  4. PopupWindowAction breaking MEF import?

    If you use Prism InteractionRequest.PopupWindowAction feature, you might have found the MEF Import a ...

  5. Node.js中的Session,不要觉得简单哦。

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,博客地址为http://www.cnblogs.com/jasonnode/ .学习网站上有对应 ...

  6. Remove-Azureaccount (Can't get Azure credentials to stick in Powershel)

    https://social.technet.microsoft.com/forums/azure/en-US/260df055-7c4e-4ce2-8f8d-190ad20a4b76/cant-ge ...

  7. 《写给大忙人看的java se 8》笔记

    现在才来了解java8,是不是后知后觉了点? 新的编程技术,个人不喜欢第一时间跟进. 待社区已有实践积淀再切入似乎更划算些? 一点点精明的考虑. 不多说,上代码. //读<写给大忙人看的java ...

  8. YbSoftwareFactory 代码生成插件【十三】:Web API 的安全性

    ASP.NET Web API 可非常方便地创建基于 HTTP 的 Services,这些服务可以非常方便地被几乎任何形式的平台和客户端(如浏览器.Windows客户端.Android设备.IOS等) ...

  9. 电脑安装Android4.0虚拟机的做法

    在开始教程之前,先给大家展示一下成功运行Android 4.0虚拟机的界面,经过笔者测试,体验很流畅,喜欢DIY和对开发感兴趣的朋友们可以猛击下一页,继续浏览教程. 准备工作 在体验前我们首先要下载J ...

  10. wx getlocation

    http://www.cnblogs.com/txw1958/p/weixin-web-location.html http://blog.csdn.net/myfmyfmyfmyf/article/ ...