一起谈.NET技术,Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放-结局(四十)

简介: 查看本系列其他相关文章请点击:Silverlight+WCF 新手实例象棋专题索引在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示在Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放(三十九)中,我们实现了用户的棋谱回放,在文章的下面,我们曾留下了两...

查看本系列其他相关文章请点击:Silverlight+WCF 新手实例象棋专题索引

在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示

Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放(三十九)中,我们实现了用户的棋谱回放,在文章的下面,我们曾留下了两个问题:

  • 下棋者在下棋过程,要不要开放“回放”功能,如果开放,需要注意什么?
  • 观众在回放过程中,突然又传来一个棋步,需要注意什么?

在解答这两个问题之前,我们先来解答上一篇的截图中发现的问题:

不知有没有人发现?图中有三个“炮”或三个”马“,出现这个事故的原因,

是由于在每次重置chess.Reset的时候,我们没有清除棋子列表,造成了有重复的棋子。找到了原因,解决的方法就相当的简单了,

只要在chess象棋类里的确Reset方法里,添加一行棋子列表.clear方法清除下就行了,增加的只有第一行:

public   void  Reset()
{
   ChessmanList.Clear();
// 增加棋子列表清除
   container.Children.Clear(); // 棋盘和棋子一并清掉了
   InitBoard(); // 只好重新初始棋盘了
   InitChessman(); // 只好重新初始棋子了
   IsCanMove  =   false ; // 设置状态不能移动了
   IsGaming  =   false ; // 这个差点忘了
}

好了,一行代码解决了我们上一节隐藏在图片中的bug。

接下来,我们要对上节留下的两个问题做一下解答了:

我们把问题顺序倒一下,先解答第二个问题吧:观众在回放过程中,突然又传来一个棋步,需要注意什么?

我们在上一节,曾定义过一个全局变量:

public   static   bool  chessManualPlaying  =   false ; // 棋谱正回放中

而上节中,我只说了后面会用到[很后哦],所以,这节我们要用到了,因为这个变量可以解答问题:

我们假设:当观众在回放棋步的过程中,棋手双方在不停的下棋,不断的传递新的棋步过来;

这时,我们仅需要处理的,只是不执行自动播放而已,至于写棋谱区文字和添加到棋谱列表的照常就行了。

所以,我们要做的事情就是:开始播放时,设置App.chessManualPlaying为true;播放结束后,设置为false;

于是我们回到播放时的代码增加:

  private   void  PlayStep()
        {
            
if  (App.stepList.Count  >   0 )
            {
                
// 播放前复位棋子
                  App.chess.Reset();
                App.chessManualPlaying 
=   true ; // 增加的一行
                timer.Interval  =  TimeSpan.FromSeconds(slPlayerInternal.Value);
                timer.Start();
            }
        }

于是我们再回到播放结束时的代码增加:

void  timer_Tick( object  sender, EventArgs e)
        {
            
// ...省略N行...
            if  (moveStepIndex  ==  App.stepList.Count) // 棋步结束
            {
                moveStepIndex 
=   0 ; // 重置索引
                  timer.Stop(); // 停止timer
                App.chessManualPlaying  =   false ; // 增加的一行
            }
        }

标识位加完了,我们回到设置自动移动棋步的地方,加判断,如果播放中,切断棋步自动移动:

接收棋步的通知在Chess.xaml.cs里,我们只需要添加半行代码[下面的!App.chessManualPlaying]:

void  client_NotifyMoveStepReceived( object  sender, NotifyMoveStepReceivedEventArgs e)
        {
            App.stepList.Add(e.player.Step);
// 添加棋步
             if  ( ! App.chessManualPlaying  &&  App.player.ID  !=  e.player.ID) // 非棋步播放中,非自己
            {
              
// ...省略棋步移动相关代码...
             }
            HelpSetChessManualEvent(e.player.Step);
// 写棋谱区
        }

第二个问题,至此就解决了,总共添加了2.5行代码。

现在转回第一个问题了:下棋者在下棋过程,要不要开放“回放”功能,如果开放,需要注意什么?

不开放:只需要把“回放”按钮启用状态设置为false就行了;

