f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
1
2
3
|
package models
import (
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
4
5
|
"fmt"
"github.com/golang/protobuf/proto"
|
17fe96be
zhangqijia
feat: 增加装备相关数据和协议
|
6
|
"pro2d/common"
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
7
|
"pro2d/common/logger"
|
ddc88bac
zhangqijia
fix: 记录战斗
|
8
|
"pro2d/csvdata"
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
9
|
"pro2d/pb"
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
10
11
12
|
)
//背包系统
|
ddc88bac
zhangqijia
fix: 记录战斗
|
13
|
func (m *RoleModel) GetItemCount(key string) int32 {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
14
15
|
c, ok := m.Items[key]
if !ok {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
16
|
c = int32(0)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
17
|
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
18
|
return c
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
19
20
21
|
}
func (m *RoleModel) CostItem(key string, count int32) bool {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
22
|
if count > m.GetItemCount(key) {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
23
24
25
26
27
|
return false
}
return m.AddItem(key, -count)
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
28
|
func (m *RoleModel) CostItems(params common.IMapStringNum) bool {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
29
|
for k, v := range params {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
30
|
if v > m.GetItemCount(k) {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
31
32
33
|
return false
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
34
|
m.AddItem(k, -v)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
35
36
37
38
39
40
41
|
}
return true
}
func (m *RoleModel) AddItem(key string, count int32) bool {
c := m.GetItemCount(key)
|
ddc88bac
zhangqijia
fix: 记录战斗
|
42
|
num := c + count
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
43
|
if num > 0 {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
44
|
m.Items[key] = num
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
45
46
47
|
} else {
delete(m.Items, key)
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
48
|
m.SetProperty("items", common.MapNumToString(m.Items))
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
49
50
51
52
53
54
|
rsp, err := proto.Marshal(&pb.RoleUpdateItemsRsp{Items: fmt.Sprintf("%s=%d", key, num)})
if err != nil {
logger.Error(err.Error())
return true
}
|
c2791869
zhangqijia
fix: gm增加删除装备删除物品接口
|
55
56
57
58
|
if m.GetConn() != nil {
m.GetConn().Send(0, uint32(pb.ProtoCode_RoleUpdateItemsRsp), rsp)
}
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
59
60
61
|
return true
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
62
|
func (m *RoleModel) AddItems(params common.IMapStringNum) bool {
|
17fe96be
zhangqijia
feat: 增加装备相关数据和协议
|
63
|
tmp := make(common.IMapString)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
64
65
66
|
for k, v := range params {
c := m.GetItemCount(k)
|
ddc88bac
zhangqijia
fix: 记录战斗
|
67
|
num := c + v
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
68
69
70
71
72
73
74
75
|
if num > 0 {
m.Items[k] = num
tmp[k] = num
} else {
delete(m.Items, k)
}
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
76
|
m.SetProperty("items", common.MapNumToString(m.Items))
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
77
|
|
17fe96be
zhangqijia
feat: 增加装备相关数据和协议
|
78
|
rsp, err := proto.Marshal(&pb.RoleUpdateItemsRsp{Items: common.MapToString(tmp)})
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
79
80
81
82
83
84
85
86
87
88
89
|
if err != nil {
logger.Error(err.Error())
return true
}
if m.GetConn() != nil {
m.GetConn().Send(0, uint32(pb.ProtoCode_RoleUpdateItemsRsp), rsp)
}
return true
}
|
c8509ef6
zhangqijia
fix: notify equip...
|
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
|
func (m *RoleModel) AddHero(hero *pb.Hero) {
h := NewHero(hero)
h.Create()
m.Heros[hero.Id] = h
}
func (m *RoleModel) AddTeam(team *pb.Team) {
t := NewTeam(team)
t.Create()
m.Teams[team.Id] = t
}
func (m *RoleModel) UpdateTeam(teams []*pb.Team) {
for _, team := range teams {
team.RoleId = m.Role.Id
t := m.Teams[team.Id]
if t != nil {
t.UpdateSchema(team)
}
}
}
func (m *RoleModel) AddEquip(equip *pb.Equipment) *EquipModel {
e := NewEquip(equip)
e.Create()
m.Equipments[equip.Id] = e
m.EquipmentAddNotify(equip)
return e
}
func (m *RoleModel) EquipmentAddNotify(equip *pb.Equipment) {
update := &pb.EquipmentAddRsp{Equip: equip}
if rsp, err := proto.Marshal(update); err != nil {
logger.Error(" EquipmentAddNotify err:", err.Error())
return
} else {
if m.GetConn() != nil {
m.GetConn().SendSuccess(uint32(pb.ProtoCode_EquipmentAddRsp), rsp)
}
}
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
132
133
134
135
|
func (m *RoleModel) UpLevel(exp int32) (int32, int32) {
level := m.Role.Level
oldLevelExp := csvdata.Get().TbAccountLevelExp.Get(level)
|
8f6d9ea9
zhangqijia
fix: UpLevel
|
136
137
138
|
if oldLevelExp == nil {
return level, m.Role.Level
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
139
|
if exp >= oldLevelExp.NeedExp-m.Role.Exp {
|
686ff048
zhangqijia
fix: 结束战斗增加字段
|
140
|
exp = exp - (oldLevelExp.NeedExp - m.Role.Exp)
|
ddc88bac
zhangqijia
fix: 记录战斗
|
141
142
143
144
|
level++
for exp > 0 {
oldLevelExp = csvdata.Get().TbAccountLevelExp.Get(level)
|
8f6d9ea9
zhangqijia
fix: UpLevel
|
145
146
147
148
|
if oldLevelExp == nil {
return level, exp
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
|
if exp >= oldLevelExp.NeedExp {
exp = exp - oldLevelExp.NeedExp
level++
} else {
exp = exp + m.Role.Exp
break
}
}
} else {
exp = exp + m.Role.Exp
}
return level, exp
}
func (m *RoleModel) Award(award common.IMapStringNum) common.IMapStringNum {
m.AddItems(award)
return award
}
|