Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放-结局(四十)
在线演示地址: Silverlight+WCF 新手实例 象棋 在线演示
在Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放(三十九)中,我们实现了用户的棋谱回放,在文章的下面,我们曾留下了两个问题:
1:下棋者在下棋过程,要不要开放“回放”功能,如果开放,需要注意什么?
2:观众在回放过程中,突然又传来一个棋步,需要注意什么?
在解答这两个问题之前,我们先来解答上一篇的截图中发现的问题:
不知有没有人发现?图中有三个“炮”或三个”马“,出现这个事故的原因,
是由于在每次重置chess.Reset的时候,我们没有清除棋子列表,造成了有重复的棋子。找到了原因,解决的方法就相当的简单了,
只要在chess象棋类里的确Reset方法里,添加一行棋子列表.clear方法清除下就行了,增加的只有第一行:
{
ChessmanList.Clear();//增加棋子列表清除
container.Children.Clear();//棋盘和棋子一并清掉了
InitBoard();//只好重新初始棋盘了
InitChessman();//只好重新初始棋子了
IsCanMove = false;//设置状态不能移动了
IsGaming = false;//这个差点忘了
}
好了,一行代码解决了我们上一节隐藏在图片中的bug。
接下来,我们要对上节留下的两个问题做一下解答了:
我们把问题顺序倒一下,先解答第二个问题吧:观众在回放过程中,突然又传来一个棋步,需要注意什么?
我们在上一节,曾定义过一个全局变量:
而上节中,我只说了后面会用到[很后哦],所以,这节我们要用到了,因为这个变量可以解答问题:
我们假设:当观众在回放棋步的过程中,棋手双方在不停的下棋,不断的传递新的棋步过来;
这时,我们仅需要处理的,只是不执行自动播放而已,至于写棋谱区文字和添加到棋谱列表的照常就行了。
所以,我们要做的事情就是:开始播放时,设置App.chessManualPlaying为true;播放结束后,设置为false;
于是我们回到播放时的代码增加:
{
if (App.stepList.Count > 0)
{
//播放前复位棋子
App.chess.Reset();
App.chessManualPlaying = true;//增加的一行
timer.Interval = TimeSpan.FromSeconds(slPlayerInternal.Value);
timer.Start();
}
}
于是我们再回到播放结束时的代码增加:
{
//...省略N行...
if (moveStepIndex == App.stepList.Count)//棋步结束
{
moveStepIndex = 0;//重置索引
timer.Stop();//停止timer
App.chessManualPlaying = false;//增加的一行
}
}
标识位加完了,我们回到设置自动移动棋步的地方,加判断,如果播放中,切断棋步自动移动:
接收棋步的通知在Chess.xaml.cs里,我们只需要添加半行代码[下面的!App.chessManualPlaying]:
{
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,播放完,设置回原值就行了;
是不是感觉和第一个问题太相似了?动手吧,还是播放开始和结束,只不过,也要增加一个变量,来存棋手的下棋状态:
增加一行全局变量:
{
//...省略2行代码...
bool tempIsCanMove;//保存棋手之前的状态
public ChessManual()
{
//...省略N行代码...
}
//...省略N行代码...
}
播放时,先取状态,再设置IsCanMove=false[这句在Reset重置里已经有了,可以省了];
{
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();
}
}
接着播放结束时,状态设置回来[最后一行代码]:
{
//...省略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 新手实例 象棋 主界面-棋谱-回放-结局(四十)相关推荐
- Silverlight+WCF 新手实例 象棋 主界面-棋谱-回放(三十九)
在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 本节完后,同时会更新Silverlight+WCF 新手实例 象棋 专题索引,并顺路提供第八阶段源码 在Silverlight+ ...
- Silverlight+WCF 新手实例 象棋 主界面-棋谱-获取列表(三十八)
2019独角兽企业重金招聘Python工程师标准>>> 在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 在Silverlight+WCF 新手实例 象棋 主界 ...
- Silverlight+WCF 新手实例 象棋 主界面-实时聊天区(二十五)
在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 演示已更新到此节介绍:Silverlight+WCF 新手实例 象棋 介绍III(二十三) 本节连着Silverlight+WC ...
- Silverlight+WCF 新手实例 象棋 主界面-事件区-求和认输(三十二)
在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 事隔几篇,我们又回到事件区,继续其它两个按钮事件,来张图吧: 在Silverlight+WCF 新手实例 象棋 主界面-事件区- ...
- Silverlight+WCF 新手实例 象棋 主界面-事件区-返回退出(三十三)
在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 还是那张图: 本节实现返回大厅和退出系统: 一:返回大厅,其实很简单的说,就是转向房间列表了. 可是,转向前也有很多事情要处理的 ...
- Silverlight+WCF 新手实例 象棋 该谁下棋-B下A停(三十)
2019独角兽企业重金招聘Python工程师标准>>> 在线演示地址:Silverlight+WCF 新手实例 象棋 在线演示 上上一节,就是二十八节:Silverlight+WCF ...
- Silverlight+WCF 新手实例 象棋 棋子移动-规则[附加上半盘限制](十)
上上一节,我们对棋子的下半盘棋子做了所有的规则限制,因为我们下棋的总是用下半盘的棋子来下,总没人用上半盘棋来下那么高境界的吧. 不过这节简单追加点代码,让那些企图高境界的人士可以临时性的自己和自己下. ...
- Silverlight+WCF 新手实例 象棋 介绍(一)
先发一下目前实例情况的截图: 1.登陆界面: 2.进入房间大厅 三种颜色,红色为红色玩家,黑色为黑色玩家,蓝色为主旁观者.点击就进去. 3.点击红色进入主界面 目前缺少系统消息文字输出,棋谱信息,棋谱 ...
- Silverlight+WCF 新手实例 象棋 介绍II(九)
2019独角兽企业重金招聘Python工程师标准>>> 继上次介绍发图以来,除了一边写文章介绍以外,还进一步不断的完善,并增加了新的功能, 现在进一步上图,对目前情况的进展做一下简单 ...
最新文章
- ruby 正则表达式 使用正负预查
- 常用获取线程基本信息的方法(新手专属)
- 阮一峰react demo代码研究的学习笔记 - how to debug converted source code
- MacOS下MySQL配置
- series、dataframe转为tensor格式数据
- 对VC++一些常见问题的整理
- c语言课程设计实训主要目的,C语言课程设计实训指导书.doc
- 软件生产的工业化思路
- 手机android系统锁了怎么解,安卓手机解锁图案忘了怎么办?手机解锁密码忘了的解决办法...
- 自己实现一个Starter
- 记一次配置路由器无线桥接的过程——让古董路由器发挥余热
- Microsoft SQL Server 数据库使用(二)
- chrome必备插件
- 雨听 | 英语学习笔记(十二)~作文范文:成绩与能力
- 希尔排序Linux下c 实现
- 图数据库JanusGraph介绍及使用(一):简介
- 大雁塔,青龙寺,樱花舞,落尘香
- Base64实现图片的编码和解码 1
- 微信在线答题如何制作?
- java代码审计--之--常用框架了解
热门文章
- 【Java异常】Cannot deserialize value of type `java.util.Date` from String “2020-04-27T19:43:05.000+0800
- 中国石油大学《大学语文》第二阶段在线作业
- Flutter弹起键盘页面布局超限问题以及布局上移问题
- 爱奇艺逗芽表情搜索分析与实践
- UEFI启动和Bios(Legacy)启动的区别
- 糖葫芦(齐大第十一届校赛)
- java实现通过图片的URL地址下载图片
- web前端之五子棋网页版小游戏
- 【剑指Offer】个人学习笔记_61_扑克牌中的顺子
- autoCAD 创建对象 使用面域 创建图案填充