Silverlight+WCF 实战-网络象棋最终篇之非线程阻塞倒计时窗口-应用篇(七)

简介:

在上一节:Silverlight+WCF 实战-网络象棋最终篇之非线程阻塞倒计 时窗口(四)中,我们通过ChildWindow实现了倒计时的窗口,来避免由于由于不点击确定而造成线程阻塞导致的请求超时问题,而本节将具体实现修改的细节代码,并附带最新源码下载。

 

另外中间提前插了两节“对战视频”的,欢迎感兴趣多多支持,点点推荐:

1:Silverlight+WCF 实战-网络象棋最终篇之对战视频-上篇[客户端开启视频/注册编号/接收视频](五)

2:Silverlight+WCF 实战-网络象棋最终篇之对战视频-下篇[客户端发送与服务端中转](六)

 

下面进入正文:

说明:

本节我们要处理的,就是出找出所有应用到MessageBox.Show的方法,将之换成自定义的MsgBox.Show方法即可。

 

为了调用方便与节流开源,我们将MsgBox提升到全局变量中,即放到App.xaml中。

public   static  MsgBox box  =   new  MsgBox(); // 全局定义

 

全局看了一下,还好,修改的地方不多,只有两个页面,以下为修改点:

1:Login.xaml 登陆提示修改:

复制代码
 
  
// MessageBox.Show("请输入昵称!");
   App.box.Show( " 请输入昵称! " , " 系统提示 " );

 
// MessageBox.Show("昵称不能包含非法字符!");
  App.box.Show( " 昵称不能包含非法字符! " " 系统提示 " );
复制代码

说明:

一共有两行提示的:注释的是原来的代码。改点非常少

看一下改造完后的消息提示:

  

 

2:EventButton.xaml 事件提示区,这里相对多一点改动

这里分两步修改:

第一步是修改只提示,没有逻辑判断分支的语句如下:

复制代码
  // MessageBox.Show("请求已发送,请等待对方回应!", "系统消 息",MessageBoxButton.OK);
App.box.Show( " 请求已发送,请等待对方回应! " " 系统消息 " );
 
// MessageBox.Show("对方同意开始游戏,请开始下棋", "游戏通 知", MessageBoxButton.OK);
App.box.Show( " 对方同意开始游戏,请开始下棋! " " 游戏通知 " );
 
// MessageBox.Show("对方拒绝开始游戏", "游戏通知", MessageBoxButton.OK);
App.box.Show( " 对方拒绝开始游戏! " " 游戏通知 " );
// MessageBox.Show("你的请求已发送,请等待回应", "游戏通知", MessageBoxButton.OK);
App.box.Show( " 你的请求已发送,请等待回应! " " 游戏通知 " );
// MessageBox.Show("对方拒绝平局", "游戏通知", MessageBoxButton.OK);
App.box.Show( " 对方拒绝平局! " " 游戏通知 " );
 
// MessageBox.Show("双方平局", "游戏结果通知", MessageBoxButton.OK);
App.box.Show( " 双方平局! " " 游戏结果通知 " );
// MessageBox.Show(e.player.NickName+" 认输了!", "游戏结果通 知", MessageBoxButton.OK);
App.box.Show(e.player.NickName  +   "  认输了! " " 游戏结果通知 " );
  
// MessageBox.Show(e.player.NickName+" 赢了!", "游戏结果通 知", MessageBoxButton.OK);
App.box.Show(e.player.NickName + "  赢了! " " 游戏 结果通知 " );
  
// MessageBox.Show(e.player.NickName + " 已进房间,请按开始按钮开始游 戏", "游戏通知", MessageBoxButton.OK);
App.box.Show(e.player.NickName  +   "  已进房间,请按开始按钮开始游戏 " " 游戏通知 " );
复制代码

第二步是修改带逻辑分支的代码,如下:

A:平手请求原代码:

复制代码
   case   " 22 " : // 平手 请求
   MessageBoxResult result  =  MessageBox.Show( " 对方请求平手,是否同意! " " 游戏请求 " , MessageBoxButton.OKCancel);
   
if  (result  ==  MessageBoxResult.OK) // 同意
    {
       App.player.AttachInfo 
=   " 21 " ; // 同意请求标识位设为21                 
   }
   
else // 拒绝
    {
       App.player.AttachInfo 
=   " 20 " ; // 拒绝请求标识位设为20
                        
    }
     App.client.EndGameAsync(App.player);
     
break ;
复制代码

 

改造成:

复制代码
  case   " 22 " : // 平手 请求
     App.box.Show( " 对方玩家请求和局,是否同 意? " " 游戏结束 " 10 , AgreeGameDeuce);  
     
break ;
  
// 方法AgreeGameDeuce
   void  AgreeGameDeuce( bool  result)
  {
     App.player.AttachInfo 
=   " 2 "   +  (result  ?   ""  :  " 0 " );
     App.client.EndGameAsync(App.player);
  }
复制代码

B:请求开始游戏原代码

复制代码
                  case   " 1 " : // 请求开始游戏
                    MessageBoxResult result  =  MessageBox.Show(e.player.NickName  +   " 请求开始游戏,是否同意开始 " " 游戏开始 " , MessageBoxButton.OKCancel);
                    App.player.AttachInfo 
