文字直播是满足一些观看视频直播而条件不足的球迷所设定的比赛直播方式,例如在长途车上为了能够了解比赛的实时赛况但又限于流量和网速等问题,就出现了文字直播的方式。无论是拥有无线上网卡的笔记本电脑或者手机等终端设备都可以通过访问文字直播满足用户需求,本实例将通过预先定义好的直播数据来模拟文字直播效果,具体实现步骤如下:

(1)新建一个网站并创建一个Default.aspx页面,在页面将使用div标签进行直播窗口的布局,除了要实时更新的数据信息外,还包含一个控制复选框,用于启用或停止自动更新。页面源中要更新的布局标签如下:

  <divclass="livecontent">

  <divclass="livecontenttitle"><span>球队</span><span>时间</span>

  <span>解说</span><span>比分</span></div>

  <asp:ScriptManagerID="ScriptManager1"runat="server"></asp:ScriptManager>

  <asp:UpdatePanelID="UpdatePanel1"runat="server">

  <ContentTemplate>

  <divclass="livecontentbody"id="livecontentbody"runat="server"></div>

  <asp:TimerID="Timer1"runat="server"

  Interval=""OnTick="Timer1_Tick"></asp:Timer>

  </ContentTemplate>

  </asp:UpdatePanel>

  </div>

(2)为了模拟直播员录入的比赛信息,在实例中将通过程序填充一些比赛数据,并且需要定义数据容器来承载这些数据,代码如下:

  publicstaticStringBuilder str = newStringBuilder();//比赛内容数据绑定容器

  publicstaticList<string[]> result = newList<string[]>();//直播员输入的比赛数据容器

  publicstaticint Index = -;//比赛信息数据索引

  protectedvoid Page_Load(object sender, EventArgs e)

   {

  if (!IsPostBack)

      {

  //首次加载时填充数据容器

          result.Add(newstring[] { "cl", "11:48", "特里斯坦汤普森两分球进", "0-0" });

          result.Add(newstring[] { "ov", "00:00", "第一节结束", "30-30" });

  //页面加载设置友好提示信息

  this.livecontentbody.InnerHtml =

  "<div class=\"start\">各位观众大家好,比赛已经正式开始!</div>";

     }

   }

注意:

由于篇幅的限制所以代码中只给出了开始数据和结束数据,实际数据总数为20条。

(3)再来实现启用或暂停的复选框功能,代码如下:

  protectedvoid CheckBox1_CheckedChanged(object sender, EventArgs e)

  {

  this.Timer1.Enabled = ((CheckBox)sender).Checked;//用于启用或暂停比赛直播

   }

(4)最后定义Timer定时器定时触发方法的功能,该处理方法将每隔10秒钟进行一次调用,然后在方法中随机生成1到3条数据并填充到容器,最后绑定到页面上,代码如下:

  protectedvoid Timer1_Tick(object sender, EventArgs e)

  {

  Random ran = newRandom();//创建随机类

  int r = ran.Next(, );//生成1-3随机数

  //根据生成的随机数进行循环,并判断总的数据量没有超出循环范围

  for (int i = ; i < r && Index < ; i++)

      {

          Index++;//从0开始

  string[] arr = result[Index];//获取指定索引的数据

  //向绑定容器中第0个位置插入比赛信息,此方式确保最新的数据永远排在最上面

          str.Insert(, "<div class=\"livecontentbodylist\">" +

  "<span><img src=\"images/" + arr[] + ".png\"/></span>" +

  "<span>" + arr[] + "</span>" +

  "<span>" + arr[] + "</span>" +

  "<span>" + arr[] + "</span>" +

  "</div>");

  }

  this.livecontentbody.InnerHtml = str.ToString();//绑定到页面div容器中

  if (Index > )//判断索引值是否超出数据总数

      {

  this.Timer1.Enabled = false;//如果超出则本节结束,停止更新

      }

  }

执行程序,页面加载时将提示友好信息,如图13.6所示,比赛开始后效果如图13.7所示,最后第一节比赛结束后效果如图13.8所示。

图13.6  直播前友好提示信息

图13.7  直播时的赛况信息

图13.8  结束时停止更新

本文摘自明日科技出版的《零基础学asp.net》,转载请注明出处!!!

