Compare commits
No commits in common. "07e252aa1dcc8c18807ec36be6b6af89b0db6353" and "92b17fdee9c32017822623f9c9c5959fa7725e58" have entirely different histories.
07e252aa1d
...
92b17fdee9
|
@ -20,8 +20,6 @@ type FortuneDragonPlayerData struct {
|
||||||
winCoin int64
|
winCoin int64
|
||||||
currentLogId string
|
currentLogId string
|
||||||
totalBet int64
|
totalBet int64
|
||||||
|
|
||||||
isFree bool //只用于判断是否可以离开
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *FortuneDragonPlayerData) init() {
|
func (p *FortuneDragonPlayerData) init() {
|
||||||
|
|
|
@ -1,14 +1,10 @@
|
||||||
package fortunedragon
|
package fortunedragon
|
||||||
|
|
||||||
import (
|
import "mongo.games.com/game/gamesrv/base"
|
||||||
"mongo.games.com/game/gamesrv/base"
|
|
||||||
"mongo.games.com/game/gamesrv/slotspkg/assemble"
|
|
||||||
)
|
|
||||||
|
|
||||||
type FortuneDragonSceneData struct {
|
type FortuneDragonSceneData struct {
|
||||||
*base.Scene //场景
|
*base.Scene //场景
|
||||||
players map[int32]*FortuneDragonPlayerData //玩家信息
|
players map[int32]*FortuneDragonPlayerData //玩家信息
|
||||||
BetConfig *assemble.BetConfig
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewFortuneDragonSceneData(s *base.Scene) *FortuneDragonSceneData {
|
func NewFortuneDragonSceneData(s *base.Scene) *FortuneDragonSceneData {
|
||||||
|
|
|
@ -217,9 +217,6 @@ func FortuneDragonCreateRoomInfoPacket(s *base.Scene, sceneEx *FortuneDragonScen
|
||||||
data := assemble.DataToCli(Response).(assemble.TableInfo)
|
data := assemble.DataToCli(Response).(assemble.TableInfo)
|
||||||
pi, _ := json.Marshal(data)
|
pi, _ := json.Marshal(data)
|
||||||
pack.PlayerInfo = string(pi)
|
pack.PlayerInfo = string(pi)
|
||||||
if sceneEx.BetConfig == nil {
|
|
||||||
sceneEx.BetConfig = &data.BetConfig
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
logger.Logger.Error("slots enter err:", err)
|
logger.Logger.Error("slots enter err:", err)
|
||||||
}
|
}
|
||||||
|
@ -330,11 +327,11 @@ func (this *SceneStateStartFortuneDragon) CanChangeTo(s base.SceneState) bool {
|
||||||
|
|
||||||
// 当前状态能否换桌
|
// 当前状态能否换桌
|
||||||
func (this *SceneStateStartFortuneDragon) CanChangeCoinScene(s *base.Scene, p *base.Player) bool {
|
func (this *SceneStateStartFortuneDragon) CanChangeCoinScene(s *base.Scene, p *base.Player) bool {
|
||||||
if playerEx, ok := p.GetExtraData().(*FortuneDragonPlayerData); ok {
|
//if playerEx, ok := p.GetExtraData().(*FortuneDragonPlayerData); ok {
|
||||||
if playerEx.isFree {
|
// if playerEx.IsOnLine() {
|
||||||
return false
|
// return false
|
||||||
}
|
// }
|
||||||
}
|
//}
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -378,22 +375,12 @@ func (this *SceneStateStartFortuneDragon) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
playerEx.BetSizeIndex = params[0]
|
playerEx.BetSizeIndex = params[0]
|
||||||
playerEx.BetLevelIndex = params[1]
|
playerEx.BetLevelIndex = params[1]
|
||||||
playerEx.BetLineIndex = params[2]
|
playerEx.BetLineIndex = params[2]
|
||||||
needCoin := sceneEx.BetConfig.BetSize[params[0]] * float64(sceneEx.BetConfig.BetLevel[params[1]]) *
|
|
||||||
float64(sceneEx.BetConfig.BetLines[params[2]])
|
|
||||||
if needCoin/10000 > float64(playerEx.Coin) {
|
|
||||||
pack := &protocol.SCFortuneDragonBilled{
|
|
||||||
OpRetCode: proto.Int32(1),
|
|
||||||
}
|
|
||||||
proto.SetDefaults(pack)
|
|
||||||
logger.Logger.Trace("SCFortuneDragonBilled:", pack.String())
|
|
||||||
playerEx.SendToClient(int(protocol.FortuneDragonPID_PACKET_FORTUNEDRAGON_SCFORTUNEDRAGONBILLED), pack)
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
playerEx.BetMode = params[3]
|
playerEx.BetMode = params[3]
|
||||||
|
|
||||||
|
logger.Logger.Trace("playerEx.Coin", playerEx.Coin)
|
||||||
playerEx.SlotsSession.SetCoin(playerEx.Coin * fortunedragon.NowByte)
|
playerEx.SlotsSession.SetCoin(playerEx.Coin * fortunedragon.NowByte)
|
||||||
|
|
||||||
|
logger.Logger.Trace("coin.... ", playerEx.SlotsSession.Coin())
|
||||||
//get data
|
//get data
|
||||||
Response, err := slots.SlotsMgrSington.Play(playerEx.SlotsSession, &base.SpinReq{
|
Response, err := slots.SlotsMgrSington.Play(playerEx.SlotsSession, &base.SpinReq{
|
||||||
GameId: int64(sceneEx.GameId),
|
GameId: int64(sceneEx.GameId),
|
||||||
|
@ -408,6 +395,7 @@ func (this *SceneStateStartFortuneDragon) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
if err == nil {
|
if err == nil {
|
||||||
data = assemble.DataToCli(Response).(assemble.GameEnd)
|
data = assemble.DataToCli(Response).(assemble.GameEnd)
|
||||||
if data.Results[0].FreeStatus == 1 || data.Results[0].FreeNumMax == 0 {
|
if data.Results[0].FreeStatus == 1 || data.Results[0].FreeNumMax == 0 {
|
||||||
|
logger.Logger.Error("bet....", -data.TotalBet)
|
||||||
//第一次触发或者正常模式
|
//第一次触发或者正常模式
|
||||||
playerEx.AddCoin(int64(-data.TotalBet), common.GainWay_HundredSceneLost, base.SyncFlag_ToClient, "system", s.GetSceneName())
|
playerEx.AddCoin(int64(-data.TotalBet), common.GainWay_HundredSceneLost, base.SyncFlag_ToClient, "system", s.GetSceneName())
|
||||||
playerEx.totalBet = int64(data.TotalBet)
|
playerEx.totalBet = int64(data.TotalBet)
|
||||||
|
@ -429,6 +417,7 @@ func (this *SceneStateStartFortuneDragon) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
gameEndStr = string(pi)
|
gameEndStr = string(pi)
|
||||||
|
|
||||||
if data.Results[0].FreeStatus == 3 || data.Results[0].FreeNumMax == 0 {
|
if data.Results[0].FreeStatus == 3 || data.Results[0].FreeNumMax == 0 {
|
||||||
|
logger.Logger.Error("win....", data.RoundReward)
|
||||||
playerEx.AddCoin(int64(data.RoundReward), common.GainWay_HundredSceneWin, 0, "system", s.GetSceneName())
|
playerEx.AddCoin(int64(data.RoundReward), common.GainWay_HundredSceneWin, 0, "system", s.GetSceneName())
|
||||||
//免费游戏结束或者正常模式
|
//免费游戏结束或者正常模式
|
||||||
sceneEx.StaticsLaba(&base.StaticLabaParam{
|
sceneEx.StaticsLaba(&base.StaticLabaParam{
|
||||||
|
@ -438,11 +427,6 @@ func (this *SceneStateStartFortuneDragon) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
IsAddTimes: true,
|
IsAddTimes: true,
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
if data.Results[0].FreeNum > 0 {
|
|
||||||
playerEx.isFree = true
|
|
||||||
} else {
|
|
||||||
playerEx.isFree = false
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
logger.Logger.Error("slots Play err:", err)
|
logger.Logger.Error("slots Play err:", err)
|
||||||
}
|
}
|
||||||
|
@ -459,7 +443,7 @@ func (this *SceneStateStartFortuneDragon) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
}
|
}
|
||||||
|
|
||||||
// 记录本次操作
|
// 记录本次操作
|
||||||
FortuneDragonAndSaveLog(sceneEx, playerEx, data)
|
FortunedragonAndSaveLog(sceneEx, playerEx, data)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -494,7 +478,7 @@ func (this *ScenePolicyFortuneDragon) GetSceneState(s *base.Scene, stateid int)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
func FortuneDragonAndSaveLog(sceneEx *FortuneDragonSceneData, playerEx *FortuneDragonPlayerData, data assemble.GameEnd) {
|
func FortunedragonAndSaveLog(sceneEx *FortuneDragonSceneData, playerEx *FortuneDragonPlayerData, data assemble.GameEnd) {
|
||||||
if !playerEx.IsRob {
|
if !playerEx.IsRob {
|
||||||
data.SnId = playerEx.SnId
|
data.SnId = playerEx.SnId
|
||||||
info, err := model.MarshalGameNoteByROLL(data)
|
info, err := model.MarshalGameNoteByROLL(data)
|
||||||
|
|
|
@ -15,22 +15,13 @@ type FortuneRabbitPlayerData struct {
|
||||||
BetLevelIndex int64 `json:"bli"` //选中的等级下标
|
BetLevelIndex int64 `json:"bli"` //选中的等级下标
|
||||||
BetLineIndex int64 `json:"bii"` //选中的线数下标
|
BetLineIndex int64 `json:"bii"` //选中的线数下标
|
||||||
BetMode int64 `json:"bm,optional"` //0.常规 1.必中
|
BetMode int64 `json:"bm,optional"` //0.常规 1.必中
|
||||||
|
|
||||||
taxCoin int64
|
|
||||||
winCoin int64
|
|
||||||
currentLogId string
|
|
||||||
totalBet int64
|
|
||||||
|
|
||||||
isFree bool //只用于判断是否可以离开
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *FortuneRabbitPlayerData) init() {
|
func (p *FortuneRabbitPlayerData) init() {
|
||||||
p.SlotsSession = base.NewSession(uint64(p.SnId), p.Coin*fortunerabbit.NowByte)
|
p.SlotsSession = base.NewSession(uint64(p.SnId), p.Coin*fortunerabbit.NowByte)
|
||||||
}
|
}
|
||||||
func (p *FortuneRabbitPlayerData) Clear() {
|
func (p *FortuneRabbitPlayerData) Clear() {
|
||||||
p.taxCoin = 0
|
|
||||||
p.winCoin = 0
|
|
||||||
p.currentLogId = ""
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 需要带到world上进行数据处理
|
// 需要带到world上进行数据处理
|
||||||
|
|
|
@ -1,14 +1,10 @@
|
||||||
package fortunerabbit
|
package fortunerabbit
|
||||||
|
|
||||||
import (
|
import "mongo.games.com/game/gamesrv/base"
|
||||||
"mongo.games.com/game/gamesrv/base"
|
|
||||||
"mongo.games.com/game/gamesrv/slotspkg/assemble"
|
|
||||||
)
|
|
||||||
|
|
||||||
type FortuneRabbitSceneData struct {
|
type FortuneRabbitSceneData struct {
|
||||||
*base.Scene //场景
|
*base.Scene //场景
|
||||||
players map[int32]*FortuneRabbitPlayerData //玩家信息
|
players map[int32]*FortuneRabbitPlayerData //玩家信息
|
||||||
BetConfig *assemble.BetConfig
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewFortuneRabbitSceneData(s *base.Scene) *FortuneRabbitSceneData {
|
func NewFortuneRabbitSceneData(s *base.Scene) *FortuneRabbitSceneData {
|
||||||
|
|
|
@ -10,7 +10,6 @@ import (
|
||||||
"mongo.games.com/game/model"
|
"mongo.games.com/game/model"
|
||||||
"mongo.games.com/game/proto"
|
"mongo.games.com/game/proto"
|
||||||
protocol "mongo.games.com/game/protocol/fortunerabbit"
|
protocol "mongo.games.com/game/protocol/fortunerabbit"
|
||||||
"mongo.games.com/game/protocol/server"
|
|
||||||
"mongo.games.com/goserver/core"
|
"mongo.games.com/goserver/core"
|
||||||
"mongo.games.com/goserver/core/logger"
|
"mongo.games.com/goserver/core/logger"
|
||||||
"time"
|
"time"
|
||||||
|
@ -110,6 +109,11 @@ func (this *ScenePolicyFortuneRabbit) OnPlayerLeave(s *base.Scene, p *base.Playe
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
logger.Logger.Trace("(this *ScenePolicyFortuneRabbit) OnPlayerLeave, sceneId=", s.GetSceneId(), " player=", p.SnId)
|
logger.Logger.Trace("(this *ScenePolicyFortuneRabbit) OnPlayerLeave, sceneId=", s.GetSceneId(), " player=", p.SnId)
|
||||||
|
if sceneEx, ok := s.ExtraData.(*FortuneRabbitSceneData); ok {
|
||||||
|
s.FirePlayerEvent(p, base.PlayerEventLeave, nil)
|
||||||
|
sceneEx.OnPlayerLeave(p, reason)
|
||||||
|
}
|
||||||
|
|
||||||
if playerEx, ok := p.ExtraData.(*FortuneRabbitPlayerData); ok {
|
if playerEx, ok := p.ExtraData.(*FortuneRabbitPlayerData); ok {
|
||||||
m := playerEx.PushPlayer()
|
m := playerEx.PushPlayer()
|
||||||
if m != nil && len(m) > 0 {
|
if m != nil && len(m) > 0 {
|
||||||
|
@ -126,10 +130,6 @@ func (this *ScenePolicyFortuneRabbit) OnPlayerLeave(s *base.Scene, p *base.Playe
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if sceneEx, ok := s.ExtraData.(*FortuneRabbitSceneData); ok {
|
|
||||||
s.FirePlayerEvent(p, base.PlayerEventLeave, nil)
|
|
||||||
sceneEx.OnPlayerLeave(p, reason)
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// 玩家掉线
|
// 玩家掉线
|
||||||
|
@ -216,9 +216,6 @@ func FortuneRabbitCreateRoomInfoPacket(s *base.Scene, sceneEx *FortuneRabbitScen
|
||||||
data := assemble.DataToCli(Response).(assemble.TableInfo)
|
data := assemble.DataToCli(Response).(assemble.TableInfo)
|
||||||
pi, _ := json.Marshal(data)
|
pi, _ := json.Marshal(data)
|
||||||
pack.PlayerInfo = string(pi)
|
pack.PlayerInfo = string(pi)
|
||||||
if sceneEx.BetConfig == nil {
|
|
||||||
sceneEx.BetConfig = &data.BetConfig
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
logger.Logger.Error("slots enter err:", err)
|
logger.Logger.Error("slots enter err:", err)
|
||||||
}
|
}
|
||||||
|
@ -329,11 +326,11 @@ func (this *SceneStateStartFortuneRabbit) CanChangeTo(s base.SceneState) bool {
|
||||||
|
|
||||||
// 当前状态能否换桌
|
// 当前状态能否换桌
|
||||||
func (this *SceneStateStartFortuneRabbit) CanChangeCoinScene(s *base.Scene, p *base.Player) bool {
|
func (this *SceneStateStartFortuneRabbit) CanChangeCoinScene(s *base.Scene, p *base.Player) bool {
|
||||||
if playerEx, ok := p.GetExtraData().(*FortuneRabbitPlayerData); ok {
|
//if playerEx, ok := p.GetExtraData().(*FortuneRabbitPlayerData); ok {
|
||||||
if playerEx.isFree {
|
// if playerEx.IsOnLine() {
|
||||||
return false
|
// return false
|
||||||
}
|
// }
|
||||||
}
|
//}
|
||||||
return true
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -378,17 +375,6 @@ func (this *SceneStateStartFortuneRabbit) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
playerEx.BetLevelIndex = params[1]
|
playerEx.BetLevelIndex = params[1]
|
||||||
playerEx.BetLineIndex = params[2]
|
playerEx.BetLineIndex = params[2]
|
||||||
//playerEx.BetMode = params[3]
|
//playerEx.BetMode = params[3]
|
||||||
needCoin := sceneEx.BetConfig.BetSize[params[0]] * float64(sceneEx.BetConfig.BetLevel[params[1]]) *
|
|
||||||
float64(sceneEx.BetConfig.BetLines[params[2]])
|
|
||||||
if needCoin/10000 > float64(playerEx.Coin) {
|
|
||||||
pack := &protocol.SCFortuneRabbitBilled{
|
|
||||||
OpRetCode: proto.Int32(1),
|
|
||||||
}
|
|
||||||
proto.SetDefaults(pack)
|
|
||||||
logger.Logger.Trace("SCFortuneRabbitBilled:", pack.String())
|
|
||||||
playerEx.SendToClient(int(protocol.FortuneRabbitPID_PACKET_FORTUNERABBIT_SCFORTUNERABBITBILLED), pack)
|
|
||||||
return true
|
|
||||||
}
|
|
||||||
|
|
||||||
playerEx.SlotsSession.SetCoin(playerEx.Coin * fortunerabbit.NowByte)
|
playerEx.SlotsSession.SetCoin(playerEx.Coin * fortunerabbit.NowByte)
|
||||||
|
|
||||||
|
@ -402,57 +388,14 @@ func (this *SceneStateStartFortuneRabbit) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
Ts: time.Now().Unix(),
|
Ts: time.Now().Unix(),
|
||||||
})
|
})
|
||||||
var gameEndStr string
|
var gameEndStr string
|
||||||
var data assemble.GameEnd
|
|
||||||
if err == nil {
|
if err == nil {
|
||||||
data = assemble.DataToCli(Response).(assemble.GameEnd)
|
data := assemble.DataToCli(Response).(assemble.GameEnd)
|
||||||
if data.Results[0].FreeStatus == 1 || data.Results[0].FreeNumMax == 0 {
|
|
||||||
//第一次触发或者正常模式
|
|
||||||
playerEx.AddCoin(int64(-data.TotalBet), common.GainWay_HundredSceneLost, base.SyncFlag_ToClient, "system", s.GetSceneName())
|
|
||||||
playerEx.totalBet = int64(data.TotalBet)
|
|
||||||
}
|
|
||||||
var taxCoin float64
|
|
||||||
if data.RoundReward > 0 {
|
|
||||||
//税收比例
|
|
||||||
taxRate := sceneEx.GetDBGameFree().GetTaxRate()
|
|
||||||
if taxRate < 0 || taxRate > 10000 {
|
|
||||||
taxRate = 500
|
|
||||||
}
|
|
||||||
taxCoin = data.RoundReward * float64(taxRate) / 10000
|
|
||||||
data.RoundReward = data.RoundReward - taxCoin
|
|
||||||
playerEx.AddServiceFee(int64(taxCoin))
|
|
||||||
playerEx.taxCoin = int64(taxCoin)
|
|
||||||
playerEx.winCoin = int64(data.RoundReward)
|
|
||||||
}
|
|
||||||
pi, _ := json.Marshal(data)
|
pi, _ := json.Marshal(data)
|
||||||
gameEndStr = string(pi)
|
gameEndStr = string(pi)
|
||||||
|
playerEx.Coin = int64(data.FinalCoin)
|
||||||
if data.Results[0].FreeStatus == 3 || data.Results[0].FreeNumMax == 0 {
|
|
||||||
playerEx.AddCoin(int64(data.RoundReward), common.GainWay_HundredSceneWin, 0, "system", s.GetSceneName())
|
|
||||||
//免费游戏结束或者正常模式
|
|
||||||
sceneEx.StaticsLaba(&base.StaticLabaParam{
|
|
||||||
SnId: playerEx.SnId,
|
|
||||||
Gain: int64(data.RoundReward - data.TotalBet),
|
|
||||||
GainTax: int64(taxCoin),
|
|
||||||
IsAddTimes: true,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
if data.Results[0].FreeNum > 0 {
|
|
||||||
playerEx.isFree = true
|
|
||||||
} else {
|
|
||||||
playerEx.isFree = false
|
|
||||||
}
|
|
||||||
|
|
||||||
if data.Results[0].FreeNum > 0 {
|
|
||||||
playerEx.isFree = true
|
|
||||||
} else {
|
|
||||||
playerEx.isFree = false
|
|
||||||
}
|
|
||||||
} else {
|
} else {
|
||||||
logger.Logger.Error("slots Play err:", err)
|
logger.Logger.Error("slots Play err:", err)
|
||||||
}
|
}
|
||||||
if playerEx.Coin != int64(data.FinalCoin) {
|
|
||||||
logger.Logger.Error("==========playerEx.Coin != Response.Coin==============", playerEx.Coin, data.FinalCoin)
|
|
||||||
}
|
|
||||||
pack := &protocol.SCFortuneRabbitBilled{
|
pack := &protocol.SCFortuneRabbitBilled{
|
||||||
OpRetCode: proto.Int32(0),
|
OpRetCode: proto.Int32(0),
|
||||||
GameEndStr: proto.String(gameEndStr),
|
GameEndStr: proto.String(gameEndStr),
|
||||||
|
@ -460,9 +403,6 @@ func (this *SceneStateStartFortuneRabbit) OnPlayerOp(s *base.Scene, p *base.Play
|
||||||
proto.SetDefaults(pack)
|
proto.SetDefaults(pack)
|
||||||
logger.Logger.Trace("SCFortuneRabbitBilled", pack.String())
|
logger.Logger.Trace("SCFortuneRabbitBilled", pack.String())
|
||||||
playerEx.SendToClient(int(protocol.FortuneRabbitPID_PACKET_FORTUNERABBIT_SCFORTUNERABBITBILLED), pack)
|
playerEx.SendToClient(int(protocol.FortuneRabbitPID_PACKET_FORTUNERABBIT_SCFORTUNERABBITBILLED), pack)
|
||||||
|
|
||||||
// 记录本次操作
|
|
||||||
FortuneRabbitAndSaveLog(sceneEx, playerEx, data)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -497,66 +437,7 @@ func (this *ScenePolicyFortuneRabbit) GetSceneState(s *base.Scene, stateid int)
|
||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
func FortuneRabbitAndSaveLog(sceneEx *FortuneRabbitSceneData, playerEx *FortuneRabbitPlayerData, data assemble.GameEnd) {
|
|
||||||
if !playerEx.IsRob {
|
|
||||||
data.SnId = playerEx.SnId
|
|
||||||
info, err := model.MarshalGameNoteByROLL(data)
|
|
||||||
if err == nil {
|
|
||||||
logid, _ := model.AutoIncGameLogId()
|
|
||||||
playerEx.currentLogId = logid
|
|
||||||
sceneEx.SaveGameDetailedLog(logid, info, &base.GameDetailedParam{})
|
|
||||||
totalin := playerEx.totalBet
|
|
||||||
totalout := int64(data.RoundReward) + playerEx.taxCoin + totalin
|
|
||||||
validFlow := totalin + totalout
|
|
||||||
validBet := common.AbsI64(totalin - totalout)
|
|
||||||
logParam := &base.SaveGamePlayerListLogParam{
|
|
||||||
Platform: playerEx.Platform,
|
|
||||||
Channel: playerEx.Channel,
|
|
||||||
Promoter: playerEx.BeUnderAgentCode,
|
|
||||||
PackageTag: playerEx.PackageID,
|
|
||||||
InviterId: playerEx.InviterId,
|
|
||||||
LogId: logid,
|
|
||||||
TotalIn: totalin,
|
|
||||||
TotalOut: totalout,
|
|
||||||
TaxCoin: playerEx.taxCoin,
|
|
||||||
BetAmount: playerEx.totalBet,
|
|
||||||
WinAmountNoAnyTax: int64(data.RoundReward) + playerEx.taxCoin,
|
|
||||||
ValidBet: validBet,
|
|
||||||
ValidFlow: validFlow,
|
|
||||||
IsFirstGame: sceneEx.IsPlayerFirst(playerEx.Player),
|
|
||||||
}
|
|
||||||
sceneEx.SaveGamePlayerListLog(playerEx.SnId, logParam)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
//统计输下注金币数
|
|
||||||
if !sceneEx.Testing && !playerEx.IsRob {
|
|
||||||
playerBet := &server.PlayerData{
|
|
||||||
SnId: proto.Int32(playerEx.SnId),
|
|
||||||
Bet: proto.Int64(playerEx.CurrentBet),
|
|
||||||
Gain: proto.Int64(int64(data.RoundReward) + playerEx.taxCoin),
|
|
||||||
Tax: proto.Int64(playerEx.taxCoin),
|
|
||||||
Coin: proto.Int64(playerEx.GetCoin()),
|
|
||||||
GameCoinTs: proto.Int64(playerEx.GameCoinTs),
|
|
||||||
}
|
|
||||||
gwPlayerBet := &server.GWPlayerData{
|
|
||||||
SceneId: sceneEx.SceneId,
|
|
||||||
GameFreeId: proto.Int32(sceneEx.GetDBGameFree().GetId()),
|
|
||||||
}
|
|
||||||
gwPlayerBet.Datas = append(gwPlayerBet.Datas, playerBet)
|
|
||||||
sceneEx.SyncPlayerDatas(&base.PlayerDataParam{
|
|
||||||
HasRobotGaming: false,
|
|
||||||
Data: gwPlayerBet,
|
|
||||||
})
|
|
||||||
}
|
|
||||||
|
|
||||||
playerEx.taxCoin = 0
|
|
||||||
playerEx.winCoin = 0
|
|
||||||
|
|
||||||
if sceneEx.CheckNeedDestroy() && data.Results[0].FreeNum <= 0 {
|
|
||||||
sceneEx.PlayerLeave(playerEx.Player, common.PlayerLeaveReason_OnDestroy, true)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
func init() {
|
func init() {
|
||||||
//主状态
|
//主状态
|
||||||
ScenePolicyFortuneRabbitSington.RegisteSceneState(&SceneStateStartFortuneRabbit{})
|
ScenePolicyFortuneRabbitSington.RegisteSceneState(&SceneStateStartFortuneRabbit{})
|
||||||
|
|
Loading…
Reference in New Issue