LoadingViewComp.ts 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205
  1. /*
  2. * @Author: mojunshou 1637302775@qq.com
  3. * @Date: 2025-03-19 16:23:51
  4. * @LastEditors: mojunshou 1637302775@qq.com
  5. * @LastEditTime: 2025-05-07 14:32:07
  6. * @Description: loading界面
  7. */
  8. import { _decorator, Toggle } from "cc";
  9. import { DeviceUtil } from "db://oops-framework/core/utils/DeviceUtil";
  10. import { ModuleUtil } from "db://oops-framework/module/common/ModuleUtil";
  11. import { oops } from "../../../../../extensions/oops-plugin-framework/assets/core/Oops";
  12. import { ecs } from "../../../../../extensions/oops-plugin-framework/assets/libs/ecs/ECS";
  13. import { CCVMParentComp } from "../../../../../extensions/oops-plugin-framework/assets/module/common/CCVMParentComp";
  14. import { AndroidEvent } from "../../common/config/AndroidEvent";
  15. import { AD_TYPE } from "../../common/config/GameDefine";
  16. import { GameEvent } from "../../common/config/GameEvent";
  17. import { UIID } from "../../common/config/GameUIConfig";
  18. import { ADHandler } from "../../common/manager/ADHandler";
  19. import { LoginHandler } from "../../common/manager/LoginHandler";
  20. import { smc } from "../../common/SingletonModuleComp";
  21. import { EliminateViewComp } from "../../view/EliminateViewComp";
  22. // import { EliminateView } from "../../view/eliminate/EliminateView";
  23. const { ccclass, property } = _decorator;
  24. /** 游戏资源加载 */
  25. @ccclass('LoadingViewComp')
  26. @ecs.register('LoadingView', false)
  27. export class LoadingViewComp extends CCVMParentComp {
  28. /** VM 组件绑定数据 */
  29. data: any = {
  30. /** 加载资源当前进度 */
  31. finished: 0,
  32. /** 加载资源最大进度 */
  33. total: 0,
  34. /** 加载资源进度比例值 */
  35. progress: "0",
  36. /** 加载流程中提示文本 */
  37. prompt: "",
  38. };
  39. private progress: number = 0;
  40. start() {
  41. this.enter();
  42. this.addEvent();
  43. this.setButton();
  44. this.updateToggleState();
  45. }
  46. private addEvent() {
  47. this.on(AndroidEvent.AgreePrivacy, this.onAgreePrivacy, this);
  48. this.on(GameEvent.WechatLoginSuss, this.loginSuss, this)
  49. this.on(GameEvent.UserLogin, this.userLogin, this);
  50. }
  51. async enter() {
  52. if (DeviceUtil.isNative && DeviceUtil.isAndroid) {
  53. await LoginHandler.inst.getVersionStatus()
  54. const state = await LoginHandler.inst.getPrivacyStatus();
  55. if (state.data.result) {
  56. //同意之后都加载一次启屏广告
  57. // CocosHandler.inst.ad_interstitial_start();
  58. ADHandler.inst.showAd(AD_TYPE.Start);
  59. } else {
  60. oops.gui.open(UIID.KindTips);
  61. }
  62. } else {
  63. //非原生,网页的
  64. this.setWxLoginBtnState(false);
  65. this.loadRes();
  66. }
  67. }
  68. private userLogin() {
  69. const isLogin = smc.account.AccountModel.isLogined;
  70. if (isLogin) {
  71. //登录过
  72. this.setWxLoginBtnState(false);
  73. this.loadRes();
  74. } else {
  75. this.setWxLoginBtnState(true);
  76. }
  77. }
  78. private loginSuss() {
  79. this.setWxLoginBtnState(false);
  80. this.loadRes();
  81. }
  82. private onAgreePrivacy() {
  83. oops.storage.set("agree", true);
  84. oops.gui.remove(UIID.KindTips);
  85. //如果是客户端就显示微信登录按钮
  86. if (DeviceUtil.isNative && DeviceUtil.isAndroid) {
  87. //const show
  88. this.setWxLoginBtnState(true);
  89. //
  90. } else {
  91. this.loadRes();
  92. }
  93. }
  94. /** 加载资源 */
  95. private async loadRes() {
  96. this.data.progress = 0;
  97. await this.loadCustom();
  98. this.loadGameRes();
  99. }
  100. /** 加载游戏本地JSON数据(自定义内容) */
  101. private loadCustom() {
  102. // 加载游戏本地JSON数据的多语言提示文本
  103. this.data.prompt = oops.language.getLangByID("loading_load_json");
  104. }
  105. /** 加载初始游戏内容资源 */
  106. private loadGameRes() {
  107. // 加载初始游戏内容资源的多语言提示文本
  108. this.data.prompt = oops.language.getLangByID("loading_load_game");
  109. oops.res.loadDir("game", this.onProgressCallback.bind(this), this.onCompleteCallback.bind(this));
  110. }
  111. /** 加载进度事件 */
  112. private onProgressCallback(finished: number, total: number, item: any) {
  113. this.data.finished = finished;
  114. this.data.total = total;
  115. var progress = finished / total;
  116. if (progress > this.progress) {
  117. this.progress = progress;
  118. this.data.progress = (progress * 100).toFixed(2);
  119. }
  120. }
  121. /** 加载完成事件 */
  122. private async onCompleteCallback() {
  123. this.data.finished = 1;
  124. this.data.total = 1;
  125. this.data.progress = 100;
  126. // 获取用户信息的多语言提示文本
  127. this.data.prompt = oops.language.getLangByID("loading_load_player");
  128. await ModuleUtil.addViewUiAsync(smc.account, EliminateViewComp, UIID.Eliminate);
  129. ModuleUtil.removeViewUi(this.ent, LoadingViewComp, UIID.Loading);
  130. }
  131. /**
  132. * @description: 微信登录
  133. * @return {*}
  134. */
  135. private btn_wxlogin() {
  136. //是否同意了我们的隐私政策
  137. const agree = oops.storage.getBoolean("agree");
  138. if (!agree) {
  139. oops.gui.toast("请同意隐私政策")
  140. return;
  141. }
  142. LoginHandler.inst.wechatLogin();
  143. }
  144. /**
  145. * @description: 显示微信登录
  146. * @return {*}
  147. */
  148. setWxLoginBtnState(state: boolean) {
  149. const wxNode = this.node.getChildByName("login_node");
  150. if (wxNode) {
  151. wxNode.active = state;
  152. }
  153. const loadNode = this.node.getChildByName("pro_progress");
  154. if (loadNode) {
  155. loadNode.active = !state;
  156. }
  157. }
  158. /**
  159. * @description:隐私政策toggle
  160. * @return {*}
  161. */
  162. onToggleChick(toggle: Toggle) {
  163. if (toggle.isChecked) {
  164. oops.storage.set("agree", true);
  165. } else {
  166. oops.storage.set("agree", false);
  167. }
  168. }
  169. //更新toggle状态
  170. updateToggleState() {
  171. const agree = oops.storage.getBoolean("agree");
  172. const toggle = this.node.getChildByPath("login_node/login_bg/tog_agree")!.uiToggle;
  173. if (agree) {
  174. toggle.isChecked = true;
  175. } else {
  176. toggle.isChecked = false;
  177. }
  178. }
  179. reset(): void { }
  180. }