为了账号安全,请及时绑定邮箱和手机立即绑定

Silverlight+WCF 新手实例 象棋 获取房间状态列表更新

标签:
架构

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

 

上节是当有用户进入某个房间时,我的某个房间状态被通知,并被通知更新。

这节说说首次进入房间大厅时,我们自己创建了N个房间,默认都是初始状态的,这时我们需要获取服务端的所有已更新的房间状态,

下到本地之后,进行批量更新状态。

 

于是开始了,首先从服务端开始,我们要获取所有已更新的房间,于是到WCF服务端添加一个方法:

到IService.cs添加方法接口

[OperationContract]
Dictionary<int, Room> GetRoomList();

 

接着要实现方法了,到Service.cs去

太阳,这方法太简单了,由于我们之前就有全局的roomList对象,直接返回就可以了。

public Dictionary<int, Room> GetRoomList()
{
  return roomList;
}

 

 

两三行代码就搞定了服务端了。于是我们悄悄的回到客户端

当然了,还是得编绎,更新服务引用,这个说多了,大伙自觉点。

我们回到房间页面Room.xaml.cs里去

我们在构造函数里添加两行代码,默认请求房间列表:

由于之前已有些代码,大伙看注释那两行:

复制代码

public Room()
{
  InitializeComponent();
  game = new Game();
  game.CreateGameRoom(30);
  game.DrawIn(LayoutRoot);
//看这里看这里,这两行是新添加的,获取房间列表
App.client.GetRoomListCompleted += new EventHandler<GameService.GetRoomListCompletedEventArgs>(client_GetRoomListCompleted);
App.client.GetRoomListAsync();
//这里实现ICallBack的方法
App.client.NotifyRoomUpdateReceived += new EventHandler<GameService.NotifyRoomUpdateReceivedEventArgs>(client_NotifyRoomUpdateReceived);
}
 //这里也要看,这里是获取房间列表的事件
void client_GetRoomListCompleted(object sender, GameService.GetRoomListCompletedEventArgs e)
{
   //房间获取完了,待实现
}复制代码

 

看到了吧,获取完后,我们要干点什么呢?当实是实现更新房间状态了。

复制代码

//这里也要看,这里是获取房间列表的事件
        void client_GetRoomListCompleted(object sender, GameService.GetRoomListCompletedEventArgs e)
        {
            //房间获取完了,下面实现了
            if (e.Result == null)
            {
                return;
            }
            //变化的房间列表
            Dictionary<int, GameService.Room> roomList = e.Result as Dictionary<int, GameService.Room>;
            if (roomList.Count > 0)
            {
                foreach (KeyValuePair<int, GameService.Room> item in roomList)
                {
                    if (item.Key > 0 && item.Key < 31)
                    {
                        UpdateRoomState(item.Value, game.GameRoomList[item.Key - 1]);
                    }
                }
            }
        }复制代码

 

看到那个UpdateRoomState函数,别说不认识,就上节我们在通知房间更新时,特别皮痒封装起来的。

搞定了,这节的代码都特别简洁,特别简单,接下来按F5看看效果:

一开始的登陆,和进入房间就不截图了,本系列截的太多了。

这里为Index页面加上一句用户显示文字,免的一片空白,第一个进去如下图:


好,开多一个浏览器,第二个用户登陆:


一进去,默认第一个用户位置就亮蓝色灯了

 OK,此节就到此结束了。


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消