import BackHomeBtn from './BackHomeBtn'; const { ccclass, property } = cc._decorator; const LOAD_SCENE_MIN_SEC: number = 1.2; enum sceneList { 'Infinite_bg_scroll' = '背景无限滚动', 'Joystick' = '遥控杆', 'Coin_fly_to_wallet' = '金币落袋', 'Magnifying_mirror' = '放大镜' } @ccclass export default class Home extends cc.Component { @property(cc.Node) loadingNode: cc.Node = null; @property(cc.ProgressBar) loadingProgress: cc.ProgressBar = null; @property(cc.Node) scrollContent: cc.Node = null; @property(cc.Prefab) scrollItemPrefab: cc.Prefab = null; onLoad() { this.initScrollItem(); } start() { this.judgeJump(); } judgeJump() { const sceneName = this.getQueryStringByName('sceneName'); const isSameVisit = window['isSameVisit']; if (!sceneName) return; if (isSameVisit) return; if (sceneList[sceneName]) { window['isSameVisit'] = true; this.loadScene(sceneName); } } getQueryStringByName(name) { let result = window.location.search.match(new RegExp('[?&]' + name + '=([^&]+)', 'i')); return result == null || result.length < 1 ? '' : result[1]; } initScrollItem() { for (let key in sceneList) { let scrollItem = cc.instantiate(this.scrollItemPrefab); scrollItem.getChildByName('label').getComponent(cc.Label).string = sceneList[key]; scrollItem.on( cc.Node.EventType.TOUCH_END, () => { cc.tween(scrollItem) .to(0.1, { scale: 1.05 }) .to(0.1, { scale: 1 }) .start(); this.loadScene(key); }, this ); this.scrollContent.addChild(scrollItem); } } beginLoad: boolean = false; finishLoadFlag: boolean = false; loadTime: number = 0; loadSceneName: string = ''; loadScene(key) { if (this.beginLoad) return; this.loadingProgress.progress = 0; this.loadingNode.active = true; this.beginLoad = true; this.loadSceneName = key; cc.director.preloadScene( key, (completedCount, totalCount) => { // 还是做假进度条吧,缓存之后太快了,一闪而过的体验不好 // this.loadingProgress.progress = completedCount / totalCount; }, (error, asset) => { if (!error) { this.finishLoadFlag = true; } else { this.loadingNode.active = false; this.beginLoad = false; this.loadTime = 0; } } ); } update(dt) { if (!this.beginLoad) return; if (this.loadTime >= LOAD_SCENE_MIN_SEC && this.finishLoadFlag) { this.loadingProgress.progress = 1; BackHomeBtn.instance.toggleActive(true); cc.director.loadScene(this.loadSceneName); } else { this.loadTime += dt; this.loadingProgress.progress = Math.min(this.loadTime / LOAD_SCENE_MIN_SEC, this.finishLoadFlag ? 1 : 0.9); } } }