Blame view

src/models/Role.lua 5.26 KB
314bc5df   zhengshouren   提交服务器初始代码
1
2
  local Role = class("Role", require("shared.ModelBase"))
  
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
3
4
  local RolePlugin = import(".RolePlugin")
  local RoleTask = import(".RoleTask")
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
5
6
7
8
  local RoleActivity = import(".RoleActivity")
  local RoleChangeStruct = import(".RoleChangeStruct")
  RolePlugin.bind(Role)
  RoleTask.bind(Role)
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
9
10
11
  RoleActivity.bind(Role)
  RoleChangeStruct.bind(Role)
  
314bc5df   zhengshouren   提交服务器初始代码
12
13
  function Role:ctor( properties )
  	Role.super.ctor(self, properties)
314bc5df   zhengshouren   提交服务器初始代码
14
  	self.ignoreHeartbeat = false
0a07bdd9   zhouahaihai   角色升级 。gm
15
  	self.heros = {}
43cc5f51   gaofengduan   调整 equip 数据结构
16
17
  	self.equipBag = {}
  	self.runeBag = {}
46fac6f1   zhouahaihai   酱料
18
  	self.advData = nil
314bc5df   zhengshouren   提交服务器初始代码
19
20
21
  end
  
  Role.schema = {
314bc5df   zhengshouren   提交服务器初始代码
22
23
  	id 					= {"number"},
  	uid 				= {"string", ""},
314bc5df   zhengshouren   提交服务器初始代码
24
  	name 				= {"string", ""},
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
25
26
27
28
  	sid 				= {"number", 0},
  	device 				= {"string", ""},
  	banTime 			= {"number", 0},
  	banType 			= {"number", 0},
0a07bdd9   zhouahaihai   角色升级 。gm
29
30
31
32
  	ltime 				= {"number", 0}, -- 最后登录时间
  	ctime 				= {"number", skynet.timex()},  -- 创建时间
  	ignoreMt			= {"number", 0},  -- 忽略维护拦截
  	sversion			= {"number", globalCsv.StructVersion or 0}, -- 重整数据版本
312b9db5   zhouahaihai   背包
33
34
  	diamond				= {"number", 0},
  	reDiamond			= {"number", 0},
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
35
  	-- roleInfo
4b7c7c96   zhouahaihai   增加 清空 挂机 冒险gm 角色经验
36
37
  	level 				= {"number", 1},
  	exp 				= {"number", 0},
6947e382   zhouahaihai   好感度, 皮肤
38
39
  	items				= {"string", ""},
  	loveStatus			= {"string", ""}, --统计角色的最高 好感度等级 类型相关 -- type=loveL type=loveL
37037eeb   zhengshouren   计算奖励
40
  	crown				= {"number", 0},	-- 看伴娘
314bc5df   zhengshouren   提交服务器初始代码
41
  
312b9db5   zhouahaihai   背包
42
43
  	bagLimit 			= {"table", globalCsv.store_limit_max},
  
23d89d13   zhouahaihai   冒险 结构
44
45
  	--冒险相关
  	advPass				= {"string", ""}, -- 通关记录
46fac6f1   zhouahaihai   酱料
46
47
48
  	advItems			= {"string", ""}, -- 冒险临时背包
  	advInfo				= {"table", {}}, -- 冒险关卡信息
  	advTeam				= {"table", {}}, -- 冒险玩家队伍信息
9ad697c8   zhouahaihai   删除 fields ,增加数据库...
49
  
384bb077   zhouahaihai   挂机
50
51
52
53
54
  	--挂机相关
  	hangPass 			= {"table", {}}, -- 挂机通过的最大关卡
  	hangTeam 			= {"table", {}}, -- 挂机队伍
  	hangInfo			= {"table", {}},  -- 当前挂机信息
  	hangBag				= {"table", {}},	-- 背包
9962b061   zhouahaihai   补充 挂机
55
  	hangBagLimit 		= {"number", globalCsv.idle_field_origin}, --背包上限
384bb077   zhouahaihai   挂机
56
  
dbd0ca58   gaofengduan   car  营养剂制作
57
  	potionBag			= {"table", {}},	-- 营养剂背包
314bc5df   zhengshouren   提交服务器初始代码
58
59
  }
  
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
60
  
0a07bdd9   zhouahaihai   角色升级 。gm
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
  function Role:notifyUpdateProperty(field, newValue, oldValue, extraValue)
  	local updateData = {
  		{
  			key = field,
  			newValue = newValue,
  			oldValue = oldValue or "",
  			extraValue = extraValue,
  		}
  	}
  
  	SendPacket(actionCodes.Role_updateProperty, MsgPack.pack(updateData))
  end
  
  function Role:updateProperty(params)
  	params = params or {}
23d89d13   zhouahaihai   冒险 结构
76
  	if not self.schema[params.field] then return end
