EquipHechengLogic.lua 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. local Lang = require("common.Lang")
  2. local Msg = require("core.Msg")
  3. local ObjHuman = require("core.ObjHuman")
  4. local EquipExcel = require("excel.equip")
  5. local BagLogic = require("bag.BagLogic")
  6. local Grid = require("bag.Grid")
  7. local Broadcast = require("broadcast.Broadcast")
  8. local DailyTaskLogic = require("dailyTask.DailyTaskLogic")
  9. local ItemDefine = require("bag.ItemDefine")
  10. local Util = require("common.Util")
  11. local EquipLogic = require("equip.EquipLogic")
  12. local CommonDefine = require("common.CommonDefine")
  13. EQUIP_HECHENG_LOG_MAX = 30
  14. local EQUIP_HECHENG_QUALITY = 5
  15. --装备合成帮助查询
  16. function equipDetailQuery(human)
  17. local descConfig = EquipExcel.detail[1]
  18. if not descConfig then return end
  19. local msgRet = Msg.gc.GC_EQUIP_HECHENG_DETAIL_QUERY
  20. msgRet.desc = descConfig.desc
  21. Msg.send(msgRet, human.fd)
  22. end
  23. local function sendQuery(human, pos)
  24. local msgRet = Msg.gc.GC_EQUIP_HECHENG_QUERY
  25. msgRet.pos = pos
  26. local cnt = 0
  27. local count = 0
  28. msgRet.dot = {0,0,0,0}
  29. for key, value in ipairs(EquipExcel.hecheng)do
  30. if pos == value.pos then
  31. cnt = cnt + 1
  32. msgRet.list[cnt].id = key
  33. msgRet.list[cnt].itemData[0] = 2
  34. Grid.makeItem(msgRet.list[cnt].itemData[1], value.hechengID, 1, nil, nil, nil, nil, 5)
  35. Grid.makeItem(msgRet.list[cnt].itemData[2], value.needID, 1, nil, nil, nil, nil, 5)
  36. msgRet.list[cnt].cnt = value.cnt
  37. Grid.makeItem(msgRet.list[cnt].need[1], value.money[1][1], value.money[1][2])
  38. msgRet.list[cnt].need[0] = 1
  39. end
  40. local nowEquipCnt = BagLogic.getItemCnt(human, value.needID)
  41. if nowEquipCnt >= value.cnt then
  42. msgRet.dot[value.pos] = 1
  43. end
  44. end
  45. msgRet.list[0] = cnt
  46. msgRet.dot[0] = 4
  47. Msg.send(msgRet, human.fd)
  48. end
  49. -- 装备合成信息查询
  50. function equipHechengQuery(human, pos)
  51. if pos == 0 then
  52. for i = ItemDefine.EQUIP_SUBTYPE_WEAPON, ItemDefine.EQUIP_SUBTYPE_SHIPIN do
  53. sendQuery(human, i)
  54. end
  55. else
  56. sendQuery(human, pos)
  57. end
  58. end
  59. -- 合成装备
  60. function equipHechengDo(human, id, indexList)
  61. print(" equipHechengDo ", id )
  62. Util.printTable(indexList)
  63. local config = EquipExcel.hecheng[id]
  64. if not config then
  65. Broadcast.sendErr(human, Util.format(Lang.SKIN_CONF_ERR))
  66. return
  67. end
  68. if config.cnt ~= #indexList then
  69. Broadcast.sendErr(human, Util.format(Lang.EQUIP_HECHENG_ERR_NOITEM,ItemDefine.getValue(config.needID,"name")))
  70. return
  71. end
  72. -- 检查 装备下标是否正确
  73. local isExist = {}
  74. local nLen = indexList[0]
  75. for i = 1, nLen, 1 do
  76. local idx = indexList[i]
  77. if isExist[idx] then
  78. Broadcast.sendErr(human, Util.format(Lang.DRILL_CHOOSE_MY_ERR_INDEX))
  79. return
  80. end
  81. isExist[idx] = true
  82. end
  83. for _, index in ipairs(indexList) do
  84. local grid = human.db.equipBag[index]
  85. if not grid or grid.id ~= config.needID then
  86. return Broadcast.sendErr(human, Util.format(Lang.EQUIP_HECHENG_ERR_NOITEM,ItemDefine.getValue(config.needID,"name")))
  87. end
  88. if grid.quality ~= EQUIP_HECHENG_QUALITY then
  89. return Broadcast.sendErr(human, Util.format(Lang.EQUIP_HECHENG_QUALITY_ERROR, EQUIP_HECHENG_QUALITY))
  90. end
  91. end
  92. -- 判断消耗
  93. for _, v in ipairs(config.money) do
  94. if BagLogic.getItemCnt(human, v[1]) < v[2] then
  95. return
  96. end
  97. end
  98. for _, v in ipairs(config.money) do
  99. BagLogic.delItem(human, v[1], v[2], "equip_hecheng")
  100. end
  101. local equipGrid = Util.copyTable(human.db.equipBag[indexList[1]])
  102. -- 删除道具
  103. for k, index in ipairs(indexList) do
  104. EquipLogic.delEquip(human, index, "equip_hecheng")
  105. end
  106. equipGrid.id = config.hechengID
  107. EquipLogic.getNewAttrByItemID(config.hechengID, equipGrid.attr)
  108. EquipLogic.addByEquipGrid(human, equipGrid, "equip_hecheng")
  109. -- 通知客户端
  110. local msgRet = Msg.gc.GC_EQUIP_HECHENG_DO
  111. BagLogic.BagLogic_GetAllSendInfo(human, msgRet.item, nil, CommonDefine.COMMON_SEND_PRIZE_TYPE_ONLYEQUIP)
  112. --Grid.makeItem(msgRet.item, equipGrid.id, 1, nil, equipGrid, index, Grid.getOpflagAtBag(equipGrid.id))
  113. Msg.send(msgRet, human.fd)
  114. local equipTb = {}
  115. equipTb[config.hechengID] = 1
  116. equipHechengLog(human,equipTb, config.money)
  117. end
  118. function equipHechengLog(human,equip,cost)
  119. local now = os.time()
  120. local logTb = {}
  121. logTb.equip = equip
  122. logTb.cost = cost
  123. logTb.time = now
  124. human.db.equipLogs = human.db.equipLogs or {}
  125. table.insert(human.db.equipLogs,1,logTb)
  126. human.db.equipLogs[EQUIP_HECHENG_LOG_MAX + 1] = nil
  127. end
  128. function equipLogsQuery(human)
  129. local msgRet = Msg.gc.GC_EUQIP_HECHENG_LOG_QUERY
  130. if human.db.equipLogs == nil or #human.db.equipLogs == 0 then
  131. msgRet.equipLogs[0] = 0
  132. Msg.send(msgRet,human.fd)
  133. return
  134. end
  135. local len = #human.db.equipLogs
  136. for i = 1,len do
  137. local v = human.db.equipLogs[i]
  138. local count = 0
  139. for equipID,equipCnt in pairs(v.equip) do
  140. Grid.makeItem(msgRet.equipLogs[i].equip,equipID,equipCnt, nil, nil, nil, nil, 5)
  141. end
  142. Grid.makeItem(msgRet.equipLogs[i].cost[1], v.cost[1],v.cost[2])
  143. msgRet.equipLogs[i].cost[0] = 1
  144. msgRet.equipLogs[i].time = v.time
  145. if i >= 30 then
  146. break
  147. end
  148. end
  149. msgRet.equipLogs[0] = len
  150. Msg.send(msgRet,human.fd)
  151. end