Commit 60ef966ec3cd1462a62743e952baf57a602a11ff
Merge branch 'cn/develop' into cn/publish/zhaolu
# Conflicts: # src/actions/GmAction.lua # src/actions/HangAction.lua # src/models/Daily.lua
Showing
5 changed files
with
80 additions
and
36 deletions
Show diff stats
src/GlobalVar.lua
src/actions/HangAction.lua
| ... | ... | @@ -1200,19 +1200,20 @@ end |
| 1200 | 1200 | function _M.takeTreasureRpc(agent, data) |
| 1201 | 1201 | local role = agent.role |
| 1202 | 1202 | local extraCount = role.dailyData:getProperty("treasureExtraCount") --每日发现额外宝藏使用次数(累计),隔天清零 |
| 1203 | - local mapCount = role.dailyData:getProperty("treasureMapCount") | |
| 1204 | 1203 | local baseExtra = role.dailyData:getProperty("treasureBaseExtra") |
| 1205 | 1204 | |
| 1206 | 1205 | if extraCount >= globalCsv.idle_treasure_extra_limie then return 1 end |
| 1207 | - if mapCount <= 0 then return 2 end | |
| 1208 | 1206 | |
| 1209 | - baseExtra = baseExtra + globalCsv.idle_treasure_base_extra | |
| 1207 | + local cost ={[ItemId.TreasureMap] = 1} | |
| 1208 | + if not role:checkItemEnough(cost) then return 2 end | |
| 1210 | 1209 | |
| 1210 | + baseExtra = baseExtra + globalCsv.idle_treasure_base_extra | |
| 1211 | 1211 | local tmpTreasure, treasureListExtra = role.dailyData:getTreasureExtra(baseExtra) |
| 1212 | 1212 | if not tmpTreasure then return 3 end |
| 1213 | 1213 | |
| 1214 | + if not role:costItems(cost, {log = {desc = "TreasureMap", int1 = ItemId.TreasureMap, int2 = 1}}) then return 4 end | |
| 1215 | + | |
| 1214 | 1216 | role.dailyData:updateProperty({field = "treasureExtraCount", delta = 1}) |
| 1215 | - role.dailyData:updateProperty({field = "treasureMapCount", value = mapCount - 1}) | |
| 1216 | 1217 | role.dailyData:updateProperty({field = "treasureBaseExtra", value = baseExtra}) |
| 1217 | 1218 | |
| 1218 | 1219 | SendPacket(actionCodes.Hang_takeTreasureRpc, MsgPack.pack({treasureListExtra = treasureListExtra, treasure = tmpTreasure})) |
| ... | ... | @@ -1226,10 +1227,9 @@ function _M.treasureMapRpc(agent,data) |
| 1226 | 1227 | local cost ={[ItemId.Jade] = globalCsv.idle_treasure_buy * count} |
| 1227 | 1228 | if not role:checkItemEnough(cost) then return 1 end |
| 1228 | 1229 | if not role:costItems(cost, {log = {desc = "treasureMap", int1 = count}}) then return 2 end |
| 1229 | - role.dailyData:updateProperty({field = "treasureMapCount", delta = count}) | |
| 1230 | 1230 | |
| 1231 | - local treasureMapCount = role.dailyData:getProperty("treasureMapCount") | |
| 1232 | - SendPacket(actionCodes.Hang_treasureMapRpc, MsgPack.pack({mapCount = treasureMapCount})) | |
| 1231 | + local reward, change = role:award({[ItemId.TreasureMap] = count}, {log = {desc = "TreasureMap", int1 = ItemId.TreasureMap, int2 = count}}) | |
| 1232 | + SendPacket(actionCodes.Hang_treasureMapRpc, MsgPack.pack(role:packReward(reward, change))) | |
| 1233 | 1233 | return true |
| 1234 | 1234 | end |
| 1235 | 1235 | ... | ... |
src/models/Daily.lua
| ... | ... | @@ -38,7 +38,6 @@ Daily.schema = { |
| 38 | 38 | treasureList = {"table", {}}, --挂机图鉴 |
| 39 | 39 | |
| 40 | 40 | treasureListExtra = {"table", {}}, --额外宝藏,挂机图鉴扩展功能 |
| 41 | - treasureMapCount = {"number", 0}, --宝藏图,消耗一张宝藏图可以发现一次额外宝藏 | |
| 42 | 41 | treasureExtraCount = {"number", 0}, --每日发现额外宝藏使用次数(累计),隔天清零 |
| 43 | 42 | treasureBaseExtra = {"number", 0}, --额外宝藏资源值 |
| 44 | 43 | |
| ... | ... | @@ -131,7 +130,6 @@ function Daily:data() |
| 131 | 130 | treasureBase = self:getProperty("treasureBase"), |
| 132 | 131 | treasureList = self:getProperty("treasureList"), |
| 133 | 132 | treasureListExtra = self:getProperty("treasureListExtra"), |
| 134 | - treasureMapCount = self:getProperty("treasureMapCount"), | |
| 135 | 133 | treasureExtraCount = self:getProperty("treasureExtraCount"), |
| 136 | 134 | treasureBaseExtra = self:getProperty("treasureBaseExtra"), |
| 137 | 135 | chatTimes = self:getProperty("chatTimes"), | ... | ... |
src/models/DailyPlugin.lua
| ... | ... | @@ -20,26 +20,31 @@ function DailyPlugin.bind(Daily) |
| 20 | 20 | end |
| 21 | 21 | |
| 22 | 22 | --CD |
| 23 | - function Daily:checkTreasureExpired(treasureAttr, treasureList) | |
| 23 | + function Daily:checkTreasureExpired(treasureAttr, treasureList, isExtra) | |
| 24 | 24 | local curInfo = treasureList[treasureAttr.id] |
| 25 | + local now = skynet.timex() | |
| 25 | 26 | if curInfo then |
| 26 | 27 | -- check finish |
| 27 | 28 | if curInfo["expire_time"] then |
| 28 | 29 | if curInfo.cool_time > 1 then |
| 29 | - if skynet.timex() >= curInfo["expire_time"] then | |
| 30 | + if now >= curInfo["expire_time"] then | |
| 30 | 31 | treasureList[treasureAttr.id] = nil |
| 31 | 32 | curInfo = clone(treasureAttr) |
| 32 | - elseif skynet.timex() >= curInfo["expire_time"] - curInfo.cool_time * oneDay then --未冷却 | |
| 33 | + elseif now >= curInfo["expire_time"] - curInfo.cool_time * oneDay then --未冷却 | |
| 33 | 34 | curInfo = nil |
| 34 | 35 | else |
| 35 | 36 | curInfo = clone(treasureAttr) |
| 36 | 37 | end |
| 37 | 38 | else |
| 38 | - if skynet.timex() >= curInfo["expire_time"] then | |
| 39 | + if now >= curInfo["expire_time"] then | |
| 39 | 40 | treasureList[treasureAttr.id] = nil |
| 40 | 41 | end |
| 41 | 42 | curInfo = clone(treasureAttr) |
| 42 | 43 | end |
| 44 | + else | |
| 45 | + if isExtra then | |
| 46 | + curInfo = nil | |
| 47 | + end | |
| 43 | 48 | end |
| 44 | 49 | else |
| 45 | 50 | curInfo = clone(treasureAttr) |
| ... | ... | @@ -48,19 +53,23 @@ function DailyPlugin.bind(Daily) |
| 48 | 53 | return curInfo |
| 49 | 54 | end |
| 50 | 55 | |
| 51 | - --绑定通关关卡 | |
| 56 | + --绑定通关关卡 每日宝藏 | |
| 52 | 57 | function Daily:checkChapters(treasureList, treasureListOther) |
| 53 | 58 | local chapters = {} |
| 54 | 59 | local tmp_chapters = {} |
| 55 | 60 | |
| 61 | + --不可以绑定的关卡 | |
| 62 | + --1. 正在挖宝,未挖到 | |
| 63 | + --2. 已经挖到宝藏,但未领取 | |
| 64 | + --3. 正在挂机 | |
| 56 | 65 | for _, curInfo in pairs(treasureList or {}) do |
| 57 | - if curInfo["expire_time"] or not curInfo["end_time"] then | |
| 66 | + if (not curInfo["expire_time"] and curInfo["end_time"]) then | |
| 58 | 67 | tmp_chapters[curInfo.chapter_id] = curInfo |
| 59 | 68 | end |
| 60 | 69 | end |
| 61 | 70 | |
| 62 | 71 | for _, curInfo in pairs(treasureListOther or {}) do |
| 63 | - if curInfo["expire_time"] or not curInfo["end_time"] then | |
| 72 | + if (not curInfo["expire_time"] and curInfo["end_time"]) then | |
| 64 | 73 | tmp_chapters[curInfo.chapter_id] = curInfo |
| 65 | 74 | end |
| 66 | 75 | end |
| ... | ... | @@ -69,10 +78,42 @@ function DailyPlugin.bind(Daily) |
| 69 | 78 | for chapter_id, val in pairs(csvdb["idle_battleCsv"]) do |
| 70 | 79 | if chapter_id ~= hangInfo.carbonId then |
| 71 | 80 | if self.owner:checkHangPass(chapter_id) then |
| 72 | - if next(tmp_chapters) and not tmp_chapters[chapter_id] then | |
| 73 | - chapters[chapter_id] = val | |
| 74 | - else | |
| 75 | - chapters[chapter_id] = val | |
| 81 | + if not tmp_chapters[chapter_id] then | |
| 82 | + chapters[chapter_id] = {treasure_weight=val.treasure_weight} | |
| 83 | + end | |
| 84 | + end | |
| 85 | + end | |
| 86 | + | |
| 87 | + end | |
| 88 | + return chapters | |
| 89 | + end | |
| 90 | + | |
| 91 | + --绑定通关关卡 额外宝藏 | |
| 92 | + function Daily:checkChaptersExtra(treasureList, treasureListOther) | |
| 93 | + local chapters = {} | |
| 94 | + local tmp_chapters = {} | |
| 95 | + | |
| 96 | + --不可以绑定的关卡 | |
| 97 | + --1. 未过期(未挖,在挖,未领) | |
| 98 | + --2. 正在挂机 | |
| 99 | + for _, curInfo in pairs(treasureList or {}) do | |
| 100 | + if not curInfo["expire_time"] then | |
| 101 | + tmp_chapters[curInfo.chapter_id] = curInfo | |
| 102 | + end | |
| 103 | + end | |
| 104 | + | |
| 105 | + for _, curInfo in pairs(treasureListOther or {}) do | |
| 106 | + if not curInfo["expire_time"] then | |
| 107 | + tmp_chapters[curInfo.chapter_id] = curInfo | |
| 108 | + end | |
| 109 | + end | |
| 110 | + | |
| 111 | + local hangInfo = self.owner:getProperty("hangInfo") or {} | |
| 112 | + for chapter_id, val in pairs(csvdb["idle_battleCsv"]) do | |
| 113 | + if chapter_id ~= hangInfo.carbonId then | |
| 114 | + if self.owner:checkHangPass(chapter_id) then | |
| 115 | + if not tmp_chapters[chapter_id] then | |
| 116 | + chapters[chapter_id] = {treasure_weight=val.treasure_weight} | |
| 76 | 117 | end |
| 77 | 118 | end |
| 78 | 119 | end |
| ... | ... | @@ -130,7 +171,7 @@ function DailyPlugin.bind(Daily) |
| 130 | 171 | |
| 131 | 172 | --只抓一个 额外宝藏 |
| 132 | 173 | function Daily:getOneTreasureExtra(treasureList, tmpTreasure, treasureBase, treasureListOther) |
| 133 | - local chapters = self:checkChapters(treasureList, treasureListOther) | |
| 174 | + local chapters = self:checkChaptersExtra(treasureList, treasureListOther) | |
| 134 | 175 | if not chapters or not next(chapters) then return end |
| 135 | 176 | |
| 136 | 177 | --扣除在挖宝列表里未过期宝藏的资源值 |
| ... | ... | @@ -177,14 +218,15 @@ function DailyPlugin.bind(Daily) |
| 177 | 218 | function Daily:checkTreasureChapterId(curInfo, treasureList, chapterId, treasureBase) |
| 178 | 219 | if not curInfo then return nil end |
| 179 | 220 | |
| 221 | + local now = skynet.timex() | |
| 180 | 222 | local treasure = nil |
| 181 | 223 | --开始挖宝关卡ID=挂机关卡ID |
| 182 | 224 | if chapterId == curInfo.chapter_id then |
| 183 | 225 | --开始挖宝 |
| 184 | 226 | if not curInfo["end_time"] then |
| 185 | - curInfo["end_time"] = skynet.timex() + curInfo.working_time | |
| 227 | + curInfo["end_time"] = now + curInfo.working_time | |
| 186 | 228 | else |
| 187 | - if skynet.timex() >= curInfo["end_time"] then | |
| 229 | + if now >= curInfo["end_time"] then | |
| 188 | 230 | if curInfo.cool_time > 1 then |
| 189 | 231 | --宝藏冷却时间 |
| 190 | 232 | if not curInfo["expire_time"] then |
| ... | ... | @@ -192,11 +234,11 @@ function DailyPlugin.bind(Daily) |
| 192 | 234 | treasureBase = treasureBase - curInfo["treasure_value"] |
| 193 | 235 | |
| 194 | 236 | treasure = treasureList[curInfo.id] |
| 195 | - curInfo["expire_time"] = skynet.timex() + curInfo.cool_time * oneDay | |
| 237 | + curInfo["expire_time"] = now + curInfo.cool_time * oneDay | |
| 196 | 238 | end |
| 197 | 239 | else |
| 198 | 240 | --已经领取宝藏 检索宝藏冷却时间 |
| 199 | - if skynet.timex() >= curInfo["expire_time"] then | |
| 241 | + if now >= curInfo["expire_time"] then | |
| 200 | 242 | treasureList[curInfo.id] = nil |
| 201 | 243 | end |
| 202 | 244 | end |
| ... | ... | @@ -213,7 +255,7 @@ function DailyPlugin.bind(Daily) |
| 213 | 255 | else |
| 214 | 256 | --已经开始挖宝 |
| 215 | 257 | if curInfo["end_time"] then |
| 216 | - if skynet.timex() >= curInfo["end_time"] then | |
| 258 | + if now >= curInfo["end_time"] then | |
| 217 | 259 | if curInfo.cool_time > 1 then |
| 218 | 260 | --宝藏冷却时间 |
| 219 | 261 | if not curInfo["expire_time"] then |
| ... | ... | @@ -221,12 +263,12 @@ function DailyPlugin.bind(Daily) |
| 221 | 263 | treasureBase = treasureBase - curInfo["treasure_value"] |
| 222 | 264 | |
| 223 | 265 | treasure = treasureList[curInfo.id] |
| 224 | - curInfo["expire_time"] = skynet.timex() + curInfo.cool_time * oneDay | |
| 266 | + curInfo["expire_time"] = now + curInfo.cool_time * oneDay | |
| 225 | 267 | end |
| 226 | 268 | |
| 227 | 269 | else |
| 228 | 270 | --已经领取宝藏 检索宝藏冷却时间 |
| 229 | - if skynet.timex() >= curInfo["expire_time"] then | |
| 271 | + if now >= curInfo["expire_time"] then | |
| 230 | 272 | treasureList[curInfo.id] = nil |
| 231 | 273 | end |
| 232 | 274 | end |
| ... | ... | @@ -267,13 +309,14 @@ function DailyPlugin.bind(Daily) |
| 267 | 309 | |
| 268 | 310 | --宝藏图鉴 |
| 269 | 311 | function Daily:getTreasureList() |
| 270 | - local tmpcsv = csvdb["idle_treasureCsv"] | |
| 271 | 312 | local treasureList = self:getProperty("treasureList") or {} --挖宝列表 过期删除 领取奖励删除 跨天更新 |
| 272 | 313 | local treasureListExtra = self:getProperty("treasureListExtra") or {} --额外宝藏列表 过期删除 领取奖励删除 跨天更新 |
| 314 | + | |
| 315 | + --获取宝藏列表(与额外宝藏逻辑不同) 进行随机获取宝藏 | |
| 273 | 316 | local tmpTreasure = {} |
| 274 | 317 | local treasureBase = globalCsv.idle_treasure_base + self.owner:getBnousTreasureBaseMaximum() |
| 275 | - for _, val in pairs(tmpcsv) do | |
| 276 | - if self:checkUnlock(val) == true then | |
| 318 | + for _, val in pairs(csvdb["idle_treasureCsv"]) do | |
| 319 | + if self:checkUnlock(val) then | |
| 277 | 320 | local treasure = self:checkTreasureExpired(val, treasureList) |
| 278 | 321 | if treasure then |
| 279 | 322 | table.insert(tmpTreasure, treasure) |
| ... | ... | @@ -328,26 +371,26 @@ function DailyPlugin.bind(Daily) |
| 328 | 371 | --宝藏功能优化——增加"发现宝藏"功能 |
| 329 | 372 | function Daily:buyTreasureExtra(treasureList) |
| 330 | 373 | local boughtTreasure = {} |
| 331 | - local treasureBase = self:getProperty("treasureExtraBase") | |
| 374 | + local treasureBase = self:getProperty("treasureBaseExtra") | |
| 332 | 375 | for id, val in pairs(treasureList) do |
| 333 | 376 | if treasureBase >= val.treasure_value then |
| 334 | 377 | boughtTreasure[id] = val |
| 335 | 378 | treasureBase = treasureBase - val.treasure_value |
| 336 | 379 | end |
| 337 | 380 | end |
| 338 | - self:updateProperty({field = "treasureExtraBase", value = treasureBase}) | |
| 381 | + self:updateProperty({field = "treasureBaseExtra", value = treasureBase}) | |
| 339 | 382 | return boughtTreasure |
| 340 | 383 | end |
| 341 | 384 | |
| 342 | 385 | function Daily:getTreasureExtra(tmpBaseExtra) |
| 343 | - local tmpcsv = csvdb["idle_treasureCsv"] | |
| 344 | 386 | local treasureList = self:getProperty("treasureList") or {} --挖宝列表 过期删除 领取奖励删除 跨天更新 |
| 345 | 387 | local treasureListExtra = self:getProperty("treasureListExtra") or {} --额外宝藏 过期删除 领取奖励删除 跨天更新 |
| 346 | 388 | |
| 389 | + --获取宝藏列表(排除未过期的宝藏) 进行随机获取宝藏 | |
| 347 | 390 | local tmpTreasure = {} |
| 348 | - for _, val in pairs(tmpcsv) do | |
| 391 | + for _, val in pairs(csvdb["idle_treasureCsv"]) do | |
| 349 | 392 | if self:checkUnlock(val) then |
| 350 | - local treasure = self:checkTreasureExpired(val, treasureListExtra) | |
| 393 | + local treasure = self:checkTreasureExpired(val, treasureListExtra, true) | |
| 351 | 394 | if treasure then |
| 352 | 395 | table.insert(tmpTreasure, treasure) |
| 353 | 396 | end | ... | ... |