Silverlight C# 游戏开发:草动系统(一)简单的草动

简介:

昨天晚上在银光进化论谈聊到以前MU的草动效果,Goods尤其觉得很好,正巧我以前做过草动的系统,可以作为经验总结一下,最近一直纠结文章标题,正好借此发挥一下,抛砖引玉:)

以前写的草动系统都是3D的,这次写2D的确实有一些麻烦,整理思路用了很久,好在Silverlight提供了很好的动画支持,很方便的就实现了一个简单的草动效果。

首先很简单,建立一个Silverlight4的项目:GrassTest01

工程的.Web项目叫GrassShow.Web,我想以后可能还有GrassTest02,03,04……

准备好地面和草(资源来自:《窝窝世界》)


创建一个控件叫Grass01,将图片添加到控件中,我的Blend已经过期,只好使用代码来实现这个过程,请参看代码:

 

Grass01控件代码
 
 
  1. <UserControl x:Class="GrassTest01.Grass01" 
  2. xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" 
  3. xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" 
  4. xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
  5. xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
  6. mc:Ignorable="d" 
  7. d:DesignHeight="300" d:DesignWidth="400"> 
  8. <UserControl.Resources> 
  9. <Storyboard x:Name="Ani_Def" RepeatBehavior="Forever" AutoReverse="True"> 
  10. <DoubleAnimationUsingKeyFrames Storyboard.TargetProperty="(UIElement.RenderTransform).(CompositeTransform.Rotation)" Storyboard.TargetName="LayoutRoot"> 
  11. <EasingDoubleKeyFrame KeyTime="0" Value="1.621"/> 
  12. <EasingDoubleKeyFrame KeyTime="0:0:1" Value="-1.839"/> 
  13. </DoubleAnimationUsingKeyFrames> 
  14. </Storyboard> 
  15. </UserControl.Resources> 
  16.  
  17. <Canvas x:Name="LayoutRoot"> 
  18. <Canvas.RenderTransform> 
  19. <CompositeTransform/> 
  20. </Canvas.RenderTransform> 
  21. <Image x:Name="image" Source="/GrassTest01;component/Res/Grass01.png" Canvas.Left="-25" Canvas.Top="-77" RenderTransformOrigin="0.5,0.9"> 
  22. </Image> 
  23. </Canvas> 
  24. </UserControl> 
 

上述代码其实使用Blend很容易实现,可惜对于我来说只有使用这个暴力方法了:)
需要特别说明两个部分,一个是动画摇摆部分:动画摇摆幅度可以通过修改DoubleAnimationUsingKeyFrames中的EasingDoubleKeyFrame来修改。另外一个是摇摆的主体,本来我想直接摇动Image,结果发现不太直观,尤其是RenderTransformOrigin的对齐,所以我直接将摇摆的动画设置到LayoutRoot,这样从根点就可以看到效果了,这是一个非常好的方法,原点可以将很多的资源元素产生的偏移点问题解决。


由于动画不会自动启动,需要在Grass01.xaml.cs中添加如下代码:

Grass01 类
 
 
  1. public partial class Grass01 : UserControl  
  2. {  
  3. public Grass01()  
  4. {  
  5. InitializeComponent();  
  6. Ani_Def.BeginTime = TimeSpan.FromSeconds(MainPage._PointRandom.NextDouble());  
  7. Ani_Def.Begin();   
  8. }  
  9.  
  10. }  
 

需要特别说明的是Ani_Def.BeginTime,随机了一个启动时间,为了更好的模拟草的随机性,而MainPage._PointRandom是一个静态的随机种子,让随机性更高。
然后就是生成,这个比较简单就是种草而已,只需要在MainPage.xaml.cs中加入代码:

代码
 
 
  1. public static Random _PointRandom = new Random((int)DateTime.Now.Ticks);  
  2. public MainPage()  
  3. {  
  4. InitializeComponent();  
  5. Image Image = new Image();  
  6. LayoutRoot.Children.Add(Image);  
  7. Image.Source = new BitmapImage(new Uri(@"/GrassTest01;component/Res/Map01.jpg", UriKind.Relative));  
  8. for (int i = 0; i < 300; i++)  
  9. {  
  10. Grass01 g1 = new Grass01();  
  11. LayoutRoot.Children.Add(g1);  
  12. Canvas.SetLeft(g1, _PointRandom.Next(50,800));  
  13. int y_PointRandom.Next(50,600);  
  14. Canvas.SetTop(g1,y );  
  15. Canvas.SetZIndex(g1, y);  
  16. }  
  17.  
  18. }   
  19.    
  20.  
我随便生成了300颗草,先看看效果:
 

动起来效果还是不错的,随机性很强,有“微风”感,可是CPU咱们可真不可恭维,简直是噩梦,相信某些“老板”看了这个效果就直接枪毙了Silverlight,什么东西啊,一个小小的草动效果就这样,开什么玩笑开发大型游戏?想想也是,咱们还是放弃算了,玩这个真的没前途。。。。
其实呢,并不是如此,只需要开启GPU加速,胜利的女神就开始向你招手了,需要添加两行代码:

1、打开Grass01.xaml.cs,添加image.CacheMode = new BitmapCache();,这里的image是你的草的Image名称,可以是任何名称

2、打开.html或者.aspx,就是承载页面找到object标签添加代码,<param name="enableGPUAcceleration" value="true"/>

这下运行再看看。

 

