From 3c836e6756adbaff0d96965a0a040f1c537ee07d Mon Sep 17 00:00:00 2001 From: meixiongfeng <766881921@qq.com> Date: Thu, 27 Jul 2023 17:04:36 +0800 Subject: [PATCH 1/2] =?UTF-8?q?=E8=B0=83=E8=AF=95bug?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- modules/stonehenge/api_challenge.go | 6 +++--- modules/stonehenge/api_enterlevel.go | 1 + modules/stonehenge/modelStonehenge.go | 1 + 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/modules/stonehenge/api_challenge.go b/modules/stonehenge/api_challenge.go index d6923125a..b57e1a6c1 100644 --- a/modules/stonehenge/api_challenge.go +++ b/modules/stonehenge/api_challenge.go @@ -8,7 +8,7 @@ import ( ) //参数校验 -func (this *apiComp) ChallengeCheck(session comm.IUserSession, req *pb.StonehengeBattleReq) (errdata *pb.ErrorData) { +func (this *apiComp) BattleCheck(session comm.IUserSession, req *pb.StonehengeBattleReq) (errdata *pb.ErrorData) { if req.Eventid == 0 { errdata = &pb.ErrorData{ Code: pb.ErrorCode_ReqParameterError, @@ -19,7 +19,7 @@ func (this *apiComp) ChallengeCheck(session comm.IUserSession, req *pb.Stoneheng } ///挑战主线关卡 -func (this *apiComp) Challenge(session comm.IUserSession, req *pb.StonehengeBattleReq) (errdata *pb.ErrorData) { +func (this *apiComp) Battle(session comm.IUserSession, req *pb.StonehengeBattleReq) (errdata *pb.ErrorData) { var ( stone *pb.DBStonehenge conf *cfg.GameStoneEventData @@ -52,7 +52,7 @@ func (this *apiComp) Challenge(session comm.IUserSession, req *pb.StonehengeBatt } return } - if errdata = this.ChallengeCheck(session, req); errdata != nil { + if errdata = this.BattleCheck(session, req); errdata != nil { return // 参数校验失败直接返回 } // diff --git a/modules/stonehenge/api_enterlevel.go b/modules/stonehenge/api_enterlevel.go index 9850577a5..6876d0638 100644 --- a/modules/stonehenge/api_enterlevel.go +++ b/modules/stonehenge/api_enterlevel.go @@ -56,6 +56,7 @@ func (this *apiComp) EnterLevel(session comm.IUserSession, req *pb.StonehengeEnt } return } + stone.Hero = make(map[string]*pb.BattleRole) // 查库 for _, hid := range req.Hid { if hero, err := this.module.ModuleHero.GetHeroByObjID(session.GetUserId(), hid); err != nil { diff --git a/modules/stonehenge/modelStonehenge.go b/modules/stonehenge/modelStonehenge.go index 59c389adf..e2365770f 100644 --- a/modules/stonehenge/modelStonehenge.go +++ b/modules/stonehenge/modelStonehenge.go @@ -60,6 +60,7 @@ func (this *MStonehenge) GetStonehengeData(uid string) *pb.DBStonehenge { stone.Reward = make(map[int32]bool, 0) stone.Addweight = make(map[int32]int32, 0) stone.Etime = utils.WeekIntervalTime(0) + stone.Hero = make(map[string]*pb.BattleRole) this.Add(uid, stone) } From 6c99d9da7bdad4753d4538e671029d4b9c37bb65 Mon Sep 17 00:00:00 2001 From: meixiongfeng <766881921@qq.com> Date: Thu, 27 Jul 2023 17:15:24 +0800 Subject: [PATCH 2/2] =?UTF-8?q?=E6=88=98=E6=96=97=E4=BA=8B=E4=BB=B6?= =?UTF-8?q?=E6=A0=A1=E9=AA=8C=20=E6=A0=A1=E9=AA=8C=E4=BC=A0=E9=80=81?= =?UTF-8?q?=E9=97=A8=E5=BC=80=E5=90=AF=E5=90=8E=20=E8=A7=A6=E5=8F=91?= =?UTF-8?q?=E6=96=B0=E7=9A=84=E4=BA=8B=E4=BB=B6=E5=AF=BC=E8=87=B4=E4=BC=A0?= =?UTF-8?q?=E9=80=81=E9=97=A8=E5=8F=88=E5=85=B3=E9=97=AD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- modules/stonehenge/api_challengeover.go | 38 +++++++++++++++++-------- 1 file changed, 26 insertions(+), 12 deletions(-) diff --git a/modules/stonehenge/api_challengeover.go b/modules/stonehenge/api_challengeover.go index dfa32c494..13e1cf22c 100644 --- a/modules/stonehenge/api_challengeover.go +++ b/modules/stonehenge/api_challengeover.go @@ -22,20 +22,21 @@ func (this *apiComp) BattleOverCheck(session comm.IUserSession, req *pb.Stonehen // /挑战主线关卡 func (this *apiComp) BattleOver(session comm.IUserSession, req *pb.StonehengeBattleOverReq) (errdata *pb.ErrorData) { var ( - isWin bool - update map[string]interface{} - roomConf *cfg.GameStoneRoomData - eventConf *cfg.GameStoneEventData - stone *pb.DBStonehenge - newEvent int32 // 是否有新的事件 - err error + isWin bool + update map[string]interface{} + roomConf *cfg.GameStoneRoomData + eventConf *cfg.GameStoneEventData + newEventConf *cfg.GameStoneEventData //新的事件配置 + stone *pb.DBStonehenge + newEvent int32 // 是否有新的事件 + err error ) errdata, isWin = this.module.battle.CheckBattleReport(session, req.Report) if errdata != nil { return } - if !isWin { + if !isWin { // 战斗失败直接返回 return } update = make(map[string]interface{}) @@ -56,7 +57,6 @@ func (this *apiComp) BattleOver(session comm.IUserSession, req *pb.StonehengeBat } return } - update["stageID"] = stone.StageID if roomConf, err = this.module.configure.GetStoneRoomDataById(stone.Rooms.Roomid); err != nil { return } @@ -64,17 +64,31 @@ func (this *apiComp) BattleOver(session comm.IUserSession, req *pb.StonehengeBat if eventConf, err = this.module.configure.GetStoneEventDataById(req.Eventid); err != nil { return } + stone.Rooms.Eventid[req.Eventid] = true // 校验事件有后续事件 if eventConf.Probability >= comm.GetRandNum(0, 1000) { // 命中 newEvent = eventConf.PostEvent - stone.Rooms.Eventid[newEvent] = false // - stone.Rooms.Eventid[req.Eventid] = true // + stone.Rooms.Eventid[newEvent] = false // } - // 校验是否通关 for _, v := range roomConf.Condition { if v == eventConf.EventType { stone.Rooms.Complete = true + if newEventConf, err = this.module.configure.GetStoneEventDataById(req.Eventid); err != nil { + errdata = &pb.ErrorData{ + Code: pb.ErrorCode_ConfigNoFound, + Title: pb.ErrorCode_ConfigNoFound.ToString(), + Message: err.Error(), + } + return + } + for _, v := range roomConf.Condition { + if v == newEventConf.EventType { + stone.Rooms.Complete = false // 判断新的事件导致传送门关闭 + break + } + } + break } }