``` feat(pet): 重构宠物繁殖系统,添加蛋孵化功能

This commit is contained in:
1
2026-01-20 22:08:36 +00:00
parent cf4660fbe0
commit 5ef922278a
68 changed files with 4467 additions and 584 deletions

View File

@@ -0,0 +1,76 @@
package model
import (
"blazing/cool"
)
// 表名常量
const TableNamePlayerEgg = "player_egg"
// Egg 对应数据库表 player_cdk_log用于记录CDK兑换日志
type Egg struct {
Base
PlayerID uint64 `gorm:"not null;index:idx_player_Egg_by_player_id;comment:'所属玩家ID'" json:"player_id"`
Data S2C_GET_BREED_INFO `gorm:"type:jsonb;not null;comment:'全部数据'" json:"data"`
CurEgg EggInfo `gorm:"type:jsonb;not null;comment:'当前蛋'" json:"cur_egg"`
EggList []EggInfo `gorm:"type:jsonb;not null;comment:'蛋列表'" json:"egg_list"`
}
// S2C_GET_BREED_INFO 获取繁殖信息协议
// 后端到前端
type S2C_GET_BREED_INFO struct {
// BreedState 繁殖状态
BreedState uint32 `json:"breedState"`
StartTime uint32 `struc:"skip"` //返回记录
// BreedLeftTime 繁殖剩余时间
BreedLeftTime uint32 `json:"breedLeftTime"`
// BreedCoolTime 繁殖冷却时间
BreedCoolTime uint32 `json:"breedCoolTime"`
// MalePetCatchTime 雄性精灵捕捉时间
MalePetCatchTime uint32 `json:"malePetCatchTime"`
// MalePetID 雄性精灵ID
MalePetID uint32 `json:"malePetID"`
// FeMalePetCatchTime 雌性精灵捕捉时间
FeMalePetCatchTime uint32 `json:"feMalePetCatchTime"`
// FeMalePetID 雌性精灵ID
FeMalePetID uint32 `json:"feMalePetID"`
// HatchState 孵化状态 ,0=未孵化 1=孵化中 2=已孵化
HatchState uint32 `json:"hatchState"`
// HatchLeftTime 孵化剩余时间
HatchLeftTime uint32 `json:"hatchLeftTime"`
// EggID 当前孵化的精灵蛋ID
EggID uint32 `json:"eggID"`
// Intimacy 亲密度 1 = 悲伤 以此类推 ["悲伤","冷淡","平淡","友好","亲密无间"]
Intimacy uint32 `json:"intimacy"`
}
// EggInfo 精灵蛋信息
type EggInfo struct {
OwnerID uint32 `json:"ownerID"` // 所属人ID
EggCatchTime uint32 `json:"eggCatchTime"` // 精灵蛋获得时间
EggID uint32 `json:"eggID"` // 精灵蛋ID
MalePetID uint32 `json:"male"` // 雄性精灵ID
FeMalePetID uint32 `json:"female"` // 雌性精灵ID
}
// TableName 返回表名
func (*Egg) TableName() string {
return TableNamePlayerEgg
}
// GroupName 返回表组名
func (*Egg) GroupName() string {
return "default"
}
// NewEgg 创建一个新的CDK记录
func NewEgg() *Egg {
return &Egg{
Base: *NewBase(),
}
}
// init 程序启动时自动创建表
func init() {
cool.CreateTable(&Egg{})
}

View File

@@ -18,7 +18,7 @@ type SignInRecord struct {
IsCompleted bool `gorm:"not null;default:false;comment:'签到是否完成0-未完成 1-已完成)'" json:"is_completed"`
//通过bitset来实现签到的进度记录
SignInProgress []uint32 `gorm:"type:json;not null;comment:'签到进度(状压实现,存储每日签到状态)'" json:"sign_in_progress"`
SignInProgress []uint32 `gorm:"type:jsonb;not null;comment:'签到进度(状压实现,存储每日签到状态)'" json:"sign_in_progress"`
}
// TableName 指定表名(遵循现有规范)

View File

@@ -0,0 +1,48 @@
package service
import (
"blazing/cool"
"blazing/modules/player/model"
"time"
)
type EggService struct {
BaseService
}
func NewEggService(id uint32) *EggService {
return &EggService{
BaseService: BaseService{userid: id,
Service: &cool.Service{Model: model.NewEgg()},
},
}
}
func (s *EggService) Get() (out *model.Egg) {
s.TestModel(s.Model).Scan(&out)
return
}
func (s *EggService) StartBreed(m, f *model.PetInfo) bool {
var tt *model.Egg
s.TestModel(s.Model).Scan(&tt)
if tt == nil {
tt = &model.Egg{}
}
if tt.Data.HatchState != 0 {
return false
}
tt.Data.StartTime = uint32(time.Now().Unix())
tt.Data.HatchState = 1
tt.Data.FeMalePetCatchTime = f.CatchTime
tt.Data.MalePetCatchTime = m.CatchTime
tt.Data.FeMalePetID = f.ID
tt.Data.MalePetID = m.ID
return true
}

View File

@@ -53,17 +53,11 @@ func (s *InfoService) Reg(nick string, color uint32) {
//go s.InitTask()
}
func (s *InfoService) Person(userid uint32) *model.PlayerInfo {
func (s *InfoService) Person(userid uint32) (out *model.PlayerEX) {
m := cool.DBM(s.Model).Where("player_id", userid)
var tt model.PlayerEX
err := m.Scan(&tt)
if err != nil {
return nil
}
cool.DBM(s.Model).Where("player_id", userid).Scan(&out)
ret := tt.Data
return &ret
return
}
func (s *InfoService) GetCache() *model.PlayerInfo {

View File

@@ -116,7 +116,7 @@ RETURNING max_ts;
`, service.NewBaseSysUserService().Model.TableName())
// 执行 Raw SQL 并扫描返回值
ret, err := cool.DBM(service.NewBaseSysUserService().Model).Raw(sql, s.userid).All()
ret, _ := cool.DBM(service.NewBaseSysUserService().Model).Raw(sql, s.userid).All()
//fmt.Println(ret, err)
y.CatchTime = ret.Array()[0].Uint32()
m1 := cool.DBM(s.Model).Where("player_id", s.userid)
@@ -127,7 +127,7 @@ RETURNING max_ts;
player.Free = 0
player.IsVip = cool.Config.ServerInfo.IsVip
_, err = m1.Insert(player)
_, err := m1.Insert(player)
if err != nil {
panic(err)
}

View File

@@ -22,6 +22,7 @@ type UserService struct {
Title *TitleService
Cdk *CdkService
Friend *FriendService
Egg *EggService
}
func NewUserService(id uint32) *UserService {
@@ -38,6 +39,7 @@ func NewUserService(id uint32) *UserService {
Title: NewTitleService(id),
Cdk: NewCdkService(id),
Friend: NewFriendService(id),
Egg: NewEggService(id),
}
}