feat(pet): 实现宠物展示功能和稀有宠物塔配置 - 添加PetDisplay字段到Player结构体,用于管理宠物展示状态 - 实现PlayerShowPet方法,支持宠物展示逻辑,包括设置展示标识、 检查宠物存在性并返回相应错误码 - 在Space中添加RefreshUserInfo方法,用于刷新用户信息并应用 宠物展示信息到SimpleInfo - 扩展SimpleInfo结构体,添加PetRide字段用于宠物骑乘标识
47 lines
1.8 KiB
Go
47 lines
1.8 KiB
Go
package model
|
||
|
||
import (
|
||
"blazing/cool"
|
||
)
|
||
|
||
// 表名常量定义:精灵奖励表(存储精灵BOSS/普通精灵对应的奖励配置:掉落物品/数量/概率/获取条件等)
|
||
const (
|
||
TableNamePetReward = "config_gift_pet" // 精灵奖励配置表(包含基础掉落/稀有奖励/VIP专属奖励/保底机制)
|
||
)
|
||
|
||
// PetReward 精灵奖励基础配置模型(核心存储结构,与数据库表字段一一对应)
|
||
type PetReward struct {
|
||
*cool.Model // 保留通用Model(ID/创建时间/更新时间等)
|
||
|
||
MonID int32 `gorm:"not null;comment:'BOSS对应的精灵ID'" json:"mon_id"`
|
||
DV int32 `gorm:"not null;default:0;comment:'成长值'" json:"dv"`
|
||
Nature int32 `gorm:"not null;default:0;comment:'BOSS属性-性格'" json:"nature"`
|
||
Effect int32 `gorm:"not null;comment:'BOSS特性'" json:"effect"`
|
||
Lv int32 `gorm:"not null;comment:'BOSS等级(LvHpMatchUser非0时此配置无效)'" json:"lv"`
|
||
IsEgg uint32 `gorm:"not null;default:0;comment:'是否蛋'" json:"is_egg"` //奖励是否为扭蛋奖励
|
||
|
||
Remark string `gorm:"type:varchar(255);default:'';comment:'性别配置备注(如:默认性别规则)'" json:"remark"` // 调整注释
|
||
}
|
||
|
||
// TableName 指定PetReward对应的数据库表名(遵循现有代码规范)
|
||
func (*PetReward) TableName() string {
|
||
return TableNamePetReward
|
||
}
|
||
|
||
// GroupName 指定表所属的分组(与BossConfig保持一致,统一为default分组)
|
||
func (*PetReward) GroupName() string {
|
||
return "default"
|
||
}
|
||
|
||
// NewPetReward 创建一个新的PetReward实例(初始化通用Model字段+所有字段默认值,与NewBossConfig保持一致)
|
||
func NewPetReward() *PetReward {
|
||
return &PetReward{
|
||
Model: cool.NewModel(),
|
||
}
|
||
}
|
||
|
||
// init 程序启动时自动创建/同步精灵奖励表结构(与BossConfig的表同步逻辑一致)
|
||
func init() {
|
||
cool.CreateTable(&PetReward{})
|
||
}
|