BattleMainComp.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. using System.Collections;
  2. using Api;
  3. using Game;
  4. using HttpApi;
  5. using Message;
  6. using Newtonsoft.Json;
  7. using Sound;
  8. using TMPro;
  9. using UI;
  10. using UnityEngine;
  11. namespace Comp
  12. {
  13. public class BattleMainComp : MonoBehaviour
  14. {
  15. public GameObject mainCamera;
  16. public GameObject resultPanel;
  17. public TextMeshProUGUI localName, antiName;
  18. public volatile bool end = false;
  19. private bool _debug = false; // 是否单机测试模式
  20. private void Start()
  21. {
  22. SoundCore.Instance.PlaySound(SoundType.BattleBgmMain, SoundCtrl.BattleBgmPlayer, true, true);
  23. MessageComp.Instance.OnBattleClientMsg += OnClientMsg;
  24. #if UNITY_EDITOR
  25. _debug = true;
  26. #endif
  27. if (_debug)
  28. {
  29. var logs =
  30. "{\"fromPlayer\":100020,\"fromPlayerHp\":210,\"toPlayerHp\":210,\"toPlayer\":100019,\"fromCock\":1,\"toCock\":1,\"winPlayer\":100020,\"lostPlayer\":100019,\"diamond\":200,\"battleCount\":34,\"winPlayerHp\":30,\"logArray\":[{\"index\":33,\"logs\":[{\"id\":33,\"msg\":\"第33回合:玩家[100019]跳起来啄击,玩家[100020]受到24点伤害,剩下30血量\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":24},{\"id\":33,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":0}]},{\"index\":11,\"logs\":[{\"id\":11,\"msg\":\"第11回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下150血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":11,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":17,\"logs\":[{\"id\":17,\"msg\":\"第17回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下150血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":17,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":0}]},{\"index\":20,\"logs\":[{\"id\":20,\"msg\":\"第20回合:玩家[100019]跳起来啄击落空了,玩家[100020]受到0点伤害,剩下126血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0},{\"id\":20,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":27,\"logs\":[{\"id\":27,\"msg\":\"第27回合:玩家[100019]跳起来啄击落空了,玩家[100020]受到0点伤害,剩下78血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0},{\"id\":27,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":29,\"logs\":[{\"id\":29,\"msg\":\"第29回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下54血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":29,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":0}]},{\"index\":4,\"logs\":[{\"id\":4,\"msg\":\"第4回合:玩家[100020]普通啄击落空了,玩家[100019]受到0点伤害,剩下186血量\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":0},{\"id\":4,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":18,\"logs\":[{\"id\":18,\"msg\":\"第18回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下138血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":18,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":23,\"logs\":[{\"id\":23,\"msg\":\"第23回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下90血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":23,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":28,\"logs\":[{\"id\":28,\"msg\":\"第28回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下66血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":28,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":34,\"logs\":[{\"id\":34,\"msg\":\"第34回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下-6血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":34,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":6,\"logs\":[{\"id\":6,\"msg\":\"第6回合:玩家[100019]跳起来啄击落空了,玩家[100020]受到0点伤害,剩下198血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0},{\"id\":6,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":21,\"logs\":[{\"id\":21,\"msg\":\"第21回合:玩家[100019]跳起来啄击,玩家[100020]受到24点伤害,剩下102血量\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":24},{\"id\":21,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":24,\"logs\":[{\"id\":24,\"msg\":\"第24回合:玩家[100020]跳起来啄击,玩家[100019]受到24点伤害,剩下66血量\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":24},{\"id\":24,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":32,\"logs\":[{\"id\":32,\"msg\":\"第32回合:玩家[100020]普通啄击落空了,玩家[100019]受到0点伤害,剩下6血量\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":0},{\"id\":32,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":3,\"logs\":[{\"id\":3,\"msg\":\"第3回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下186血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":3,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":15,\"logs\":[{\"id\":15,\"msg\":\"第15回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下114血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":15,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":16,\"logs\":[{\"id\":16,\"msg\":\"第16回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下102血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":16,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":12,\"logs\":[{\"id\":12,\"msg\":\"第12回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下138血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":12,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":14,\"logs\":[{\"id\":14,\"msg\":\"第14回合:玩家[100019]跳起来啄击,玩家[100020]受到24点伤害,剩下162血量\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":24},{\"id\":14,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":0}]},{\"index\":19,\"logs\":[{\"id\":19,\"msg\":\"第19回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下126血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":19,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":22,\"logs\":[{\"id\":22,\"msg\":\"第22回合:玩家[100019]跳起来啄击,玩家[100020]受到24点伤害,剩下78血量\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":24},{\"id\":22,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":25,\"logs\":[{\"id\":25,\"msg\":\"第25回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下54血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":25,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":1,\"logs\":[{\"id\":1,\"msg\":\"第1回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下198血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":1,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":5,\"logs\":[{\"id\":5,\"msg\":\"第5回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下198血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":5,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":9,\"logs\":[{\"id\":9,\"msg\":\"第9回合:玩家[100019]普通啄击,玩家[100020]受到12点伤害,剩下186血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":12},{\"id\":9,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":26,\"logs\":[{\"id\":26,\"msg\":\"第26回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下42血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":26,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":30,\"logs\":[{\"id\":30,\"msg\":\"第30回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下30血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":30,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":2,\"logs\":[{\"id\":2,\"msg\":\"第2回合:玩家[100020]跳起来啄击落空了,玩家[100019]受到0点伤害,剩下198血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0},{\"id\":2,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":7,\"logs\":[{\"id\":7,\"msg\":\"第7回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下174血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":7,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0}]},{\"index\":8,\"logs\":[{\"id\":8,\"msg\":\"第8回合:玩家[100019]跳起来啄击落空了,玩家[100020]受到0点伤害,剩下198血量\",\"from\":100019,\"to\":100020,\"type\":1,\"value\":0},{\"id\":8,\"msg\":\"\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":0}]},{\"index\":10,\"logs\":[{\"id\":10,\"msg\":\"第10回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下162血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":10,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":13,\"logs\":[{\"id\":13,\"msg\":\"第13回合:玩家[100020]普通啄击,玩家[100019]受到12点伤害,剩下126血量\",\"from\":100020,\"to\":100019,\"type\":1,\"value\":12},{\"id\":13,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]},{\"index\":31,\"logs\":[{\"id\":31,\"msg\":\"第31回合:玩家[100020]跳起来啄击,玩家[100019]受到24点伤害,剩下6血量\",\"from\":100020,\"to\":100019,\"type\":2,\"value\":24},{\"id\":31,\"msg\":\"\",\"from\":100019,\"to\":100020,\"type\":2,\"value\":0}]}],\"dbId\":0}";
  31. var obj = JsonConvert.DeserializeObject<BattleDetailListObj>(logs);
  32. StartCoroutine(StartGame(obj));
  33. }
  34. else
  35. {
  36. localName.text = AccountManager.Instance.selfInfo.name;
  37. ApiComp.Instance.GetBattleDetail(GameCore.Instance.curBattleSession,
  38. (obj) => { StartCoroutine(StartGame(obj)); }, (code, msg) =>
  39. {
  40. // TODO Do nothing
  41. Debug.LogWarning("request battle err " + msg);
  42. });
  43. }
  44. }
  45. // ReSharper disable Unity.PerformanceAnalysis
  46. private IEnumerator StartGame(BattleDetailListObj obj)
  47. {
  48. Debug.Log("Debug模式 " + _debug);
  49. var localPlayerId = _debug ? obj.fromPlayer : AccountManager.Instance.selfInfo.playerId; // 兼容测试模式
  50. GamePlayer localPlayer, antiPlayer;
  51. if (localPlayerId == obj.fromPlayer)
  52. {
  53. localPlayer = new GamePlayer()
  54. { cockId = obj.fromCock, playerId = obj.fromPlayer, hp = obj.fromPlayerHp };
  55. antiPlayer = new GamePlayer() { cockId = obj.toCock, playerId = obj.toPlayer, hp = obj.toPlayerHp };
  56. }
  57. else
  58. {
  59. localPlayer = new GamePlayer() { cockId = obj.toCock, playerId = obj.toPlayer, hp = obj.toPlayerHp };
  60. antiPlayer = new GamePlayer()
  61. { cockId = obj.fromCock, playerId = obj.fromPlayer, hp = obj.fromPlayerHp };
  62. }
  63. Debug.Log("local player is " + localPlayer.playerId + "==== anti player is " + antiPlayer.playerId);
  64. ApiComp.Instance.QueryPlayerInfo(antiPlayer.playerId, (data) => { antiName.text = data.name; },
  65. (code, msg) => { antiName.text = "net error"; });
  66. GameCore.Instance.Init(localPlayer, antiPlayer, gameObject, mainCamera, obj, resultPanel);
  67. yield return new WaitForEndOfFrame();
  68. }
  69. private void OnClientMsg(int playerId, MsgContent content)
  70. {
  71. if (content.contentType == "lift")
  72. {
  73. Debug.Log("接收lift");
  74. GameCore.Instance.GetCurState().LiftCock();
  75. }
  76. }
  77. public void Lift()
  78. {
  79. Debug.Log("click lift");
  80. // GameCore.Instance.TransitionToState(GameCore.Instance.endState);
  81. ApiComp.Instance.MsgInBattle(GameCore.Instance.curBattleSession, new MsgContent() { contentType = "lift" });
  82. GameCore.Instance.GetCurState().LiftCock();
  83. }
  84. public void ClickResult()
  85. {
  86. Debug.Log("Click result");
  87. GameStartJumper.BackToUI();
  88. // 获取当前场景
  89. // var currentScene = SceneManager.GetActiveScene();
  90. // // 关闭当前场景
  91. // SceneManager.UnloadSceneAsync(currentScene);
  92. }
  93. private void Update()
  94. {
  95. if (end)
  96. {
  97. end = false;
  98. StartCoroutine(End());
  99. }
  100. }
  101. private IEnumerator End()
  102. {
  103. yield return new WaitForSeconds(2f);
  104. GameCore.Instance.TransitionToState(GameCore.Instance.endState);
  105. }
  106. }
  107. }