开放:其实也不难:我们只要限制在播放过程中,不让棋手下棋就行了,

同时棋手播放过程也会产生第一个问题:不过,我们刚才已经解决,加的代码对棋手也是同样有效。

如何限制棋手不让下棋,其实很简单了,chess.IsCanMove属性就能限制了,只要播放时,设置为false,播放完,设置回原值就行了;

是不是感觉和第一个问题太相似了?动手吧,还是播放开始和结束,只不过,也要增加一个变量,来存棋手的下棋状态:

增加一行全局变量:

  public   partial   class  ChessManual : UserControl
    {
       
// ...省略2行代码...
         bool  tempIsCanMove; // 保存棋手之前的状态
         public  ChessManual()
        {
            
// ...省略N行代码...

        }
       
// ...省略N行代码...
   }

播放时,先取状态,再设置IsCanMove=false[这句在Reset重置里已经有了,可以省了];

  private   void  PlayStep()
        {
            
if  (App.stepList.Count  >   0 )
            {
                
// 播放前复位棋子
                tempIsCanMove  =  App.chess.IsCanMove; // 先存之前状态
                App.chess.Reset(); // 重置状态时会设置IsCanMove=false,所以不用写多一行
                App.chessManualPlaying  =   true ;
                timer.Interval 
=  TimeSpan.FromSeconds(slPlayerInternal.Value);
                timer.Start();
            }
        }

接着播放结束时,状态设置回来[最后一行代码]:

void  timer_Tick( object  sender, EventArgs e)
        {
            
// ...省略N行代码...
             if  (moveStepIndex  ==  App.stepList.Count) // 判断棋步结束没有
            {
                moveStepIndex 
=   0 ; // 重置索引
                timer.Stop(); // 停止timer
                App.chessManualPlaying  =   false ;
                App.chess.IsCanMove 
=  tempIsCanMove; // 增加的一行
            }
        }

 

OK,至此,我们用了同样的方法,解决了上节的两个问题,接下来又到F5的showtime时间:

正常,上图,这下棋步回放是正常的了:

1:棋手正下棋不久:

2:观众进来了,播放了棋步,定位到实时状态:

3:观众想看下棋过程,开始“回放”棋步:

4:“回放”到第三步棋中:

5:回放到第五步棋中:

OK,截图到就到此了,本系列文章,一不小心就写了40节了,在这系列的40节里,所有功能已完全的开放源码并讲解完了!

有兴趣的读者欢迎关注本系列文章,明天公司又要搬家了,本系列有没有后续文章,目前情况不明......

顺路更新下索引:Silverlight+WCF 新手实例 象棋 专题索引

目录
相关文章
|
4月前
|
监控 Cloud Native 测试技术
.NET技术深度解析:现代企业级开发指南
每日激励:“不要一直责怪过去的自己,他曾经站在雾里也很迷茫”。我是蒋星熠Jaxonic,一名在代码宇宙中探索的极客旅人。从.NET Framework到.NET 8,我深耕跨平台、高性能、云原生开发,践行领域驱动设计与微服务架构,用代码书写技术诗篇。分享架构演进、性能优化与AI融合前沿,助力开发者在二进制星河中逐光前行。关注我,共探技术无限可能!
.NET技术深度解析:现代企业级开发指南
|
10月前
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
428 0
|
开发框架 算法 .NET
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
C#/.NET/.NET Core技术前沿周刊 | 第 15 期(2024年11.25-11.30)
239 6
|
开发框架 Cloud Native .NET
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
C#/.NET/.NET Core技术前沿周刊 | 第 16 期(2024年12.01-12.08)
253 6
|
机器学习/深度学习 人工智能 Cloud Native
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台
在数字化时代,.NET 技术凭借其跨平台兼容性、丰富的类库和工具集以及卓越的性能与效率,成为软件开发的重要平台。本文深入解析 .NET 的核心优势,探讨其在企业级应用、Web 开发及移动应用等领域的应用案例,并展望未来在人工智能、云原生等方面的发展趋势。
313 3
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
503 5
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
503 0
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
299 7
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
319 0
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
262 0