博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c#经典俄罗斯方块 vs2012开发
阅读量:5844 次
发布时间:2019-06-18

本文共 2568 字,大约阅读时间需要 8 分钟。

 

把网上两个开源的俄罗斯方块,整合到一起了,开发环境vs2012+.net 4.0,有问题、建议可以加群沟通哦

 

复古的 c#写的一个俄罗斯方块小游戏,友好的人机交互,具体功能如下:1.游戏分七个关卡,通关后还有通关加分。2.有卡通背景图。3.有背景音乐和音效。4.有得分排行榜。5.能手动更换游戏背景图和背景音乐6.能自定义游戏控制键。 贴出一段核心代码,如何消行的,本个俄罗斯方块的核心就是 对于 &|>>^4种位运算符的运用,也是我整合这两个俄罗斯方块 的亮点,欢迎大家提出改进意见
1    ///  2         /// 查找已被填满的行 3         ///  4         /// 
5 public List
FindFullLines() 6 { 7 8 //清空原暂存表 9 fullLines.Clear();10 keepLines.Clear();11 List
reDrawPosList = new List
();12 //从最底行开始检查是否有消除行13 for (int y = this.YBlocks - 1; y >= 0 && arrBitBlock[y] != bitEmpty; )14 {15 if (arrBitBlock[y] == bitFull)16 {17 for (int x = 0; x < xBlocks; x++) //消除该行的block18 ArrayBlock[x, y] = null;19 SquareBlock[] arr = null;20 //将该行之上的block下移,如果到顶则不执行21 for (int i = y; i - 1 >= 0; i--)22 {23 //记录最高的 图形24 arr = new SquareBlock[10];25 for (int x = 0; x < xBlocks; x++)26 {27 28 if ((arrBitBlock[i - 1] & (1 << x)) != 0) //如果上方有block29 30 {31 this.ArrayBlock[x, i] = this.ArrayBlock[x, i - 1] == null ? null : this.ArrayBlock[x, i - 1].Clone() as SquareBlock; 32 33 ArrayBlock[x, i - 1] = null;34 reDrawPosList.Add(new Position(x, i));35 36 //ArrayBlock[x, i] = ArrayBlock[x, i - 1].Clone() as SquareBlock;37 }38 }39 arrBitBlock[i] = arrBitBlock[i - 1];//转移监控位40 }41 42 destroyLines++;43 fullLines.Add(y - fullLines.Count());44 45 46 }47 else48 {49 keepLines.Add(y - fullLines.Count());50 y--;//当消除一行后指针不下移,当没有消除的时候指针才下移51 52 }53 MinY = y - fullLines.Count();54 }55 return fullLines;56 }

 

 

 

参考:  http://download.csdn.net/detail/free722/1883329

 

参考:http://www.cnblogs.com/tuyile006/archive/2007/05/16/748256.html

你可能感兴趣的文章
pycharm工具下代码下面显示波浪线的去处方法
查看>>
C#高级编程9 第17章 使用VS2013-C#特性
查看>>
对软件工程这门课的收获与总结
查看>>
磁盘与目录的容量(转)
查看>>
【SpringBoot】在IOC之外的类中使用IOC内部的Bean
查看>>
android--Activity有返回值的跳转
查看>>
Fiddle:使用断点:bpu,bpafter
查看>>
Codeforces VK Cup 2015 A.And Yet Another Bracket Sequence(后缀数组+平衡树+字符串)
查看>>
spring+springMvc+struts的SSH框架整合
查看>>
二叉树 - 已知前中,求后序遍历
查看>>
Linux 内核
查看>>
解决php连接mysql数据库中文乱码问题
查看>>
OO第二单元作业小结
查看>>
vue之安装配置
查看>>
angular之两种路由
查看>>
java反射机制续
查看>>
子矩阵
查看>>
面试体验:Facebook 篇(转)
查看>>
Data type confusion: what is an int(11)?
查看>>
[NOIP1999] 提高组 洛谷P1014 Cantor表
查看>>