mirror of
https://github.com/ifengzp/cocos-awesome.git
synced 2025-01-13 22:41:50 +00:00
112 lines
2.9 KiB
TypeScript
112 lines
2.9 KiB
TypeScript
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' = '放大镜',
|
|
'Change_clothes' = '换装'
|
|
}
|
|
|
|
@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);
|
|
}
|
|
}
|
|
}
|