0a07bdd9   zhouahaihai   角色升级 。gm
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
  	local oldValue = self:getProperty(params.field)
  	local ret = {key = params.field, oldValue = oldValue}
  	if params.value then
  		ret.newValue = params.value
  		self:setProperty(params.field, params.value)
  	elseif params.delta then
  		self:incrProperty(params.field, params.delta)
  		ret.newValue = self:getProperty(params.field)
  	else
  		return
  	end
  	if not params.notNotify then
  		SendPacket(actionCodes.Role_updateProperty, MsgPack.pack({ret}))
  	end
  end
  
  function Role:updateProperties(params, notNotify)
  	for field, value in pairs(params) do
  		self:setProperty(field, value)
  	end
  	if not notNotify then
  		SendPacket(actionCodes.Role_updateProperties, MsgPack.pack(params))
  	end
  end
  
  function Role:notifyUpdateProperties(params)
  	SendPacket(actionCodes.Role_updateProperties, MsgPack.pack(params))
  end
  
23d89d13   zhouahaihai   冒险 结构
106
  -- 某些字段 更新改变量 改变量的定义由字段自身决定 {{type = ""}, }
6947e382   zhouahaihai   好感度, 皮肤
107
108
109
110
111
112
  function Role:changeUpdates(params, notNotify)
  	local changeUpdateFunc = {
  		["loveStatus"] = function(info)
  			self:setProperty("loveStatus", self:getProperty("loveStatus"):setv(info["field"], info["value"]))
  			return {type = "loveStatus", field = info["field"], value = info["value"]}
  		end,
23d89d13   zhouahaihai   冒险 结构
113
114
115
116
117
118
  		--table 类型通用更新
  		["tableCommon"] = function(fieldType, info)
  			if self.class.schema[fieldType][1] ~= "table" then
  				error("[ERROR:] need handler for changeUpdate, field : " .. fieldType)
  				return
  			end
dbd0ca58   gaofengduan   car  营养剂制作
119
  			--支持多深度单字段
23d89d13   zhouahaihai   冒险 结构
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
  			local curValue = self:getProperty(fieldType)
  			if type(info["field"]) == "table" then
  				for _idx, _field in ipairs(info["field"]) do
  					if _idx < #info["field"] then
  						curValue[_field] = curValue[_field] or {}
  						curValue = curValue[_field]
  					else
  						curValue[_field] = info["value"]
  					end
  				end
  			else
  				curValue[info["field"]] = info["value"]
  			end
  			self:setProperty(fieldType)
  			return {type = fieldType, field = info["field"], value = info["value"]}
  		end,
6947e382   zhouahaihai   好感度, 皮肤
136
  	}
0a07bdd9   zhouahaihai   角色升级 。gm
137
  
6947e382   zhouahaihai   好感度, 皮肤
138
139
140
141
142
  	local updates = {}
  	for _, one in ipairs(params) do
  		if changeUpdateFunc[one["type"]] then
  			table.insert(updates, changeUpdateFunc[one["type"]](one))
  		else
23d89d13   zhouahaihai   冒险 结构
143
  			table.insert(updates, changeUpdateFunc["tableCommon"](one["type"], one))
6947e382   zhouahaihai   好感度, 皮肤
144
145
146
147
148
149
  		end
  	end
  	if not notNotify and next(updates) then
  		SendPacket(actionCodes.Role_changeUpdate, MsgPack.pack(updates))
  	end
  end
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
150
  
314bc5df   zhengshouren   提交服务器初始代码
151
152
153
  function Role:data()
  	return {
  		id = self:getProperty("id"),
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
154
155
  		name = self:getProperty("name"),
  		level = self:getProperty("level"),
4b7c7c96   zhouahaihai   增加 清空 挂机 冒险gm 角色经验
156
  		exp = self:getProperty("exp"),
be83d162   zhouahaihai   登陆成功。 增加数据结构修正功能
157
  		items = self:getProperty("items"):toNumMap(),
6947e382   zhouahaihai   好感度, 皮肤
158
  		loveStatus = self:getProperty("loveStatus"):toNumMap(),
312b9db5   zhouahaihai   背包
159
160
  		diamond = self:getAllDiamond(),
  		bagLimit = self:getProperty("bagLimit"),
dbd0ca58   gaofengduan   car  营养剂制作
161
  
23d89d13   zhouahaihai   冒险 结构
162
163
  		advPass = self:getProperty("advPass"),
  		advInfo = self:getProperty("advInfo"),
46fac6f1   zhouahaihai   酱料
164
  		advItems = self:getProperty("advItems"):toNumMap(),
36c30c5c   zhouahaihai   冒险
165
  		advTeam = self:getProperty("advTeam"),
384bb077   zhouahaihai   挂机
166
167
168
169
170
171
  
  		hangPass = self:getProperty("hangPass"),
  		hangTeam = self:getProperty("hangTeam"),
  		hangInfo = self:getProperty("hangInfo"),
  		hangBag = self:getProperty("hangBag"),
  		hangBagLimit = self:getProperty("hangBagLimit"),
dbd0ca58   gaofengduan   car  营养剂制作
172
173
  
  		potionBag = self:getProperty("potionBag"),
314bc5df   zhengshouren   提交服务器初始代码
174
175
176
177
  	}
  end
  
  return Role