微风仍然吹过,看起来还是那么平静,效果似乎达到了哦:)想了解这方面更多的请参考深蓝色右手有关的GPU加速文章
我发现很多的效果并不是需要很多的代码来堆积,有的时候,使用简单的代码就能达到想要的效果,其实并不复杂,有可能仅仅是灵光一闪而已。
本次的源代码在这里下载:点击这里下载源代码

展示效果如下:(小人使用键盘WASD控制)

 

PS:小人的基础系统也不是很复杂,我取出了自己引擎中的一套实现方法,大部分开发手法都在过往的文章中写过,继续欢迎对Silverlight技术研究的朋友共同探讨,对于有一定水平的朋友欢迎加入“银光进化论谈”群9675769,加入条件有限制请了解后申请http://www.cnblogs.com/nowpaper/archive/2010/07/12/1775887.html



本文转自nowpaper 51CTO博客,原文链接:http://blog.51cto.com/nowpaper/712380

相关文章
|
3月前
|
存储 开发框架 .NET
【C#】C# 基础语法与游戏开发
【1月更文挑战第21天】【C#】C# 基础语法与游戏开发
|
8天前
|
开发框架 前端开发 JavaScript
采用C#.Net +JavaScript 开发的云LIS系统源码 二级医院应用案例有演示
技术架构:Asp.NET CORE 3.1 MVC + SQLserver + Redis等 开发语言:C# 6.0、JavaScript 前端框架:JQuery、EasyUI、Bootstrap 后端框架:MVC、SQLSugar等 数 据 库:SQLserver 2012
|
25天前
|
安全 JavaScript 前端开发
C#医院手麻系统源码,手术麻醉管理系统源码
手术麻醉管理系统贯穿患者入院至出院全程,整合术前术后流程,如手术排班、麻醉计划、术中监护及术后恢复。采用C#.net6.0、Vue、Ant-Design等技术,与sqlserver2019数据库结合。系统提供麻醉记录、手术安全核查、费用管理等功能,确保信息数字化和流程规范化。通过自动化记录和数据分析,增强手术安全,优化资源分配,并支持医疗质控与研究。
C#医院手麻系统源码,手术麻醉管理系统源码
|
26天前
|
存储 监控 安全
C#手术麻醉系统源码 大型医院手麻系统4大需求是什么?
C#编写的大型医院手术麻醉系统旨在满足四大核心需求:智慧医院建设,要求实时患者信息共享与监控;医院等级评级,强调安全评估与术后管理;电子病历评级,规定手术预约、麻醉信息的标准化;科室需求,包括系统互联、流程信息化、数据追溯、操作简便、文书完整、快速响应、生命体征动态采集及质量控制。系统提升手麻工作的效率与安全性,确保手术顺利进行。
|
1月前
|
数据挖掘 C# 开发工具
采用C#语言开发的全套医院体检系统PEIS源码功能介绍
体检系统,是专为体检中心/医院体检科等体检机构,专门开发的全流程管理系统,通过软件实现检测仪器数据自动提取,内置多级医生工作台,细化工作将体检检查结果汇总,生成体检报告登记到计算机系统中。通过软件系统进行数据分析统计与评判以及建立体检相关的体检档案。从而实现体检流程的信息化,提高工作效率,减少手动结果录入的一些常犯错误。 在实际应用中,医院体检系统能够解决传统体检中手工操作带来的问题,如工作量大、效率低下、易漏检、重检或错检等。通过与医院信息系统(如HIS、LIS、PACS等)的连接,系统能够满足体检中心的日常工作流程,提供更好的管理、统计和查询分析功能。同时,基于网络基础的系统可以在网上传输
23 1
|
2月前
|
开发框架 前端开发 NoSQL
C#医院区域云LIS系统源码
LIS操作流程标本流转----标本核收----标本上机检验----费用汇总----报告审核----报告发布----报告打印等基础流程
38 3
|
3月前
|
存储 开发框架 .NET
【C#】认识C# (为了游戏开发 O(≧口≦)O)
【1月更文挑战第26天】【C#】认识C# (为了游戏开发 O(≧口≦)O)
|
3月前
|
运维 数据挖掘 C#
C#大型LIS检验信息系统项目源码
LIS系统能实现临床检验信息化,检验科信息管理自动化。其主要功能是将检验科的实验仪器传出的检验数据经数据分析后,自动生成打印报告,通过网络存储在数据库中,使医生能够通过医生工作站方便、及时地看到患者的检验结果。
31 0
|
3月前
|
小程序 前端开发 C#
C#三甲医院在线预约挂号系统源码
医院在线预约挂号系统是一种方便患者预约挂号的系统,患者可以通过该系统进行预约挂号,省去了到医院现场排队等待的时间,提高了就诊效率。随着医院信息化水平的不断发展,医院在线预约挂号管理系统已成为医院管理中不可或缺的一部分。
56 1
|
3月前
|
小程序 前端开发 C#
C#微信公众号HIS预约挂号系统源码
微信公众号预约挂号系统、支付宝小程序预约挂号系统主要是让自费、医保患者在手机上就能实现就医全过程,实时预约挂号、自费、医保结算,同时还可以查询检查检验报告等就诊信息,真正实现了让信息“多跑路”,让群众“少跑腿”。系统与HIS对接,通过医院微信公众号,患者用身份证注册以后,可以预约看诊的时间、医生挂号缴费。预约成功后,会收到预约码或二维码,患者可以在预约的时间段,前往医院看诊。既可以节约患者的等待时间,又可以降低医院的负荷。 一、开发环境 ❀技术架构:net     ❀开发语言:C# ❀开发工具:VS2019     ❀前端框架:uni-app     ❀后端框架:net     ❀数 据
88 1