五、实现关卡相关内容:
- 在 SceneLevel.ts 文件,在 init 方法尾部继续
var mileStone: number = LevelDataManager.Shared().MileStone;
for(var i: number = 0; i < LevelDataManager.Shared().getLevelsNum(); i++) {
var icon = new LevelIcon();
group.addChild(icon);
icon.Level = i + 1;
icon.x = Math.sin(spanY*i/2/180*Math.PI)*200 + group.width/2;
icon.y = group.height - spanY * i - icon.height;
icon.addEventListener(
egret.TouchEvent.TOUCH_TAP,
this.icon_tap,
this
);
icon.enabled = i < mileStone;
this.levelIcon.push(icon);
}
private icon_tap() { }
- 来到 LevelIcon.exml 来设置,调整 up / down / disabled 三种状态的图片 image;
- 目前存在两个问题:1. 不能让用户往下滑到最底,要自动;2. 箭头没有指向当前关卡;
- 解决第一个问题:来到 SceneLevel.ts 中,在 init 方法里:
this.group_levels.scrollV = group.height - this.height;
this.img_arrow.anchorOffsetX = this.img_arrow.width/2;
this.img_arrow.anchorOffsetY = this.img_arrow.height;
this.img_arrow.touchEnabled = false;
var currentIcon = group.getChildAt(mileStone - 1);
this.img_arrow.x = currentIcon.x + currentIcon.width;
this.img_arrow.y = currentIcon.y;
this.sel_level = mileStone;
this.group_levels.addChild(this.img_arrow);
private icon_tap(e: egret.TouchEvent) {
var icon = <LevelIcon>e.currentTarget;
if(this.sel_level != icon.Level) {
this.img_arrow.x = icon.x + icon.width/2;
this.img_arrow.y = icon.y;
this.sel_level = icon.Level;
}else{
}
}
六、游戏场景:
-
创建游戏场景 EUI 组件: data:image/s3,"s3://crabby-images/d3a4a/d3a4af3867150b10b49b594049d17e80e53ff1fb" alt="在这里插入图片描述" -
声明单例类,在 SceneGame.ts 中:
private static shared: SceneGame;
public static Shared(): SceneGame {
if(SceneGame.shared == null) {
SceneGame.shared = new SceneGame();
}
return SceneGame.shared;
}
public initLevel(level: number) { }
-
在 SceneLevel.ts 中传入关卡数组下标: data:image/s3,"s3://crabby-images/7b2c4/7b2c4db227473431e6dc6ea62b89ba371eb61db7" alt="在这里插入图片描述" -
构建 SceneGame.exml: data:image/s3,"s3://crabby-images/2632e/2632ef5f00dedbb661232518b6da60fb99c10027" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/bafd7/bafd73970b7106247124d74ea2d96bded44120e7" alt="在这里插入图片描述" -
构建 Word 组件:可选字体及答案; data:image/s3,"s3://crabby-images/1cd02/1cd025beb20d0975b58bb608eee32448db97a3ef" alt="在这里插入图片描述" -
打开 Word.exml,拖入 rect 组件,设置宽高为 80,约束为填充上下左右; data:image/s3,"s3://crabby-images/3a8ec/3a8ec98b94f53a2259c73e736468ce0c8eaa37f8" alt="在这里插入图片描述" -
设置圆角; data:image/s3,"s3://crabby-images/50a21/50a2100d93767c88b8053b2e8e29ea5240565f5b" alt="在这里插入图片描述" -
text 的 ID 设置为 lb_text; data:image/s3,"s3://crabby-images/42970/429700a072acfbb75b77288a3a4372cb482361ed" alt="在这里插入图片描述" -
复制 label 组件的“复制自定义”到 Word.ts 中:
public lb_text:eui.Label;
protected childrenCreated():void {
super.childrenCreated();
this.init();
}
private init() {
this.lb_text.addEventListener(
egret.TouchEvent.TOUCH_TAP,
this.word_tap,
this
);
}
protected word_tap() {
SceneGame.Shared().word_click(this);
}
public setWordText(val: string) {
this.lb_text.text = val;
}
public getWordText(): string {
return this.lb_text.text;
}
-
在 SceneGame.exml 中 拖入Group 布局 设置宽高: data:image/s3,"s3://crabby-images/7f7cd/7f7cd8cc491ccc9b6cbb060fc14ccd62ee1d1feb" alt="在这里插入图片描述" -
在自定义组件库里面拖入 word 组件,复制 19 个出来,设置布局为网格布局: data:image/s3,"s3://crabby-images/82721/827215a54c6c604d1df2880ef3ac43011e3f206c" alt="在这里插入图片描述" -
设置间隙和对齐方式: data:image/s3,"s3://crabby-images/ebfde/ebfde370c0236e22c0984c96a25a619ada5b56ea" alt="在这里插入图片描述" -
设置 ID 为:group_words data:image/s3,"s3://crabby-images/8eba8/8eba86963ba70c467886584e4e5eae29abdb8517" alt="在这里插入图片描述" -
添加一个答案区域的 group 组件; -
设置宽高,并设置 ID 为 group_answer; -
在 group 组件中添加一个 answerword 自定义组件,设置如下; data:image/s3,"s3://crabby-images/84348/843480dfe15424c569b844b58cee204b87a82c2a" alt="在这里插入图片描述" -
复制三个,宽高即 y 不变,x 分别为18,103,189,277; data:image/s3,"s3://crabby-images/98883/98883207c9e012c78959fd75cca6801e27b39fba" alt="在这里插入图片描述" -
编写游戏场景,在 SceneGame.exml 选中复制自定义到 SceneGame.ts,声明一个变量,用来表示所处的关卡
public btnBack:eui.Button;
public imgQuestion:eui.Image;
public group_words:eui.Group;
public group_answer:eui.Group;
private levelIndex: number = 0;
public initLevel(level: number) {
this.levelIndex = level;
var levelData = LevelDataManager.Shared().getLevel(level);
var words = levelData.answer + levelData.word;
while(words.length == 10) {
var i = Math.floor(Math.random()*LevelDataManager.Shared().getLevelsNum());
if(i != level) {
var temp = LevelDataManager.Shared().getLevel(i);
}
words += temp.answer + temp.word;
}
var wordList: string[] = [];
for(var i: number = 0; i < words.length; i++) {
wordList.push(words.charAt(i));
}
wordList = this.randomList(wordList);
for(var i: number = 0; i < this.group_words.numChildren; i++) {
var word = <Word>this.group_words.getChildAt(i);
word.setWordText(wordList[i]);
word.visible = true;
}
for(var i: number = 0; i < this.group_answer.numChildren; i++) {
var answer = <AnswerWord>this.group_answer.getChildAt(i);
answer.SetSelectWord(null);
answer.visible = true;
answer.SelectWord = null;
}
this.imgQuestion.source = "resource/assets/" + levelData.img;
}
private randomList(arr: string[]):string[] {
var array = [];
while(arr.length > 0) {
var i = Math.floor(Math.random()*arr.length);
array.push(arr[i]);
arr.splice(i,1);
}
return array;
}
public word_click(word: Word) {
var sel: AnswerWord = null;
for(var i: number = 0; i < this.group_answer.numChildren; i++) {
var answer = <AnswerWord>this.group_answer.getChildAt(i);
if(answer.SelectWord == null) {
sel = answer;
break;
}
}
if(sel) {
sel.SetSelectWord(word);
var check_str : string = '';
for(var i: number = 0; i < this.group_answer.numChildren; i++) {
var answer = <AnswerWord>this.group_answer.getChildAt(i);
check_str += answer.getWordText();
}
if(check_str == LevelDataManager.Shared().getLevel(this.levelIndex).answer) {
this.showWin();
}
}
}
private showWin() {
console.log('答案正确!');
}
|