2020-04-03 00:58:36 +08:00
|
|
|
|
import BackHomeBtn from './BackHomeBtn';
|
|
|
|
|
const { ccclass, property } = cc._decorator;
|
|
|
|
|
const LOAD_SCENE_MIN_SEC: number = 1.2;
|
2020-04-01 01:40:54 +08:00
|
|
|
|
enum sceneList {
|
2024-05-15 22:37:35 +08:00
|
|
|
|
'Magnifying_mirror' = '放大镜效果',
|
|
|
|
|
'Scratch_ticket' = '刮刮卡实现',
|
|
|
|
|
'Moving_ghost' = '移动残影效果',
|
2020-05-04 19:18:35 +08:00
|
|
|
|
'Water_spread' = '水波扩散效果(shader)',
|
|
|
|
|
'Follow_spot' = '追光效果(shader)',
|
2024-05-15 22:37:35 +08:00
|
|
|
|
'Mosaic' = '马赛克/像素风(shader)',
|
|
|
|
|
'Dissolve_color' = '溶解效果(shader)',
|
|
|
|
|
'Typer' = '打字机效果',
|
|
|
|
|
'Specular_gloss' = '镜面光泽效果(shader)',
|
2020-05-18 00:00:59 +08:00
|
|
|
|
'Metaball' = '融球效果(shader)',
|
2024-05-15 22:37:35 +08:00
|
|
|
|
'Bullet_Tracking' = '子弹跟踪效果',
|
|
|
|
|
'SwitchScene__SquaresWire' = '场景切换(Squares Wire)',
|
2020-05-04 19:18:35 +08:00
|
|
|
|
'Circle_avatar' = '圆形头像(shader)',
|
2020-04-05 00:49:55 +08:00
|
|
|
|
'Coin_fly_to_wallet' = '金币落袋效果',
|
2020-04-25 16:07:43 +08:00
|
|
|
|
'Infinite_bg_scroll' = '背景无限滚动',
|
|
|
|
|
'Change_clothes' = '换装',
|
2020-04-14 23:57:16 +08:00
|
|
|
|
'Screen_vibrating' = '震屏效果+动画恢复第一帧',
|
2020-05-12 11:40:13 +08:00
|
|
|
|
'Joystick' = '遥控杆',
|
2020-05-28 21:40:16 +08:00
|
|
|
|
'Filter' = '颜色滤镜',
|
2024-05-15 22:37:35 +08:00
|
|
|
|
'Photo_gallery' = '渐变过渡的相册(shader)',
|
2020-04-01 01:40:54 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@ccclass
|
|
|
|
|
export default class Home extends cc.Component {
|
2020-04-03 00:58:36 +08:00
|
|
|
|
@property(cc.Node)
|
|
|
|
|
loadingNode: cc.Node = null;
|
|
|
|
|
@property(cc.ProgressBar)
|
|
|
|
|
loadingProgress: cc.ProgressBar = null;
|
2020-04-01 01:40:54 +08:00
|
|
|
|
@property(cc.Node)
|
|
|
|
|
scrollContent: cc.Node = null;
|
|
|
|
|
@property(cc.Prefab)
|
|
|
|
|
scrollItemPrefab: cc.Prefab = null;
|
|
|
|
|
|
|
|
|
|
onLoad() {
|
|
|
|
|
this.initScrollItem();
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-02 23:13:21 +08:00
|
|
|
|
start() {
|
|
|
|
|
this.judgeJump();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
judgeJump() {
|
2020-04-03 00:58:36 +08:00
|
|
|
|
const sceneName = this.getQueryStringByName('sceneName');
|
|
|
|
|
const isSameVisit = window['isSameVisit'];
|
2020-04-02 23:13:21 +08:00
|
|
|
|
|
|
|
|
|
if (!sceneName) return;
|
|
|
|
|
if (isSameVisit) return;
|
|
|
|
|
|
|
|
|
|
if (sceneList[sceneName]) {
|
2020-04-03 00:58:36 +08:00
|
|
|
|
window['isSameVisit'] = true;
|
2020-04-02 23:13:21 +08:00
|
|
|
|
this.loadScene(sceneName);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
getQueryStringByName(name) {
|
2020-04-03 00:58:36 +08:00
|
|
|
|
let result = window.location.search.match(new RegExp('[?&]' + name + '=([^&]+)', 'i'));
|
|
|
|
|
return result == null || result.length < 1 ? '' : result[1];
|
2020-04-02 23:13:21 +08:00
|
|
|
|
}
|
|
|
|
|
|
2020-04-01 01:40:54 +08:00
|
|
|
|
initScrollItem() {
|
|
|
|
|
for (let key in sceneList) {
|
|
|
|
|
let scrollItem = cc.instantiate(this.scrollItemPrefab);
|
|
|
|
|
|
2020-04-03 00:58:36 +08:00
|
|
|
|
scrollItem.getChildByName('label').getComponent(cc.Label).string = sceneList[key];
|
|
|
|
|
scrollItem.on(
|
|
|
|
|
cc.Node.EventType.TOUCH_END,
|
|
|
|
|
() => {
|
2024-05-15 22:37:35 +08:00
|
|
|
|
cc.tween(scrollItem).to(0.1, { scale: 1.05 }).to(0.1, { scale: 1 }).start();
|
2020-04-03 00:58:36 +08:00
|
|
|
|
this.loadScene(key);
|
|
|
|
|
},
|
|
|
|
|
this
|
|
|
|
|
);
|
2020-04-01 01:40:54 +08:00
|
|
|
|
|
|
|
|
|
this.scrollContent.addChild(scrollItem);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2020-04-03 00:58:36 +08:00
|
|
|
|
beginLoad: boolean = false;
|
|
|
|
|
finishLoadFlag: boolean = false;
|
|
|
|
|
loadTime: number = 0;
|
|
|
|
|
loadSceneName: string = '';
|
2020-04-01 01:40:54 +08:00
|
|
|
|
loadScene(key) {
|
2020-04-03 00:58:36 +08:00
|
|
|
|
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);
|
|
|
|
|
}
|
2020-04-01 01:40:54 +08:00
|
|
|
|
}
|
|
|
|
|
}
|