feat: 添加ItemInfo结构体并重构抽蛋和任务系统 - 在common/data/color.go中添加ItemInfo结构体用于表示发放物品的信息 - 在common/utils/tomap.go中添加RandomSlice泛型函数用于从切片中随机选取元素 - 重构action_egg.go中的EggGamePlay功能,实现抽蛋逻辑和物品发放 - 更新fight_boss.go中使用新的ItemInfo结构体替换旧的model.ItemInfo - 修改user_talk.go中获取物品数量的逻辑 - 更新user_task.go中任务完成逻辑使用新的ItemInfo结构体 - 在egg.go中更新抽蛋结果结构体使用ItemInfo - 更新战斗奖励结构体使用ItemInfo - 在player.go中添加学习力道具处理逻辑 - 重构任务系统使用新的ItemInfo结构体 - 移除旧的model.ItemInfo定义 - 更新宠物奖励配置模型添加成长值等字段 - 实现GetEgg方法用于获取扭蛋奖励 - 修复宠物融合材料服务中的道具验证逻辑 ```
89 lines
2.3 KiB
Go
89 lines
2.3 KiB
Go
package service
|
||
|
||
import (
|
||
"blazing/cool"
|
||
|
||
"blazing/modules/config/model"
|
||
"blazing/modules/dict/service"
|
||
"strings"
|
||
|
||
"github.com/gogf/gf/v2/database/gdb"
|
||
"github.com/gogf/gf/v2/frame/g"
|
||
"github.com/gogf/gf/v2/util/gconv"
|
||
"github.com/gogf/gf/v2/util/grand"
|
||
)
|
||
|
||
// PetFusionMaterialService 宠物融合材料子表Service(对应pet_fusion_material表)
|
||
type PetFusionMaterialService struct {
|
||
*cool.Service // 嵌入通用Service(继承基础CRUD方法)
|
||
}
|
||
|
||
// NewPetFusionMaterialService 创建PetFusionMaterialService实例
|
||
func NewPetFusionMaterialService() *PetFusionMaterialService {
|
||
return &PetFusionMaterialService{
|
||
&cool.Service{
|
||
Model: model.NewPetFusionMaterial(), // 绑定PetFusionMaterial模型(默认参数占位)
|
||
//Cache: gcache.New(),
|
||
// PageQueryOp: &cool.QueryOp{KeyWordField: []string{"material1", "material2", "material3", "material4"}},
|
||
},
|
||
}
|
||
}
|
||
|
||
// 获取融合材料的特性,返回两个值,一个是指定的特性,另一个是如果配方没找到的情况下,默认的配置
|
||
func (s *PetFusionMaterialService) Data(Material1 [4]uint32) uint32 {
|
||
|
||
cacheKey := strings.Join(gconv.Strings(Material1[:]), ":")
|
||
println(cacheKey, "获取融合id")
|
||
fusions := service.DictInfoServiceS.GetData("fusion")
|
||
|
||
for _, v := range Material1 {
|
||
// if v < 10000 {
|
||
// //使用过小的道具
|
||
// return 0
|
||
// }
|
||
_, ok := fusions[v]
|
||
if !ok {
|
||
//todo使用了非法材料
|
||
return 0
|
||
}
|
||
|
||
}
|
||
m := cool.DBM(s.Model)
|
||
|
||
var effect *model.PetFusionMaterial //一个特性应该是唯一的,但是我们要获取默认随机特性
|
||
condition := g.Map{
|
||
"material1": Material1[0],
|
||
"material2": Material1[1],
|
||
"material3": Material1[2],
|
||
"material4": Material1[3],
|
||
"is_enable": 1,
|
||
}
|
||
m.Where(condition).Cache(gdb.CacheOption{
|
||
// Duration: time.Hour,
|
||
|
||
Force: false,
|
||
}).Scan(&effect)
|
||
//这时候有可能效果是空的,那么这时候就再次查询默认的特性,保证每次必会生成一个数据库有的特性
|
||
//也许这个时候的特性配方就是随机从数据库中查找一个特性
|
||
|
||
if effect == nil {
|
||
effect2s := service.DictInfoServiceS.GetData("effect")
|
||
for _, v := range effect2s {
|
||
return gconv.Uint32(v.Value)
|
||
}
|
||
|
||
}
|
||
r := grand.Intn(4)
|
||
switch r {
|
||
case 0:
|
||
return effect.Trait1Idx
|
||
case 1:
|
||
return effect.Trait2Idx
|
||
case 2:
|
||
return effect.Trait3Idx
|
||
case 3:
|
||
return effect.Trait4Idx
|
||
}
|
||
return 0
|
||
}
|