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

(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. Problem 29

    Problem 29 Consider all integer combinations of ab for 2 ≤ a ≤ 5 and 2 ≤ b ≤ 5: 仔细看看以下a与b的组合 22=4, 2 ...

  2. STM32定时器配置(TIM1-TIM8)高级定时器+普通定时器,定时计数模式下总结

    文章结构: ——> 一.定时器基本介绍 ——> 二.普通定时器详细介绍TIM2-TIM5 ——> 三.定时器代码实例 一.定时器基本介绍  之前有用过野火的学习板上面讲解很详细,所以 ...

  3. 清北学堂模拟赛d1t5 拍照(photo)

    题目描述 假设这是一个二次元.LYK召集了n个小伙伴一起来拍照.他们分别有自己的身高Hi和宽度Wi.为了放下这个照片并且每个小伙伴都完整的露出来,必须需要一个宽度为ΣWi,长度为max{Hi}的相框. ...

  4. CODEVS1533 Fibonacci数列 (矩阵乘法)

    嗯,,,矩阵乘法最基础的题了. Program CODEVS1250; ..,..] of longint; var T,n,mo:longint; a,b:arr; operator *(a,b:a ...

  5. hdu_1048_The Hardest Problem Ever_201311052052

    The Hardest Problem Ever Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java ...

  6. Spring MVC-表单(Form)标签-下拉框(Dropdown)示例(转载实践)

    以下内容翻译自:https://www.tutorialspoint.com/springmvc/springmvc_dropdown.htm 说明:示例基于Spring MVC 4.1.6. 以下示 ...

  7. 开源GIS软件 2

    Android上的导航软件 AndNav AndNav 是一款 Android 手机上的 GPS导航软件(非开源).软件支持GPS定位信息,目的地查询,道路建议管理,导航提示等功能,十分强大的一款软件 ...

  8. CF #EDU R1 E

    最二的一次了~我开始以为是带有贪心的DP,谁知道想错了.后来才想明白,暴力二分+记忆化DP #include <iostream> #include <cstdio> #inc ...

  9. .Net程序猿玩转Android开发---(6)线性布局LinearLayout

                                LinearLayout控件是Android中重要的布局控件,是一个线性控件,所谓线性控件的意思是指该控件里面的内容仅仅能水平或垂直排列.也就 ...

  10. 十分钟学会canvas

    一句话描述:canvas是HTML5加入的用来绘制2D图像与文字的元素. 基础 简单步骤: var c = document.getElementById("mycanvas"); ...