This commit is contained in:
wh_zcy 2023-06-07 19:58:35 +08:00
commit 4c82ab7028
7 changed files with 761 additions and 709 deletions

File diff suppressed because it is too large Load Diff

View File

@ -19469,8 +19469,8 @@
"Type": 2, "Type": 2,
"Argu": [ "Argu": [
424009012, 424009012,
1, -1,
1 -1
], ],
"FollowSK": [], "FollowSK": [],
"SucFollowSK": [], "SucFollowSK": [],
@ -19536,12 +19536,12 @@
"Where": [], "Where": [],
"Order": "", "Order": "",
"Limit": 10, "Limit": 10,
"ExecuteCnt": 3, "ExecuteCnt": 6,
"Type": 1, "Type": 1,
"Argu": [ "Argu": [
1, 1,
4, 4,
1350 1000
], ],
"FollowSK": [], "FollowSK": [],
"SucFollowSK": [], "SucFollowSK": [],

View File

@ -11968,8 +11968,8 @@
"ChildSkill": { "ChildSkill": {
"Id": [ "Id": [
224009311, 224009311,
224009313, 224009312,
224009312 224009313
] ]
}, },
"Desc": { "Desc": {

View File

@ -191,7 +191,7 @@ func (this *apiComp) Upgrade(session comm.IUserSession, req *pb.EquipmentUpgrade
errdata = &pb.ErrorData{ errdata = &pb.ErrorData{
Code: pb.ErrorCode_EquipmentOnFoundEquipment, Code: pb.ErrorCode_EquipmentOnFoundEquipment,
Title: pb.ErrorCode_EquipmentOnFoundEquipment.ToString(), Title: pb.ErrorCode_EquipmentOnFoundEquipment.ToString(),
Message: fmt.Sprintf("未找到装备 uid:%s id:%d", session.GetUserId(), v), Message: fmt.Sprintf("未找到装备 uid:%s id:%s", session.GetUserId(), v),
} }
return return
} }

View File

@ -413,6 +413,9 @@ func (this *modelEquipmentComp) upgradeEquipment(equipment *pb.DB_Equipment, equ
} }
if equip.EquipId == 1 { if equip.EquipId == 1 {
if len(equipment.AdverbEntry) <= 0 {
return
}
var attrlibrary *cfg.GameEquipAttrlibrarySData var attrlibrary *cfg.GameEquipAttrlibrarySData
r := rand.New(rand.NewSource(configure.Now().Unix())) r := rand.New(rand.NewSource(configure.Now().Unix()))
index := r.Perm(len(equipment.AdverbEntry))[0] index := r.Perm(len(equipment.AdverbEntry))[0]

View File

@ -54,24 +54,24 @@ func (this *apiComp) Decompose(session comm.IUserSession, req *pb.ItemsDecompose
} }
return return
} }
sale = make([]*cfg.Gameatn, 0, len(itemcf.DecomposeDeplete)) // sale = make([]*cfg.Gameatn, 0, len(itemcf.DecomposeDeplete))
for _, v := range itemcf.DecomposeDeplete { // for _, v := range itemcf.DecomposeDeplete {
sale = append(sale, &cfg.Gameatn{ // sale = append(sale, &cfg.Gameatn{
A: v.A, // A: v.A,
T: v.T, // T: v.T,
N: v.N * int32(req.Amount), // N: v.N * int32(req.Amount),
}) // })
} // }
if errdata = this.module.ConsumeRes(session, sale, true); errdata != nil { // if errdata = this.module.ConsumeRes(session, sale, true); errdata != nil {
return // return
} // }
if req.Amount > item.Amount { if req.Amount > item.Amount {
this.module.Errorf("SellItemCheck over all amount:[%d:%d]", req.Amount, item.Amount) this.module.Errorf("SellItemCheck over all amount:[%d:%d]", req.Amount, item.Amount)
errdata = &pb.ErrorData{ errdata = &pb.ErrorData{
Code: pb.ErrorCode_ReqParameterError, Code: pb.ErrorCode_ReqParameterError,
Title: pb.ErrorCode_ReqParameterError.ToString(), Title: pb.ErrorCode_ReqParameterError.ToString(),
Message: fmt.Sprintf("道具数量不足! 道具数量:%s", item.Amount), Message: fmt.Sprintf("道具数量不足! 道具数量:%d", item.Amount),
} }
return return
} }

View File

