Silverlight游戏开发小技巧:扇形排列元素-创新互联

斗地主风靡了大江南北,在春晚都做免费性推广,×××平台几乎将其作为标配,但是牌类游戏总是一成不变的样子——横向排列,如果扇形排列应该更加符合真实,最近在WP7上玩了一个UNO游戏就是用扇形排列,感觉很不错,今天咱们照猫画虎,在Silverlight上实现一个扇形的手牌效果。

成都创新互联是专业的中山网站建设公司,中山接单;提供成都网站建设、网站设计,网页设计,网站设计,建网站,PHP网站建设等专业做网站服务;采用PHP框架,可快速的进行中山网站开发网页制作和功能扩展;专业做搜索引擎喜爱的网站,专业的做网站团队,希望更多企业前来合作!

Silverlight 游戏开发小技巧:扇形排列元素

可能看到这个预览图有的朋友就会笑了,这个可以使用RenderTransform实现,前面有讲过,只需要将RenderTransformOrigin的原点设置在牌外面就行,然后旋转,这样实现倒是可以,可是算起来实在麻烦,要考虑牌数和位置,今天不是炒冷饭,而是使用PathListBox来实现,PathListBox在Silverlight的标准SDK中是没有的,它是Blend的一个扩展控件,用来实现路径动画等效果。

现在先建立一张牌的控件,这次不用新建,首先在画布上画好,如下图:

Silverlight 游戏开发小技巧:扇形排列元素

选择绘制出来的元素,点击鼠标右键选择制作成用户控件的选项

Silverlight 游戏开发小技巧:扇形排列元素

输入一个名字:

Silverlight 游戏开发小技巧:扇形排列元素

这样就会制作好了一个自定义的控件,此做法可以省去定大小等麻烦,如下图:

Silverlight 游戏开发小技巧:扇形排列元素

现在我们添加一个用户自定义控件到MainPage看看效果,你需要在Asset(资产)中找到这个用户控件,如果没有则需要编译一下:Ctrl+Alt+B

Silverlight 游戏开发小技巧:扇形排列元素

现在绘制一个圆形,在工具中选择Ellipse

Silverlight 游戏开发小技巧:扇形排列元素

看好规定好的路径,绘制好位置之后,将这个圆形变成Path路径,然后在工具栏中选择Direct Selection,选择下面的两条线,这两条线是我们所不需要的,所以直接按Del按钮删除掉:

Silverlight 游戏开发小技巧:扇形排列元素

只剩下一个将要作为路径的Path

Silverlight 游戏开发小技巧:扇形排列元素

选定Path,点击鼠标右键选择制作成为Layout Path功能,这个其实是一个快捷方式,如果正常操作需要引用dll然后添加对应的控件,我这里以简单的方式完成:

Silverlight 游戏开发小技巧:扇形排列元素

PathListBox此时就会出现在布局中了,并且下面的Path也添加到PathListBox做路径的基础。

Silverlight 游戏开发小技巧:扇形排列元素

现在拖动Card控件到PathListBox中,你会发现牌已经到了最开始的点了:

Silverlight 游戏开发小技巧:扇形排列元素

下面选定PathListBox,把参数设置成如下:

Silverlight 游戏开发小技巧:扇形排列元素

现在复制几个Card出来看看效果吧,怎么样,很不错吧。

Silverlight 游戏开发小技巧:扇形排列元素

但是这个排列仍然觉得别扭,调整Path就可以达到你的目标,可是有更好的方法来解决,把参数调整成下面的参数:

Silverlight 游戏开发小技巧:扇形排列元素

就是说开始的点在30%,而结束的点在40%,你可以动态调整一下,看看效果,非常棒,弄成动画就更有意思了:)

最后把黑线去掉,这样看起来就更加自然了:

Silverlight 游戏开发小技巧:扇形排列元素

选择Path把Stroke的颜色画笔设置为没有。

好了现在已经完成,我为Card做了一个小动画看起来更加有趣,在这个小技巧的基础上,相信各位能扩展更多的玩法出来,今天就到此为止吧:)

本篇工程源代码下载地址如下:点击直接下载

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前标题:Silverlight游戏开发小技巧:扇形排列元素-创新互联
分享链接:http://hbruida.cn/article/ccopod.html