refactor(service): 重构物品、宠物和任务服务,统一使用EX模型和回调函数处理数据操作
This commit is contained in:
@@ -1,197 +0,0 @@
|
||||
package model
|
||||
|
||||
import (
|
||||
"blazing/cool"
|
||||
"encoding/json"
|
||||
)
|
||||
|
||||
// ------------------------------
|
||||
// 1. BOSS主表结构(核心ID与关联)
|
||||
// ------------------------------
|
||||
|
||||
const TableNameBoss = "boss"
|
||||
|
||||
// Boss 主表仅存储核心索引和JSON数据
|
||||
type Boss struct {
|
||||
*cool.Model
|
||||
PlanetID int32 `gorm:"not null;index:idx_boss_planet;comment:'所属星球/地图ID'" json:"planet_id"`
|
||||
BossID int32 `gorm:"not null;comment:'BOSS序号(同星球内唯一)'" json:"boss_id"`
|
||||
Data string `gorm:"type:text;not null;comment:'BOSS详细数据(JSON格式)'" json:"data"`
|
||||
Galaxy string `gorm:"type:varchar(50);comment:'所属星系(如帕诺星系)'" json:"galaxy"`
|
||||
}
|
||||
|
||||
// 联合唯一索引:确保星球+BOSS序号唯一
|
||||
func (b *Boss) Indexes() map[string]string {
|
||||
return map[string]string{
|
||||
"idx_planet_boss_unique": "planet_id,boss_id",
|
||||
}
|
||||
}
|
||||
|
||||
// TableName 定义表名
|
||||
func (*Boss) TableName() string {
|
||||
return TableNameBoss
|
||||
}
|
||||
|
||||
// GroupName 定义分组名
|
||||
func (*Boss) GroupName() string {
|
||||
return "default"
|
||||
}
|
||||
|
||||
// GroupName 定义分组名
|
||||
func (s *Boss) GetData() string {
|
||||
return s.Data
|
||||
}
|
||||
|
||||
// NewBoss 创建新的BOSS主表实例
|
||||
func NewBoss() *Boss {
|
||||
return &Boss{
|
||||
Model: cool.NewModel(),
|
||||
}
|
||||
}
|
||||
|
||||
// ------------------------------
|
||||
// 2. BOSS详细数据结构(JSON存储)
|
||||
// ------------------------------
|
||||
|
||||
// BossData 封装BOSS所有详细属性,用于JSON序列化
|
||||
type BossData struct {
|
||||
// 基础信息
|
||||
EncyclopediaID int32 `json:"encyclopedia_id"` // BOSS图鉴ID
|
||||
Desc string `json:"desc"` // BOSS名称描述
|
||||
Level int32 `json:"level"` // 等级
|
||||
Capturable bool `json:"capturable"` // 是否可捕捉
|
||||
|
||||
// 战斗属性
|
||||
MaxHP int32 `json:"max_hp"` // 最大血量(-1使用默认公式)
|
||||
Attack int32 `json:"attack"` // 攻击属性
|
||||
Defense int32 `json:"defense"` // 防御属性
|
||||
SpecialAttack int32 `json:"special_attack"` // 特攻属性
|
||||
SpecialDefense int32 `json:"special_defense"` // 特防属性
|
||||
Speed int32 `json:"speed"` // 速度属性
|
||||
Definitely int32 `json:"definitely"` // 必定命中率(默认5)
|
||||
Dodge int32 `json:"dodge"` // 闪避率(默认5)
|
||||
Stat string `json:"stat"` // 开局属性变化(攻击,特攻,防御,特防,速度,命中)
|
||||
|
||||
// 技能列表
|
||||
Skills []BossSkill `json:"skills"`
|
||||
|
||||
// 免疫效果
|
||||
ImmunityEffectIDs []int32 `json:"immunity_effect_ids"` // 免疫效果ID列表
|
||||
ImmunityBuffNames []string `json:"immunity_buff_names"` // 免疫Buff名称列表
|
||||
|
||||
// 特殊Buff
|
||||
SpecialBuffs []SpecialBuff `json:"special_buffs"`
|
||||
}
|
||||
|
||||
// BossSkill 技能详情结构
|
||||
type BossSkill struct {
|
||||
ID int32 `json:"id"` // 技能ID
|
||||
Desc string `json:"desc"` // 技能描述
|
||||
InfinityPP bool `json:"infinity_pp"` // 是否PP无限
|
||||
}
|
||||
|
||||
// SpecialBuff 特殊Buff结构
|
||||
type SpecialBuff struct {
|
||||
Value string `json:"value"` // Buff标识(如boss://map314-boss0)
|
||||
Params string `json:"params"` // 附加参数(空格分隔)
|
||||
}
|
||||
|
||||
// ------------------------------
|
||||
// 3. JSON序列化/反序列化工具方法
|
||||
// ------------------------------
|
||||
|
||||
// ToJSON 将BossData转为JSON字符串
|
||||
func (d *BossData) ToJSON() (string, error) {
|
||||
data, err := json.Marshal(d)
|
||||
if err != nil {
|
||||
return "", err
|
||||
}
|
||||
return string(data), nil
|
||||
}
|
||||
|
||||
// ParseBossData 从JSON字符串解析BossData
|
||||
func ParseBossData(jsonStr string) (*BossData, error) {
|
||||
var data BossData
|
||||
if err := json.Unmarshal([]byte(jsonStr), &data); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
return &data, nil
|
||||
}
|
||||
|
||||
// ------------------------------
|
||||
// 4. 表初始化
|
||||
// ------------------------------
|
||||
|
||||
func init() {
|
||||
// 创建BOSS主表
|
||||
cool.CreateTable(&Boss{})
|
||||
}
|
||||
|
||||
// ------------------------------
|
||||
// 5. 使用示例
|
||||
// ------------------------------
|
||||
|
||||
/*
|
||||
// 存储BOSS数据示例
|
||||
func ExampleSaveBoss() {
|
||||
// 1. 构建详细数据
|
||||
skills := []BossSkill{
|
||||
{ID: 10001, Desc: "撞击", InfinityPP: true},
|
||||
{ID: 20020, Desc: "毒粉", InfinityPP: true},
|
||||
}
|
||||
|
||||
immunityEffects := []int32{7, 36}
|
||||
immunityBuffs := []string{"condition://brun", "condition://poison"}
|
||||
|
||||
specialBuffs := []SpecialBuff{
|
||||
{Value: "boss://map59-boss0", Params: ""},
|
||||
}
|
||||
|
||||
bossData := &BossData{
|
||||
EncyclopediaID: 347,
|
||||
Desc: "远古鱼龙",
|
||||
Level: 100,
|
||||
Capturable: false,
|
||||
MaxHP: 3000,
|
||||
Attack: 280,
|
||||
SpecialAttack: 417,
|
||||
Defense: 350,
|
||||
SpecialDefense: 317,
|
||||
Speed: 264,
|
||||
Definitely: 45,
|
||||
Stat: "0 0 0 0 0 0",
|
||||
Skills: skills,
|
||||
ImmunityEffectIDs: immunityEffects,
|
||||
ImmunityBuffNames: immunityBuffs,
|
||||
SpecialBuffs: specialBuffs,
|
||||
}
|
||||
|
||||
// 2. 序列化为JSON
|
||||
dataJSON, _ := bossData.ToJSON()
|
||||
|
||||
// 3. 存储到主表
|
||||
boss := NewBoss()
|
||||
boss.PlanetID = 59
|
||||
boss.BossID = 0
|
||||
boss.Galaxy = "卡兰星系"
|
||||
boss.Data = dataJSON
|
||||
|
||||
// 实际项目中使用GORM保存
|
||||
// db.Create(boss)
|
||||
}
|
||||
|
||||
// 查询BOSS数据示例
|
||||
func ExampleGetBoss() {
|
||||
// 1. 从数据库查询主表
|
||||
var boss Boss
|
||||
// db.Where("planet_id = ? AND boss_id = ?", 59, 0).First(&boss)
|
||||
|
||||
// 2. 解析JSON数据
|
||||
bossData, _ := ParseBossData(boss.Data)
|
||||
|
||||
// 3. 使用数据
|
||||
println("BOSS名称:", bossData.Desc)
|
||||
println("等级:", bossData.Level)
|
||||
println("技能数量:", len(bossData.Skills))
|
||||
}
|
||||
*/
|
||||
@@ -1,4 +0,0 @@
|
||||
package model
|
||||
|
||||
// /这里实现周期性任务,比如每日任务,每周任务,每月任务,每年任务,一次性任务
|
||||
type PeriodType int
|
||||
@@ -10,8 +10,13 @@ const TableNamePlayerBagItem = "player_bag_item"
|
||||
type Item struct {
|
||||
*cool.Model
|
||||
PlayerID uint64 `gorm:"not null;index:idx_player_bag_item_by_player_id;comment:'所属玩家ID'" json:"player_id"`
|
||||
Data string `gorm:"type:text;not null;comment:'全部数据'" json:"data"`
|
||||
Data string ` gorm:"type:text;not null;comment:'全部数据'" json:"data"`
|
||||
}
|
||||
type ItemEX struct {
|
||||
Item
|
||||
Data map[uint32]SingleItemInfo `orm:"data" json:"data"`
|
||||
}
|
||||
|
||||
type SingleItemInfo struct {
|
||||
// 物品Id,
|
||||
ItemId uint32 `json:"itemId"`
|
||||
|
||||
@@ -55,6 +55,11 @@ type Pet struct {
|
||||
//是否上架
|
||||
Data string `gorm:"type:text;not null;comment:'精灵全部数据'" json:"data"`
|
||||
}
|
||||
type PetEX struct {
|
||||
Pet
|
||||
Data PetInfo `orm:"data" json:"data"`
|
||||
|
||||
}
|
||||
|
||||
func LastFourElements[T any](s []T) []T {
|
||||
n := len(s)
|
||||
|
||||
@@ -15,12 +15,10 @@ type Task struct {
|
||||
Data string `gorm:"type:text;not null;comment:'全部数据'" json:"data"`
|
||||
}
|
||||
|
||||
// TaskInfo 单个任务的详细信息,包含任务步骤状态和整体状态
|
||||
type TaskInfo struct {
|
||||
// TaskInfo 任务步骤信息,
|
||||
// struc:"[20]byte" 确保二进制序列化时固定20字节长度,json标签指定JSON字段名
|
||||
//TaskID uint32 `json:"task_id"` //区分是每日任务还是常规任务,常规为0,每日为1
|
||||
Info []uint32 `struc:"[20]byte" json:"task_info"`
|
||||
// TaskEX 单个任务的详细信息,包含任务步骤状态和整体状态
|
||||
type TaskEX struct {
|
||||
Task
|
||||
Data []uint32 `struc:"[20]byte" orm:"data" json:"data"`
|
||||
//LastResetTime time.Time `gorm:"not null;comment:'上次重置时间(UTC)'" json:"last_reset_time"` //这里是每天重置
|
||||
// Status 任务整体状态:0-未接受,1-已接受,2-已完成未领取,3-已完成已领取
|
||||
// json标签指定JSON字段名,与业务状态说明保持一致
|
||||
|
||||
Reference in New Issue
Block a user