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

(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. 00106_UDP通信

    1.DatagramPacket (1)JDK中提供了一个DatagramPacket类,该类的实例对象就相当于一个集装箱,用于封装UDP通信中发送或者接收的数据: (2)在创建发送端和接收端的Dat ...

  2. 【POJ 1860】Currency Exchange

    [题目链接]:http://poj.org/problem?id=1860 [题意] 给你n种货币,m种货币之间的交换信息; 交换信息以 A,B,RA,CA,RB,CB的形式给出; 即A换B的话假设A ...

  3. 允许MS SqlServer远程连接

    实际问题: 服务器192.168.0.103上的SQL Express数据库实例,局域网内其余机器的Sql Server Management Studio都无法连接. 在本机上,可以用“.\SqlE ...

  4. JAVA的堆和栈(转)

    堆栈是 两种数据结构.堆栈都是一种数据项按序排列的数据结构,只能在一端(称为栈顶(top))对数据项进行插入和删除.在单片机应用中,堆栈是个特殊的存储 区,主要功能是暂时存放数据和地址,通常用来保护断 ...

  5. SpringMVC+security

    转自:http://blog.csdn.net/bigshotzhang/article/details/12346979 下面我们将实现关于Spring Security3的一系列教程. 最终的目标 ...

  6. JVM内存管理和垃圾回收机制介绍

    http://backend.blog.163.com/blog/static/20229412620128233285220/     内存管理和垃圾回收机制是JVM最核心的两个组成部分,对其内部实 ...

  7. apache禁止訪问某些文件或文件夹的方法

    [apache配置禁止訪问] 1. 禁止訪问某些文件/文件夹 添加Files选项来控制,比方要不同意訪问 .inc 扩展名的文件,保护php类库: <Files ~ "\.inc$&q ...

  8. NSThread/NSOperation/GCD 三种多线程技术

    1.iOS的三种多线程技术 1.NSThread 每个NSThread对象对应一个线程,量级较轻(真正的多线程) 2.以下两点是苹果专门开发的“并发”技术,使得程序员可以不再去关心线程的具体使用问题 ...

  9. light oj1074

    Description The people of Mohammadpur have decided to paint each of their houses red, green, or blue ...

  10. 支付宝即时到帐接口的python实现,演示样例採用django框架

    因工作须要研究了支付宝即时到帐接口.并成功应用到站点上,把过程拿出来分享. 即时到帐仅仅是支付宝众多商家服务中的一个,表示客户付款,客户用支付宝付款.支付宝收到款项后,立即通知你,而且此笔款项与交易脱 ...