=  (result  ==  MessageBoxResult.OK)   ?   " 11 " " 10 " ;
                    App.client.StartGameAsync(App.player);
                    
if  (result  ==  MessageBoxResult.OK) // 同意开始游戏
                    {
                        btnGameDeuce.IsEnabled 
=   true ;
                        btnGameLose.IsEnabled 
=   true ;
                        App.chess.IsGaming 
=   true ;
                    }
                     break ;
复制代码

改造成:

复制代码
  case   " 1 " : // 请求 开始游戏
  App.box.Show(e.player.NickName  +   "  请求开始游戏,是否同意开始 " " 游戏开始 " 6 , ConfirmStartGame);
  
break ;
// 方法:ConfirmStartGame
         void  ConfirmStartGame( bool  result)
        {
            
if  (result)
            {
                App.chess.IsGaming 
=   true ;
                btnGameDeuce.IsEnabled 
=   true ;
                btnGameLose.IsEnabled 
=   true ;
                App.player.AttachInfo 
=   " 11 " ;
            }
            
else
            {
                App.player.AttachInfo 
=   " 10 " ;
            }
            App.client.StartGameAsync(App.player);
// 应答
        }
复制代码

 

至此,我们终于将所有的消息弹出框改造完了。

 

看一下改造完后的消息提示:

 

 

 

接着是大家期待已久的源码下载:--第十阶段源码:点击下载[别忘了 留下言推荐下哦^-^]

 

最后:谢谢大家对本系列的喜欢,谢谢支持~

PS:传说点一下推荐会有10个园豆,喜欢麻烦点一下“推荐”,thank you very much!!

版权声明:本文原创发表于博客园,作者为路过秋天,原文链接:

http://www.cnblogs.com/cyq1162/archive/2010/12/27/1917777.html

相关文章
|
5月前
|
负载均衡 算法 安全
基于Reactor模式的高性能网络库之线程池组件设计篇
EventLoopThreadPool 是 Reactor 模式中实现“一个主线程 + 多个工作线程”的关键组件,用于高效管理多个 EventLoop 并在多核 CPU 上分担高并发 I/O 压力。通过封装 Thread 类和 EventLoopThread,实现线程创建、管理和事件循环的调度,形成线程池结构。每个 EventLoopThread 管理一个子线程与对应的 EventLoop(subloop),主线程(base loop)通过负载均衡算法将任务派发至各 subloop,从而提升系统性能与并发处理能力。
276 3
|
2月前
|
JSON 网络协议 安全
【Java】(10)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
160 1
|
2月前
|
JSON 网络协议 安全
【Java基础】(1)进程与线程的关系、Tread类;讲解基本线程安全、网络编程内容;JSON序列化与反序列化
几乎所有的操作系统都支持进程的概念,进程是处于运行过程中的程序,并且具有一定的独立功能,进程是系统进行资源分配和调度的一个独立单位一般而言,进程包含如下三个特征。独立性动态性并发性。
176 1
|
6月前
|
存储 SQL 安全
Java 无锁方式实现高性能线程实战操作指南
本文深入探讨了现代高并发Java应用中单例模式的实现方式,分析了传统单例(如DCL)的局限性,并提出了多种无锁实现方案。包括基于ThreadLocal的延迟初始化、VarHandle原子操作、Record不可变对象、响应式编程(Reactor)以及CDI依赖注入等实现方式。每种方案均附有代码示例及适用场景,同时通过JMH性能测试对比各实现的优劣。最后,结合实际案例设计了一个高性能配置中心,展示了无锁单例在实际开发中的应用。总结中提出根据场景选择合适的实现方式,并遵循现代单例设计原则以优化性能和安全性。文中还提供了代码获取链接,便于读者实践与学习。
116 0
|
2月前
|
Java 调度 数据库
Python threading模块:多线程编程的实战指南
本文深入讲解Python多线程编程,涵盖threading模块的核心用法:线程创建、生命周期、同步机制(锁、信号量、条件变量)、线程通信(队列)、守护线程与线程池应用。结合实战案例,如多线程下载器,帮助开发者提升程序并发性能,适用于I/O密集型任务处理。
257 0
|
7月前
|
设计模式 运维 监控
并发设计模式实战系列(4):线程池
需要建立持续的性能剖析(Profiling)和调优机制。通过以上十二个维度的系统化扩展,构建了一个从。设置合理队列容量/拒绝策略。动态扩容/优化任务处理速度。检查线程栈定位热点代码。调整最大用户进程数限制。CPU占用率100%
448 0
|
4月前
|
数据采集 消息中间件 并行计算
Python多线程与多进程性能对比:从原理到实战的深度解析
在Python编程中,多线程与多进程是提升并发性能的关键手段。本文通过实验数据、代码示例和通俗比喻,深入解析两者在不同任务类型下的性能表现,帮助开发者科学选择并发策略,优化程序效率。
275 1
|
6月前
|
算法 Java 测试技术
深度优化OSS上传性能:多线程分片上传 vs 断点续传实战对比
本文深入解析对象存储服务(OSS)文件上传性能优化技术,重点探讨多线程分片上传与断点续传两种方案。通过理论分析、代码实现和性能测试,对比其在不同场景下的表现差异,并提供选型建议与最佳实践,助力提升大文件上传效率与稳定性。
539 0