通过ASP.NET Ajax技术模拟实现NBA比赛文字直播功能的更多相关文章

  1. 使用AJAX技术发送异步请求,HTTP服务端推送

    使用AJAX技术发送异步请求 什么是AJAX AJAX指一步Javascript和XML(Asynchronous JavaScript And XML),它是一些列技术的组合,简单来说AJAX基于X ...

  2. 利用ASP.NET AJAX的Timer讓GridView每隔一段時間做到自動換頁的功能

    最近在討論區看到這個問題,小弟利用asp.net ajax的timer來實作這個功能 利用timer每隔一段時間,讓gridview自動跳頁並且更新gridview的內容 asp.net(c#) Gr ...

  3. ASP.NET AJAX入门系列(1):概述

    经常关注我的Blog的朋友可能注意到了,在我Blog的左边系列文章中,已经移除了对Atlas学习手记系列文章的推荐,因为随着ASP.NET AJAX 1.0 Beta版的发布,它们已经不再适用,为了不 ...

  4. C#/ASP.NET/AJAX

      C#/ASP.NET/AJAX ASP.NET 4.5新特性一:强类型数据绑定(Strongly-Type Data-Bindings) 摘要: 随着ASP.NET 4.5的发布提供了很多的新特性 ...

  5. 【转】【Asp.Net】了解使用 ASP.NET AJAX 进行局部页面更新

    简介Microsoft的 ASP.NET 技术提供了一个面向对象.事件驱动的编程模型,并将其与已编译代码的优势结合起来.但其服务器端的处理模型仍存在技术本身所固有的几点不足: 进行页面更新需要往返服务 ...

  6. Java之Ajax技术

    ajax(asynchronouse javascript and xml) 异步的javascript 和 xml(现在常把xml换成json): ajax是2005年提出的,在2006,2007年 ...

  7. Ajax 技术一

    一.Ajax概述 1.历史起源 1998年,微软公司Outlook Web Access研发小组在当时的IE浏览器中集成了一种技术,可以在客户端无刷新的前提下向服务器端发送Http请求,这门技术称之为 ...

  8. 你真正的了解Ajax?Ajax技术简述

    Ajax技术是目前在浏览器中通过JavaScript脚本可以使用的所有技术的集合.Ajax并没有创造出某种具体的新技术,它所使用的大多数技术都是在很多年以前就已经存在了,然而Ajax以一种崭新的方式来 ...

  9. asp.net ajax检查用户名是否存在代码

    原文  asp.net ajax检查用户名是否存在代码 用户注册时,我们经常需要检查用户名是否存在,本文就是实现无刷新验证用户名 打开开发环境VS 2005,新建项目(或打开现有项目),新建一个Web ...

随机推荐

  1. 解决高分屏/高DPI下GNOME3/Linux字体和按钮太小的问题

    更改系统设置就好了. 我的设备是Surface Pro,12英寸,分辨率2736x1824,在虚拟机里安装CentOS 7后字特别小,标题栏的最小化/最大化/关闭按钮也很小,眼睛受不了的. 更改两个设 ...

  2. 基本数据类型:布尔型(bool)和空值None

    一.布尔型(bool) 布尔类型很简单,就两个值 ,一个True(真),一个False(假), 主要用记逻辑判断: 一件事情成立就是True,不成立就是False,也可以将bool值归类为数字, 是因 ...

  3. C# WPF 无窗体传递消息

    WPF如果存在窗体(或至少,在任务栏有图标显示),互相传递消息是很容易的. 寻找目标窗体句柄->WindowsAPI SendMessage/PostMessage->目标窗体AddHoo ...

  4. 请问spfa+stack 和spfa+queue 是什么原理

    一个是bfs加迭代 一个是dfs加迭代 请问迭代是什么 就是不断地做,做到没有更优的解为止 或者是不断得做,做到逼近答案为止.. 栈比队列更快更节省空间

  5. [TS-A1487][2013中国国家集训队第二次作业]分配游戏[二分]

    根据题意,设$3n$次比较中胜了$w$次,负了$l$次,平了$d$次,所有场次中胜了$W$次,负了$L$次,平了$D$次.如果一场赢了,那么$w-l$就会$+1$,相同地,$W-L$也会$+1$:如果 ...

  6. CODEVS2144 砝码称重2 (哈希表)

    由于m很大,所以不能使用DP. 注意到n≤30,直接暴力2^n会TLE. 所以,将砝码平均分成两份,对一份进行一次暴力,用哈希表存下可能的结果. 对下一份再进行一次暴力,在哈希表中搜索剩余的砝码重量是 ...

  7. 知新之--12-factors

    作为总的原则,在程序设计上很有高度... 参考URL:http://12factor.net/zh_cn/ ========================================== 12- ...

  8. U - Palindrome Manacher

    Andy the smart computer science student was attending an algorithms class when the professor asked t ...

  9. servlet和Spring的DispatcherServlet详解

    Servlet是什么 1. Servlet是服务器端运行的一个程序,是一个被编译好的Java类.它不是框架等. 2. Web容器的启动,需要依赖Servlet.当web服务器开始执行时,servlet ...

  10. [Meteor] Meteor安装被墙问题

    我的系统安装地址是这个https://static-meteor.netdna-ssl.com/packages-bootstrap/1.3.2.4/meteor-bootstrap-os.osx.x ...