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

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

1:下棋者在下棋过程,要不要开放“回放”功能,如果开放,需要注意什么?

2:观众在回放过程中,突然又传来一个棋步,需要注意什么?

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

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

是由于在每次重置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 新手实例 象棋 专题索引

Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放-结局(四十)相关推荐

  1. Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放(三十九)

    在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 本节完后,同时会更新Silverlight+WCF 新手实例 象棋 专题索引,并顺路提供第八阶段源码 在Silverlight+ ...

  2. Silverlight+WCF 新手实例 象棋 主界面-棋谱-获取列表(三十八)

    2019独角兽企业重金招聘Python工程师标准>>> 在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 在Silverlight+WCF 新手实例 象棋 主界 ...

  3. Silverlight+WCF 新手实例 象棋 主界面-实时聊天区(二十五)

    在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 演示已更新到此节介绍:Silverlight+WCF 新手实例 象棋 介绍III(二十三) 本节连着Silverlight+WC ...

  4. Silverlight+WCF 新手实例 象棋 主界面-事件区-求和认输(三十二)

    在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 事隔几篇,我们又回到事件区,继续其它两个按钮事件,来张图吧: 在Silverlight+WCF 新手实例 象棋 主界面-事件区- ...

  5. Silverlight+WCF 新手实例 象棋 主界面-事件区-返回退出(三十三)

    在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 还是那张图: 本节实现返回大厅和退出系统: 一:返回大厅,其实很简单的说,就是转向房间列表了. 可是,转向前也有很多事情要处理的 ...

  6. Silverlight+WCF 新手实例 象棋 该谁下棋-B下A停(三十)

    2019独角兽企业重金招聘Python工程师标准>>> 在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 上上一节,就是二十八节:Silverlight+WCF ...

  7. Silverlight+WCF 新手实例 象棋 棋子移动-规则[附加上半盘限制](十)

    上上一节,我们对棋子的下半盘棋子做了所有的规则限制,因为我们下棋的总是用下半盘的棋子来下,总没人用上半盘棋来下那么高境界的吧. 不过这节简单追加点代码,让那些企图高境界的人士可以临时性的自己和自己下. ...

  8. Silverlight+WCF 新手实例 象棋 介绍(一)

    先发一下目前实例情况的截图: 1.登陆界面: 2.进入房间大厅 三种颜色,红色为红色玩家,黑色为黑色玩家,蓝色为主旁观者.点击就进去. 3.点击红色进入主界面 目前缺少系统消息文字输出,棋谱信息,棋谱 ...

  9. Silverlight+WCF 新手实例 象棋 介绍II(九)

    2019独角兽企业重金招聘Python工程师标准>>> 继上次介绍发图以来,除了一边写文章介绍以外,还进一步不断的完善,并增加了新的功能, 现在进一步上图,对目前情况的进展做一下简单 ...

最新文章

  1. ruby 正则表达式 使用正负预查
  2. 常用获取线程基本信息的方法(新手专属)
  3. 阮一峰react demo代码研究的学习笔记 - how to debug converted source code
  4. MacOS下MySQL配置
  5. series、dataframe转为tensor格式数据
  6. 对VC++一些常见问题的整理
  7. c语言课程设计实训主要目的,C语言课程设计实训指导书.doc
  8. 软件生产的工业化思路
  9. 手机android系统锁了怎么解,安卓手机解锁图案忘了怎么办?手机解锁密码忘了的解决办法...
  10. 自己实现一个Starter
  11. 记一次配置路由器无线桥接的过程——让古董路由器发挥余热
  12. Microsoft SQL Server 数据库使用(二)
  13. chrome必备插件
  14. 雨听 | 英语学习笔记(十二)~作文范文:成绩与能力
  15. 希尔排序Linux下c 实现
  16. 图数据库JanusGraph介绍及使用(一):简介
  17. 大雁塔,青龙寺,樱花舞,落尘香
  18. Base64实现图片的编码和解码 1
  19. 微信在线答题如何制作?
  20. java代码审计--之--常用框架了解

热门文章

  1. 【Java异常】Cannot deserialize value of type `java.util.Date` from String “2020-04-27T19:43:05.000+0800
  2. 中国石油大学《大学语文》第二阶段在线作业
  3. Flutter弹起键盘页面布局超限问题以及布局上移问题
  4. 爱奇艺逗芽表情搜索分析与实践
  5. UEFI启动和Bios(Legacy)启动的区别
  6. 糖葫芦(齐大第十一届校赛)
  7. java实现通过图片的URL地址下载图片
  8. web前端之五子棋网页版小游戏
  9. 【剑指Offer】个人学习笔记_61_扑克牌中的顺子
  10. autoCAD 创建对象 使用面域 创建图案填充