@ -116,52 +116,101 @@ func (this *apiComp) Useitem(session comm.IUserSession, req *pb.ItemsUseItemReq)
if errdata = this.module.DispenseRes(session, sale, true); errdata != nil { if errdata = this.module.DispenseRes(session, sale, true); errdata != nil {
return return
} }
case itemuse_synthesis: //合成 case itemuse_synthesis: //合成/分解
user := this.module.ModuleUser.GetUser(session.GetUserId()) if req.Select == 0 { // 合成
reward := this.module.ModuleTools.GetGroupDataByLottery(itemcf.BoxId, user.Vip, user.Lv) // 走新的掉落 user := this.module.ModuleUser.GetUser(session.GetUserId())
if reward == nil { reward := this.module.ModuleTools.GetGroupDataByLottery(itemcf.BoxId, user.Vip, user.Lv) // 走新的掉落
errdata = &pb.ErrorData{ if reward == nil {
Code: pb.ErrorCode_ConfigNoFound, errdata = &pb.ErrorData{
Title: pb.ErrorCode_ConfigNoFound.ToString(), Code: pb.ErrorCode_ConfigNoFound,
Message: fmt.Sprintf("掉落组未找到:%d", itemcf.BoxId), Title: pb.ErrorCode_ConfigNoFound.ToString(),
Message: fmt.Sprintf("掉落组未找到:%d", itemcf.BoxId),
}
return
} }
return if itemcf.SynthetizeNum*int32(req.Amount) > int32(item.Amount) { //碎片数量不够
} errdata = &pb.ErrorData{
if itemcf.SynthetizeNum*int32(req.Amount) > int32(item.Amount) { //碎片数量不够 Code: pb.ErrorCode_ItemsNoEnough,
errdata = &pb.ErrorData{ Title: pb.ErrorCode_ItemsNoEnough.ToString(),
Code: pb.ErrorCode_ItemsNoEnough, Message: fmt.Sprintf("道具Id:%s", itemcf.Id),
Title: pb.ErrorCode_ItemsNoEnough.ToString(), }
Message: fmt.Sprintf("道具Id:%d", itemcf.Id), return
}
sale := make([]*cfg.Gameatn, 0, len(itemcf.SynthetizeDeplete))
for _, v := range itemcf.SynthetizeDeplete {
sale = append(sale, &cfg.Gameatn{
A: v.A,
T: v.T,
N: v.N * int32(req.Amount),
})
}
if errdata = this.module.ConsumeRes(session, sale, true); errdata != nil {
return
} }
return
}
sale := make([]*cfg.Gameatn, 0, len(itemcf.SynthetizeDeplete))
for _, v := range itemcf.SynthetizeDeplete {
sale = append(sale, &cfg.Gameatn{
A: v.A,
T: v.T,
N: v.N * int32(req.Amount),
})
}
if errdata = this.module.ConsumeRes(session, sale, true); errdata != nil {
return
}
if errdata = this.module.AddItemforGrid(session, req.GridId, -1*itemcf.SynthetizeNum*int32(req.Amount), true); errdata != nil { if errdata = this.module.AddItemforGrid(session, req.GridId, -1*itemcf.SynthetizeNum*int32(req.Amount), true); errdata != nil {
return return
} }
sale = make([]*cfg.Gameatn, 0, len(prop)) sale = make([]*cfg.Gameatn, 0, len(prop))
for _, v1 := range reward { for _, v1 := range reward {
sale = append(sale, &cfg.Gameatn{ sale = append(sale, &cfg.Gameatn{
A: v1.A, A: v1.A,
T: v1.T, T: v1.T,
N: v1.N * int32(req.Amount), N: v1.N * int32(req.Amount),
}) })
} }
if errdata = this.module.DispenseRes(session, sale, true); errdata != nil { if errdata = this.module.DispenseRes(session, sale, true); errdata != nil {
return return
} }
} else {
if item, err = this.module.modelItems.QueryUserPackByGridId(session.GetUserId(), req.GridId); err != nil {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_ReqParameterError,
Title: pb.ErrorCode_ReqParameterError.ToString(),
Message: err.Error(),
}
return
}
if itemcf, err = this.module.configure.GetItemConfigure(item.ItemId); err != nil {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_ConfigurationException,
Title: pb.ErrorCode_ConfigurationException.ToString(),
Message: err.Error(),
}
return
}
if itemcf.DecomposeDeplete == nil || len(itemcf.DecomposeDeplete) == 0 {
errdata = &pb.ErrorData{
Code: pb.ErrorCode_ItemsUseNoCanSell,
Title: pb.ErrorCode_ItemsUseNoCanSell.ToString(),
Message: fmt.Sprintf("道具分解配置未配置! 道具id:%s", itemcf.Id),
}
return
}
if req.Amount > item.Amount {
this.module.Errorf("SellItemCheck over all amount:[%d:%d]", req.Amount, item.Amount)
errdata = &pb.ErrorData{
Code: pb.ErrorCode_ReqParameterError,
Title: pb.ErrorCode_ReqParameterError.ToString(),
Message: fmt.Sprintf("道具数量不足! 道具数量:%d", item.Amount),
}
return
}
sale := make([]*cfg.Gameatn, len(itemcf.Sale))
for i, v := range itemcf.DecomposeDeplete {
temp := *v
sale[i] = &temp
sale[i].N = v.N * int32(req.Amount)
}
if errdata = this.module.DispenseRes(session, sale, true); errdata != nil {
return
}
item.Amount = item.Amount - req.Amount
if errdata = this.module.AddItemforGrid(session, req.GridId, -1*int32(req.Amount), true); errdata != nil {
return
}
}
default: default:
errdata = &pb.ErrorData{ errdata = &pb.ErrorData{
Code: pb.ErrorCode_ItemsUseNotSupported, Code: pb.ErrorCode_ItemsUseNotSupported,