




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
生命游戏源代码*定义生命游戏参数*Dim gridSize As Integer 格网大小Dim gridNumberCol As Long 列格网数Dim gridNumberRow As Long 行格网数Dim gridMatrix() As Byte 格网矩阵Dim gridMTemp() As Byte 格网临时矩阵Dim intervalTime As Long 演化间隔时间Dim gridFillColor As Long 格网填充颜色Dim developTimes As Long 演化次数Dim liveNumbers As Long 存活个数*初始化生命游戏参数*Private Sub initLifeConfig() gridSize = txtGridSize.Text intervalTime = txtTime.Text gridNumberCol = Int(picLife.ScaleWidth / gridSize) + 1 gridNumberRow = Int(picLife.ScaleHeight / gridSize) + 1 txtCANumber.Text = CLng(gridNumberCol * gridNumberRow / 3) Label6.Caption = 不能超过 & gridNumberCol * gridNumberRow & 个 ReDim gridMatrix(0 To gridNumberCol - 1, 0 To gridNumberRow - 1) ReDim gridMTemp(0 To gridNumberCol - 1, 0 To gridNumberRow - 1) gridFillColor = vbGreen picLife.FillStyle = 0 picLife.FillColor = gridFillColor picLife.BackColor = vbWhite timerLife.Enabled = False timerLife.Interval = intervalTime developTimes = 0 liveNumbers = 0End Sub*输出某个元胞的状态*Private Sub printgridcolor(ByVal i As Long, ByVal j As Long, ByVal k As Long) If k = 1 Then picLife.Line (i * gridSize, j * gridSize)-(i + 1) * gridSize - 1, (j + 1) * gridSize - 1), gridFillColor, B ElseIf k = 0 Then picLife.FillColor = vbWhite picLife.Line (i * gridSize, j * gridSize)-(i + 1) * gridSize - 1, (j + 1) * gridSize - 1), vbWhite, B picLife.FillColor = gridFillColor End IfEnd Sub*输出元胞状态*Private Sub exportLifeStatus() picLife.Cls For i = 0 To gridNumberCol - 1 For j = 0 To gridNumberRow - 1 If gridMatrix(i, j) = 1 Then Call printgridcolor(i, j, 1) Next j Next iEnd Sub*元胞演化(需要完成的部分!)*Private Sub lifeDelevoping() Dim neighborLiveNumber As Byte 记录邻域存活的元胞数 Dim row As Integer, col As Integer 记录元胞所在的行和列 neighborLiveNumber = 0 初始化邻域存活的元胞数 需要用到的变量: gridNumberCol As Long 列格网数 gridNumberRow As Long 行格网数 gridMatrix() As Byte 格网矩阵,当前的CA格局,大小:gridNumberCol * gridNumberRow,下标从0开始 gridMTemp() As Byte 格网临时矩阵,下一回合的CA格局,大小:gridNumberCol * gridNumberRow,下标从0开始 以上两个二维数组的下标,先Col后Row 元胞状态说明:死亡的元胞为0,存活的元胞为1 -开始生命元胞的演化- For row = 0 To gridNumberRow - 1 For col = 0 To gridNumberCol - 1 -判断邻域存活的元胞数- Dim i As Integer, j As Integer Your code For i = row - 1 To row + 1 For j = col - 1 To col + 1 If (j = 0 And i = 0) And (j gridNumberCol And i 3 Or neighborLiveNumber 2 Then gridMTemp(col, row) = 0 Else gridMTemp(col, row) = 1 End If End If neighborLiveNumber = 0 Next col Next row -生命元胞演化结束- -返回元胞的状态,并显示在格网上- For i = 0 To gridNumberCol - 1 For j = 0 To gridNumberRow - 1 gridMatrix(i, j) = gridMTemp(i, j) Next j Next i Call exportLifeStatus -End Sub*初始化窗体外观*Private Sub initFormVisible() If frmLife.WindowState = 1 Then Exit Sub framConfig.Top = 0 framConfig.Left = 10 framConfig.Width = frmLife.ScaleWidth - 20 picLife.Top = framConfig.Top + framConfig.Height + 10 picLife.Left = framConfig.Left picLife.Width = framConfig.Width picLife.Height = frmLife.ScaleHeight - picLife.Top - 10 framConfig2.Left = (framConfig.Width - framConfig2.Width) / 2End Sub*Private Sub cmdBegin_Click() timerLife.Enabled = TrueEnd SubPrivate Sub cmdEnd_Click() timerLife.Enabled = False For i = 0 To gridNumberCol - 1 For j = 0 To gridNumberRow - 1 If gridMatrix(i, j) = 1 Then liveNumbers = liveNumbers + 1 End If Next j Next i lblLiveNumbers.Caption = liveNumbers liveNumbers = 0End SubPrivate Sub cmdExit_Click() EndEnd SubPrivate Sub cmdRandomCA_Click() -随机生成一定数目存活的元胞- Dim liveNumber As Long Dim liveNumberTotal As Long liveNumber = 0 liveNumberTotal = txtCANumber.Text timerLife.Enabled = False picLife.Cls For i = 0 To gridNumberCol - 1 For j = 0 To gridNumberRow - 1 gridMatrix(i, j) = 0 Next j Next i Do While liveNumber = liveNumberTotal i = Int(gridNumberCol * Rnd) j = Int(gridNumberRow * Rnd) If gridMatrix(i, j) = 0 Then liveNumber = liveNumber + 1 gridMatrix(i, j) = 1 Call printgridcolor(i, j, 1) End If Loop End SubPrivate Sub cmdReset_Click() developTimes = 0 Call initLifeConfigEnd SubPrivate Sub Form_Load() Call initFormVisible Call initLifeConfigEnd SubPrivate Sub Form_Resize() -resize时,重置窗体参数- Call initFormVisible Call initLifeConfigEnd SubPrivate Sub picLife_MouseDown(Button As Integer, Shift As Integer, X As Single, Y As Single) -鼠标按下给定元胞初始状态- i = Int(X / gridSize) j = Int(Y / gridSize) If gridMatrix(i, j) = 0 Then gridMatrix(i, j) = 1 Call printgridcolor(i, j, 1) Else gridMatrix(i, j) = 0 Call printgridcolor(i, j, 0) End IfEnd SubPrivate Sub timerLife_Timer() developTimes = developTimes + 1 lblTimes.Caption = t= & developTimes & 次 Call lifeDelevoping If developTimes = 1 Or developTimes = 10 Or developTimes = 20 Or developTimes = 50 Or developTimes = 100 Or developTimes = 200 Or developTimes = 500 Or developTimes = 1000 Then timerLife.Enabled = False For i = 0 To gridNumberCol - 1 For j = 0 To gridNumberRow - 1 If gridMatrix(i, j) = 1 Then liveNumbers = liveNumbers + 1 Next j Next i lbl
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 淀粉糖制造工基础考核试卷及答案
- 职业培训师技术考核试卷及答案
- 橡胶胶料抗热稳定性改善工艺考核试卷及答案
- 化肥干燥工艺考核试卷及答案
- 金属文物修复师基础知识考核试卷及答案
- 信息技术高中基础试题及答案
- 国内货运代理公司合伙协议书
- 银行职能岗面试题及答案
- 银行压力面试题库及答案
- 贵州专业素养试题及答案
- 智能计算系统:从深度学习到大模型 第2版课件 6、第六章-面向深度学习的处理器原理
- 2024年小学教师继续教育工作计划范例(3篇)
- (2024)河南省公务员考试《行测》真题及答案解析
- 自动化模具制造行业可行性分析报告
- 房颤心电图课件
- 工地拌和站试验室培训课件建筑土木工程
- 2024年卫生院“健康促进医院”创建工作总结样本(3篇)
- 副总经理招聘面试题与参考回答(某大型集团公司)2025年
- 餐饮4D管理培训资料
- 峥嵘岁月 课件-2024-2025学年高中音乐人音版(2019) 必修 音乐鉴赏
- 《用户体验设计导论》
评论
0/150
提交评论