魔塔之拯救白娘子 完整工程下载地址: 《魔塔之拯救白娘子》~11地图编辑器-地图编辑界面鼠标点击判断:
鼠标点击判断:
①点击的对象是卡通图片切换:完成对3种类型的卡通切换并显示
②点击的对象是某个卡通图片:获得该开通的编号,显示相应的信息,比如怪物属性
③点击的是地图界面:根据②的在地图界面绘制②的卡通并显示
④其他选择,比如退出编辑,清空地图等等。
Sub 地图编辑界面鼠标点击判断()
If Running <> 8 Then Exit Sub
If Xi.MouseKey(xgL_BUTTON) Then
鼠标X坐标 = Xi.MouseX
鼠标Y坐标 = Xi.MouseY
If 鼠标X坐标 = 497 Or 鼠标X坐标 > 497 And 鼠标X坐标 < 573 Then
If 鼠标Y坐标 = 44 Or 鼠标Y坐标 > 44 And 鼠标Y坐标 < 67 Then
地图编辑器界面按钮按下标志1 = True
地图编辑器界面按钮按下标志2 = False
地图编辑器界面按钮按下标志3 = False
地图编辑器界面_选择图形编号 = 1
End If
End If
If 鼠标X坐标 = 582 Or 鼠标X坐标 > 582 And 鼠标X坐标 < 656 Then
If 鼠标Y坐标 = 44 Or 鼠标Y坐标 > 44 And 鼠标Y坐标 < 67 Then
地图编辑器界面按钮按下标志1 = False
地图编辑器界面按钮按下标志2 = True
地图编辑器界面按钮按下标志3 = False
地图编辑器界面_选择图形编号 = 1
End If
End If
If 鼠标X坐标 = 666 Or 鼠标X坐标 > 666 And 鼠标X坐标 < 742 Then
If 鼠标Y坐标 = 44 Or 鼠标Y坐标 > 44 And 鼠标Y坐标 < 67 Then
地图编辑器界面按钮按下标志1 = False
地图编辑器界面按钮按下标志2 = False
地图编辑器界面按钮按下标志3 = True
地图编辑器界面_选择图形编号 = 1
End If
End If
'以上判断是否按下编辑器界面的3个选项按钮
'以下判断是否按下清空地图,保存地图和载入地图
If 鼠标X坐标 = 174 Or 鼠标X坐标 > 174 And 鼠标X坐标 < 252 Then
If 鼠标Y坐标 = 455 Or 鼠标Y坐标 > 455 And 鼠标Y坐标 < 478 Then
地图编辑器界面按钮按下标志_保存地图 = True
End If
End If
If 鼠标X坐标 = 318 Or 鼠标X坐标 > 318 And 鼠标X坐标 < 395 Then
If 鼠标Y坐标 = 455 Or 鼠标Y坐标 > 455 And 鼠标Y坐标 < 478 Then
地图编辑器界面按钮按下标志_清空地图 = True
End If
End If
If 鼠标X坐标 = 34 Or 鼠标X坐标 > 34 And 鼠标X坐标 < 115 Then
If 鼠标Y坐标 = 455 Or 鼠标Y坐标 > 455 And 鼠标Y坐标 < 480 Then
If 地图编辑器界面按钮按下标志_载入地图 = False Then
地图编辑器界面按钮按下标志_载入地图 = True
Else
地图编辑器界面按钮按下标志_载入地图 = False
'
End If
End If
End If
'退出地图编辑器,返回游戏第一页
If 鼠标X坐标 = 543 Or 鼠标X坐标 > 543 And 鼠标X坐标 < 613 Then
If 鼠标Y坐标 = 462 Or 鼠标Y坐标 > 462 And 鼠标Y坐标 < 484 Then
If MsgBox("你是否放弃地图编辑,返回主菜单?如果没有保存地图,请点否!", vbQuestion Or vbYesNo, Me.Caption) = vbYes Then
Running = 9: 读档标志 = False: 判断running状态_初始化: BackPic.LoadGraph "image\魔塔背景\魔塔背景1.jpg", xgBLACK
End If
End If
End If
'以下判断是否选择了某个土块
'检测第1行1-9
Dim 地图编辑器界面_鼠标选择范围X坐标 As Single
Dim 地图编辑器界面_鼠标选择范围y坐标 As Single
Dim j As Integer
地图编辑器界面_鼠标选择范围X坐标 = 474
地图编辑器界面_鼠标选择范围y坐标 = 102
For j = 0 To 8
If 鼠标X坐标 = 地图编辑器界面_鼠标选择范围X坐标 + j * 32 Or 鼠标X坐标 > 地图编辑器界面_鼠标选择范围X坐标 + j * 32 And 鼠标X坐标 < 地图编辑器界面_鼠标选择范围X坐标 + j * 32 + 26 Then
If 鼠标Y坐标 = 地图编辑器界面_鼠标选择范围y坐标 Or 鼠标Y坐标 > 地图编辑器界面_鼠标选择范围y坐标 And 鼠标Y坐标 < 地图编辑器界面_鼠标选择范围y坐标 + 32 Then
地图编辑器界面_选择图形编号 = j + 1
End If
End If
Next
'检测第2行10-19
地图编辑器界面_鼠标选择范围X坐标 = 474
地图编辑器界面_鼠标选择范围y坐标 = 146
'
For j = 0 To 8
If 鼠标X坐标 = 地图编辑器界面_鼠标选择范围X坐标 + j * 32 Or 鼠标X坐标 > 地图编辑器界面_鼠标选择范围X坐标 + j * 32 And 鼠标X坐标 < 地图编辑器界面_鼠标选择范围X坐标 + j * 32 + 26 Then
If 鼠标Y坐标 = 地图编辑器界面_鼠标选择范围y坐标 Or 鼠标Y坐标 > 地图编辑器界面_鼠标选择范围y坐标 And 鼠标Y坐标 < 地图编辑器界面_鼠标选择范围y坐标 + 32 Then
地图编辑器界面_选择图形编号 = j + 1 + 9
End If
End If
Next
'检测第3行20-29
地图编辑器界面_鼠标选择范围X坐标 = 474
地图编辑器界面_鼠标选择范围y坐标 = 185
'
For j = 0 To 8
If 鼠标X坐标 = 地图编辑器界面_鼠标选择范围X坐标 + j * 32 Or 鼠标X坐标 > 地图编辑器界面_鼠标选择范围X坐标 + j * 32 And 鼠标X坐标 < 地图编辑器界面_鼠标选择范围X坐标 + j * 32 + 26 Then
If 鼠标Y坐标 = 地图编辑器界面_鼠标选择范围y坐标 Or 鼠标Y坐标 > 地图编辑器界面_鼠标选择范围y坐标 And 鼠标Y坐标 < 地图编辑器界面_鼠标选择范围y坐标 + 32 Then
地图编辑器界面_选择图形编号 = j + 1 + 18
If 地图编辑器界面按钮按下标志1 = True And 地图编辑器界面_选择图形编号 > 25 Then 地图编辑器界面_选择图形编号 = 25: Exit For
End If
End If
Next
'检测第4行30-39
地图编辑器界面_鼠标选择范围X坐标 = 474
地图编辑器界面_鼠标选择范围y坐标 = 225
'
For j = 0 To 6
If 鼠标X坐标 = 地图编辑器界面_鼠标选择范围X坐标 + j * 32 Or 鼠标X坐标 > 地图编辑器界面_鼠标选择范围X坐标 + j * 32 And 鼠标X坐标 < 地图编辑器界面_鼠标选择范围X坐标 + j * 32 + 26 Then
If 鼠标Y坐标 = 地图编辑器界面_鼠标选择范围y坐标 Or 鼠标Y坐标 > 地图编辑器界面_鼠标选择范围y坐标 And 鼠标Y坐标 < 地图编辑器界面_鼠标选择范围y坐标 + 32 Then
地图编辑器界面_选择图形编号 = j + 1 + 27
If 地图编辑器界面按钮按下标志2 = True And 地图编辑器界面_选择图形编号 > 28 Then 地图编辑器界面_选择图形编号 = 28: Exit For
End If
End If
Next
''检测第5行40-49
'地图编辑器界面_鼠标选择范围X坐标 = 474
' 地图编辑器界面_鼠标选择范围y坐标 = 225
''
' For j = 0 To 6
'
' If 鼠标X坐标 = 地图编辑器界面_鼠标选择范围X坐标 + j * 32 Or 鼠标X坐标 > 地图编辑器界面_鼠标选择范围X坐标 + j * 32 And 鼠标X坐标 < 地图编辑器界面_鼠标选择范围X坐标 + j * 32 + 26 Then
'
' If 鼠标Y坐标 = 地图编辑器界面_鼠标选择范围y坐标 Or 鼠标Y坐标 > 地图编辑器界面_鼠标选择范围y坐标 And 鼠标Y坐标 < 地图编辑器界面_鼠标选择范围y坐标 + 32 Then
'
' 地图编辑器界面_选择图形编号 = j + 1 + 27
'
'
'End If
'End If
'
' Next
'以上判断是否选择绘图图形快
'以下判断选择了图形快以后进行绘图工作
' 当前K=1当前J=0当前图片编号:0图片 X坐标:0图片Y坐标:32
'当前K=1当前J=1当前图片编号:1图片 X坐标:32图片Y坐标:32
'当前K=1当前J=2当前图片编号:1图片 X坐标:64图片Y坐标:32
'当前K=1当前J=3当前图片编号:1图片 X坐标:96图片Y坐标:32
'当前K=1当前J=4当前图片编号:1图片 X坐标:128图片Y坐标:32
'当前K=1当前J=5当前图片编号:1图片 X坐标:160图片Y坐标:32
'当前K=1当前J=6当前图片编号:1图片 X坐标:192图片Y坐标:32
'当前K=1当前J=7当前图片编号:1图片 X坐标:224图片Y坐标:32
'当前K=1当前J=8当前图片编号:1图片 X坐标:256图片Y坐标:32
'当前K=1当前J=9当前图片编号:1图片 X坐标:288图片Y坐标:32
'当前K=1当前J=10当前图片编号:1图片 X坐标:320图片Y坐标:32
'当前K=1当前J=11当前图片编号:1图片 X坐标:352图片Y坐标:32
'当前K=1当前J=12当前图片编号:0图片 X坐标:384图片Y坐标:32
''1-29为基本道具;'30-79为道具 ;'80-99为怪物
Dim tempX As Integer '地图X边界判断
'Dim tempY As Integer '地图y边界判断
Dim m() As String
Dim k As Integer
For k = 1 To 11
'判断第一行
地图编辑器界面_鼠标选择范围X坐标 = 32
地图编辑器界面_鼠标选择范围y坐标 = 32 * k
For j = 0 To 10
If 鼠标X坐标 = 地图编辑器界面_鼠标选择范围X坐标 + j * 32 Or 鼠标X坐标 > 地图编辑器界面_鼠标选择范围X坐标 + j * 32 And 鼠标X坐标 < 地图编辑器界面_鼠标选择范围X坐标 + j * 32 + 32 Then
If 鼠标Y坐标 = 地图编辑器界面_鼠标选择范围y坐标 Or 鼠标Y坐标 > 地图编辑器界面_鼠标选择范围y坐标 And 鼠标Y坐标 < 地图编辑器界面_鼠标选择范围y坐标 + 32 Then
'地图编辑器界面_选择图形编号 = j + 1 + 27
' 地图编辑器界面_图形说明
'地图数据(1) = "0,1,1,1,1,1,1,1,1,1,1,1,0"
m = Split(地图数据(k), ",")
tempX = 鼠标X坐标 / 32
If tempX > 11 Then tempX = 11
m(tempX) = 地图编辑器界面_选择图形编号
If 地图编辑器界面按钮按下标志2 = True Then
m(tempX) = m(tempX) + 29
' 地图编辑器界面_选择图形编号 = 地图编辑器界面_选择图形编号 + 29
End If
If 地图编辑器界面按钮按下标志3 = True Then
m(tempX) = m(tempX) + 79
' 地图编辑器界面_选择图形编号 = 地图编辑器界面_选择图形编号 + 79
End If
地图数据(k) = m(0) & "," & m(1) & "," & m(2) & "," & m(3) & "," & m(4) & "," & m(5) & "," & m(6) & "," & m(7) & "," & m(8) & "," & m(9) & "," & m(10) & "," & m(11) & "," & m(12)
写临时地图数据 (0)
地图编辑器界面_临时地图标志 = True
End If
End If
Next j
Next k
'以下处理载入地图操作
Dim 偏移量X As Integer '地图X边界判断
Dim 偏移量Y As Integer '地图y边界判断
'判断第一行32-43,503-511
' 地图编辑器界面_鼠标选择范围X坐标 = 32
' 地图编辑器界面_鼠标选择范围y坐标 = 503
For j = 1 To 地图最大层号
If j < 30 Then
偏移量X = 10 + 20 * j: 偏移量Y = 503
Else
偏移量X = 10 + 20 * (j - 29): 偏移量Y = 530
End If
If 鼠标X坐标 = 偏移量X Or 鼠标X坐标 > 偏移量X And 鼠标X坐标 < 偏移量X + 15 Then
If 鼠标Y坐标 = 偏移量Y Or 鼠标Y坐标 > 偏移量Y And 鼠标Y坐标 < 偏移量Y + 15 Then
'处理点击加载地图事件
当前正在编辑的地图编号 = j: 地图编辑器界面_修正地图 = True
If 地图编辑器界面_修正地图 = True And 当前正在编辑的地图编号 > 0 And 地图编辑器界面按钮按下标志_载入地图 = True Then
读取地图数据 (当前正在编辑的地图编号)
写临时地图数据 (0)
End If
Exit For
End If
End If
Next j
'Next k
End If
End Sub
本段代码虽然长,但结构非常清晰,当然写 也很随意,但还是很好懂的,在此不多说。