f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
1
2
3
|
package models
import (
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
4
5
|
"fmt"
"github.com/golang/protobuf/proto"
|
e172952c
zhangqijia
feat: email 系统搭建
|
6
7
|
"go.mongodb.org/mongo-driver/bson"
"go.mongodb.org/mongo-driver/mongo/options"
|
17fe96be
zhangqijia
feat: 增加装备相关数据和协议
|
8
|
"pro2d/common"
|
e172952c
zhangqijia
feat: email 系统搭建
|
9
|
"pro2d/common/db/mongoproxy"
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
10
|
"pro2d/common/logger"
|
ddc88bac
zhangqijia
fix: 记录战斗
|
11
|
"pro2d/csvdata"
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
12
|
"pro2d/pb"
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
13
14
15
|
)
//背包系统
|
ddc88bac
zhangqijia
fix: 记录战斗
|
16
|
func (m *RoleModel) GetItemCount(key string) int32 {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
17
18
|
c, ok := m.Items[key]
if !ok {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
19
|
c = int32(0)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
20
|
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
21
|
return c
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
22
23
24
|
}
func (m *RoleModel) CostItem(key string, count int32) bool {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
25
|
if count > m.GetItemCount(key) {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
26
27
28
29
30
|
return false
}
return m.AddItem(key, -count)
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
31
|
func (m *RoleModel) CostItems(params common.IMapStringNum) bool {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
32
|
for k, v := range params {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
33
|
if v > m.GetItemCount(k) {
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
34
35
36
|
return false
}
|
c99d59cc
zhangqijia
fix: 批量删除物品
|
37
|
params[k] = -v
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
38
|
}
|
c99d59cc
zhangqijia
fix: 批量删除物品
|
39
40
|
return m.AddItems(params)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
41
42
43
44
45
|
}
func (m *RoleModel) AddItem(key string, count int32) bool {
c := m.GetItemCount(key)
|
ddc88bac
zhangqijia
fix: 记录战斗
|
46
|
num := c + count
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
47
|
if num > 0 {
|
ddc88bac
zhangqijia
fix: 记录战斗
|
48
|
m.Items[key] = num
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
49
50
51
|
} else {
delete(m.Items, key)
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
52
|
m.SetProperty("items", common.MapNumToString(m.Items))
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
53
|
|
30e6d227
zhangqijia
fix: add nty
|
54
|
rsp, err := proto.Marshal(&pb.RoleUpdateItemsNty{Items: fmt.Sprintf("%s=%d", key, num)})
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
55
56
57
58
|
if err != nil {
logger.Error(err.Error())
return true
}
|
c2791869
zhangqijia
fix: gm增加删除装备删除物品接口
|
59
60
|
if m.GetConn() != nil {
|
c1d56a47
zhangqijia
fix: update preserve
|
61
|
m.GetConn().Send(0, uint32(pb.ProtoCode_RoleUpdateItemsNty), rsp, 0)
|
c2791869
zhangqijia
fix: gm增加删除装备删除物品接口
|
62
|
}
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
63
64
65
|
return true
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
66
|
func (m *RoleModel) AddItems(params common.IMapStringNum) bool {
|
17fe96be
zhangqijia
feat: 增加装备相关数据和协议
|
67
|
tmp := make(common.IMapString)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
68
69
70
|
for k, v := range params {
c := m.GetItemCount(k)
|
ddc88bac
zhangqijia
fix: 记录战斗
|
71
|
num := c + v
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
72
73
|
if num > 0 {
m.Items[k] = num
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
74
|
} else {
|
c99d59cc
zhangqijia
fix: 批量删除物品
|
75
|
num = 0
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
76
77
|
delete(m.Items, k)
}
|
c99d59cc
zhangqijia
fix: 批量删除物品
|
78
|
tmp[k] = num
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
79
80
|
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
81
|
m.SetProperty("items", common.MapNumToString(m.Items))
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
82
|
|
30e6d227
zhangqijia
fix: add nty
|
83
|
rsp, err := proto.Marshal(&pb.RoleUpdateItemsNty{Items: common.MapToString(tmp)})
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
84
85
86
87
88
89
|
if err != nil {
logger.Error(err.Error())
return true
}
if m.GetConn() != nil {
|
c1d56a47
zhangqijia
fix: update preserve
|
90
|
m.GetConn().Send(0, uint32(pb.ProtoCode_RoleUpdateItemsNty), rsp, 0)
|
f631f225
zhangqijia
feat: 增加背包系统,以及背包...
|
91
92
93
94
|
}
return true
}
|
c8509ef6
zhangqijia
fix: notify equip...
|
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
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 {
|
23822e2f
zhangqijia
fix: update proto...
|
110
|
team.RoleId = m.Data.Id
|
c8509ef6
zhangqijia
fix: notify equip...
|
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
|
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) {
|
23822e2f
zhangqijia
fix: update proto...
|
127
|
update := &pb.EquipmentAddNty{Equip: equip}
|
c8509ef6
zhangqijia
fix: notify equip...
|
128
129
130
131
132
|
if rsp, err := proto.Marshal(update); err != nil {
logger.Error(" EquipmentAddNotify err:", err.Error())
return
} else {
if m.GetConn() != nil {
|
c1d56a47
zhangqijia
fix: update preserve
|
133
|
m.GetConn().SendSuccess(uint32(pb.ProtoCode_EquipmentAddNty), rsp, 0)
|
c8509ef6
zhangqijia
fix: notify equip...
|
134
135
136
|
}
}
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
137
138
|
func (m *RoleModel) UpLevel(exp int32) (int32, int32) {
|
23822e2f
zhangqijia
fix: update proto...
|
139
140
|
exp = exp + m.Data.Exp
level := m.Data.Level
|
ddc88bac
zhangqijia
fix: 记录战斗
|
141
|
oldLevelExp := csvdata.Get().TbAccountLevelExp.Get(level)
|
8f6d9ea9
zhangqijia
fix: UpLevel
|
142
|
if oldLevelExp == nil {
|
b0e5082c
zhangqijia
fix: 英雄升级函数优化
|
143
|
return level, exp
|
8f6d9ea9
zhangqijia
fix: UpLevel
|
144
|
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
145
|
|
b0e5082c
zhangqijia
fix: 英雄升级函数优化
|
146
147
148
149
150
151
152
153
154
155
156
|
for exp > 0 {
if exp >= oldLevelExp.NeedExp {
exp = exp - oldLevelExp.NeedExp
level++
} else {
break
}
oldLevelExp = csvdata.Get().TbAccountLevelExp.Get(level)
if oldLevelExp == nil {
return level, exp
}
|
ddc88bac
zhangqijia
fix: 记录战斗
|
157
158
|
}
return level, exp
|
ddc88bac
zhangqijia
fix: 记录战斗
|
159
160
161
162
163
164
|
}
func (m *RoleModel) Award(award common.IMapStringNum) common.IMapStringNum {
m.AddItems(award)
return award
}
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
165
|
|
35adfcdb
zhangqijia
fix: 裝備戒指类型特殊处理
|
166
|
func (m *RoleModel) EquipmentRefer(equipId, heroId string, refer bool, pos int32) int32 {
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
167
168
169
170
171
172
173
174
175
176
|
e, ok := m.Equipments[equipId]
if !ok {
return 2
}
equip := e.(*EquipModel)
// 1 脱
// 1.1 装备直接脱掉
// 2 戴
|
74286d71
zhangqijia
fix: 裝備 删除pos 添加 ...
|
177
178
179
180
181
|
// 2.0.1 如果是戒指,特殊处理, 未被其他英雄穿戴直接穿,同位置装备是否穿戴, 已经被穿戴,则脱了再穿
// 2.0.2 如果是戒指,特殊处理, 如果其他英雄已经被穿戴,则脱了再穿, 同位置装备是否穿戴, 已经被穿戴,则脱了再穿
// 2.1.1 如果不是戒指,未被其他英雄穿戴直接穿,同位置装备是否穿戴, 已经被穿戴,则脱了再穿
// 2.1.2 如果不是戒指,如果其他英雄已经被穿戴,则脱了再穿, 同位置装备是否穿戴, 已经被穿戴,则脱了再穿
// 可以合并。不用判断是否是戒指。
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
182
|
h1 := m.Heros[heroId]
|
23822e2f
zhangqijia
fix: update proto...
|
183
|
h2 := m.Heros[equip.Data.HeroId]
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
184
185
|
var outHero, inHero *HeroModel
|
23822e2f
zhangqijia
fix: update proto...
|
186
|
inEquip := csvdata.Get().TbEquipmentData.Get(equip.Data.GetTbId())
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
187
|
if !refer {
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
188
189
|
if h1 != nil {
outHero = h1.(*HeroModel)
|
23822e2f
zhangqijia
fix: update proto...
|
190
|
outHero.DelEquipment(equip.Data.Id)
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
191
192
193
|
}
if h2 != nil {
outHero = h2.(*HeroModel)
|
23822e2f
zhangqijia
fix: update proto...
|
194
|
outHero.DelEquipment(equip.Data.Id)
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
195
196
197
198
199
200
201
202
203
|
}
equip.SetProperty("heroid", "")
} else {
if h1 == nil {
return 3
}
inHero = h1.(*HeroModel)
|
35adfcdb
zhangqijia
fix: 裝備戒指类型特殊处理
|
204
205
206
207
208
|
if common.EquipmentTyp(inEquip.EquipType) == common.Ring {
if pos != common.RingPosL && pos != common.RingPosR {
return 4
}
}
|
74286d71
zhangqijia
fix: 裝備 删除pos 添加 ...
|
209
|
// 2.1.1
|
23822e2f
zhangqijia
fix: update proto...
|
210
|
if equip.Data.HeroId == "" {
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
211
|
var outEquipID string
|
74286d71
zhangqijia
fix: 裝備 删除pos 添加 ...
|
212
|
for id, typ := range inHero.Equipments {
|
35adfcdb
zhangqijia
fix: 裝備戒指类型特殊处理
|
213
|
if typ == pos {
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
214
215
216
217
|
outEquipID = id
break
}
}
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
218
219
220
221
222
|
if outEquipID != "" {
tmpEuqip, ok := m.Equipments[outEquipID]
if ok {
outEquip := tmpEuqip.(*EquipModel)
outEquip.SetProperty("heroid", "")
|
3cd84ccc
zhangqijia
fix: 裝備位置修改
|
223
|
inHero.DelEquipment(outEquipID)
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
224
225
226
|
}
}
|
23822e2f
zhangqijia
fix: update proto...
|
227
228
|
inHero.AddEquipment(equip.Data.Id, pos)
equip.SetProperty("heroid", inHero.Data.Id)
|
35adfcdb
zhangqijia
fix: 裝備戒指类型特殊处理
|
229
|
equip.SetProperty("pos", pos)
|
3cd84ccc
zhangqijia
fix: 裝備位置修改
|
230
|
} else {
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
231
232
233
|
if h2 == nil {
return 4
}
|
74286d71
zhangqijia
fix: 裝備 删除pos 添加 ...
|
234
|
// 2.1.2
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
235
236
|
outHero = h2.(*HeroModel)
var outEquipID string
|
3cd84ccc
zhangqijia
fix: 裝備位置修改
|
237
|
for id, tpos := range inHero.Equipments {
|
35adfcdb
zhangqijia
fix: 裝備戒指类型特殊处理
|
238
|
if tpos == pos {
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
239
240
241
242
243
244
245
246
247
248
|
outEquipID = id
break
}
}
if outEquipID != "" {
tmpEquip, ok := m.Equipments[outEquipID]
if ok {
outEquip := tmpEquip.(*EquipModel)
outEquip.SetProperty("heroid", "")
|
3cd84ccc
zhangqijia
fix: 裝備位置修改
|
249
|
inHero.DelEquipment(outEquipID)
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
250
251
252
|
}
}
|
23822e2f
zhangqijia
fix: update proto...
|
253
254
255
|
outHero.DelEquipment(equip.Data.Id)
inHero.AddEquipment(equip.Data.Id, pos)
equip.SetProperty("heroid", inHero.Data.Id)
|
35adfcdb
zhangqijia
fix: 裝備戒指类型特殊处理
|
256
|
equip.SetProperty("pos", pos)
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
257
|
}
|
74286d71
zhangqijia
fix: 裝備 删除pos 添加 ...
|
258
|
|
98cfa13a
zhangqijia
fix: 批量穿戴裝備
|
259
260
261
|
}
return 0
}
|
e172952c
zhangqijia
feat: email 系统搭建
|
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
|
func (m *RoleModel) DelExpireEmail() error {
filter := bson.D{{"roleid", m.Data.Id}}
sort := bson.D{
{"createtime", -1},
}
var limit int64 = 10000
var skip int64 = EMAIL_LIMIT
//查询条件
opts := &options.FindOptions{
Sort: sort,
Limit: &limit,
Skip: &skip,
}
emails := make([]*pb.Email, EMAIL_LIMIT)
err := mongoproxy.FindManyFilter("email", filter, opts, &emails)
if err != nil {
return err
}
var ids []string
for _, email := range emails {
ids = append(ids, email.Id)
}
filter = append(filter, bson.E{Key: "$in", Value: ids})
err = mongoproxy.DelMany("email", filter)
if err != nil {
return err
}
return nil
}
func (m *RoleModel) LoadEmails() []*pb.Email {
//filter := bson.D{{"roleid", m.Data.Id}}
//sort := bson.D{
// {"createtime", -1},
//}
//var limit int64 = EMAIL_LIMIT
////查询条件
//opts := &options.FindOptions{
// Sort: sort,
// Limit: &limit,
//}
emails := make([]*pb.Email, EMAIL_LIMIT)
err := mongoproxy.FindMany("email", "roleid", m.Data.Id, &emails)
if err != nil {
return nil
}
return emails
}
|