dd
This commit is contained in:
@@ -11,6 +11,10 @@ import { MissionSet,MissionNum,MonsetList } from "../common/config/MissionSet";
|
||||
import { RandomManager } from "../../../../extensions/oops-plugin-framework/assets/core/common/random/RandomManager";
|
||||
import { Role } from "../Role/Role";
|
||||
import { Hero } from "../monster/Hero";
|
||||
import { HeroModelComp } from "../monster/HeroModelComp";
|
||||
import { MonsterModelComp } from "../monster/MonsterModelComp";
|
||||
import { MonsterViewComp } from "../monster/MonsterViewComp";
|
||||
import { Mon } from "../mon/Mon";
|
||||
const { ccclass, property } = _decorator;
|
||||
|
||||
/** 视图层对象 */
|
||||
@@ -31,7 +35,8 @@ export class MapMonsterComp extends CCComp {
|
||||
cur_mission:number = 1; //当前关卡方案
|
||||
mission_list:any = []
|
||||
setp_timer: Timer = new Timer(0.5);
|
||||
setp_num:number = 3;
|
||||
target_timer: Timer = new Timer(0.1);
|
||||
setp_num:number = 1;
|
||||
onLoad(){
|
||||
// 监听全局事件
|
||||
oops.message.on("other_add_monster", this.on_other_add_monster, this);
|
||||
@@ -57,17 +62,62 @@ export class MapMonsterComp extends CCComp {
|
||||
this.monster_refresh()
|
||||
}
|
||||
if (this.refresh_timer.update(dt)) {
|
||||
this.setp_num = RandomManager.instance.getRandomInt(this.min_monster_num,this.max_monster_num,2)
|
||||
this.setp_num = 1
|
||||
}
|
||||
if (this.mission_up_timer.update(dt)) {
|
||||
// 刷新怪物定时器
|
||||
this.cur_count += 1;
|
||||
}
|
||||
// if(this.target_timer.update(dt)){
|
||||
// this.target_update()
|
||||
// }
|
||||
// if (this.game_timer.update(dt)) {
|
||||
// smc.vm_data.game.g_time += 1;
|
||||
// }
|
||||
// this.shuaxin(dt)
|
||||
}
|
||||
target_update(){
|
||||
console.log("map ",smc.t_hero,smc.t_monster)
|
||||
let heros:any = ecs.query(ecs.allOf(HeroModelComp));
|
||||
let monsters:any =ecs.query(ecs.allOf(MonsterModelComp));
|
||||
let h_x=-1000
|
||||
let m_x=1000
|
||||
let thi=9999
|
||||
let tmi=9999
|
||||
for (let i = 0; i < heros.length; i++) {
|
||||
const hero = heros[i];
|
||||
if(hero.MonsterView.node.position.x > h_x){
|
||||
h_x = hero.MonsterView.node.position.x
|
||||
thi = i
|
||||
if(smc.t_hero.eid == hero.MonsterView.eid){
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
for (let i = 0; i < monsters.length; i++) {
|
||||
const monster = monsters[i];
|
||||
if(monster.MonsterView.node.position.x < m_x){
|
||||
m_x = monster.MonsterView.node.position.x
|
||||
tmi = i
|
||||
if(smc.t_monster.eid == monster.MonsterView.eid){
|
||||
break
|
||||
}
|
||||
}
|
||||
}
|
||||
if(thi==9999){
|
||||
smc.t_hero={eid:0,pos:v3(0,0,0)}
|
||||
}else{
|
||||
smc.t_hero = {eid:heros[thi].MonsterView.eid,pos:v3(heros[thi].MonsterView.node.position,heros[thi].MonsterView.node.position.y)}
|
||||
|
||||
}
|
||||
|
||||
if(tmi==9999){
|
||||
smc.t_monster={eid:0,pos:v3(0,0,0)}
|
||||
}else{
|
||||
smc.t_monster ={eid:monsters[tmi].MonsterView.eid,pos:v3(monsters[tmi].MonsterView.node.position,monsters[tmi].MonsterView.node.position.y)}
|
||||
}
|
||||
|
||||
}
|
||||
load_role(){
|
||||
let role = ecs.getEntity<Role>(Role);
|
||||
let pos = v3(BoxSet.HERO_START,BoxSet.GAME_LINE)
|
||||
@@ -93,15 +143,26 @@ export class MapMonsterComp extends CCComp {
|
||||
// console.log("当前波数",this.cur_count)
|
||||
// console.log("当前怪物池",this.mission_list[this.monster_level])
|
||||
let m:any = RandomManager.instance.getRandomByObjectList(this.mission_list[this.monster_level],1)
|
||||
let m1:any = RandomManager.instance.getRandomByObjectList(this.mission_list[this.monster_level],1)
|
||||
let m2:any = RandomManager.instance.getRandomByObjectList(this.mission_list[this.monster_level],1)
|
||||
// console.log("刷怪",m)
|
||||
this.addMonster(m[0])
|
||||
var scene = smc.map.MapView.scene;
|
||||
let pos:Vec3 = v3(BoxSet.MONSTER_START,BoxSet.GAME_LINE)
|
||||
let pos1:Vec3 = v3(BoxSet.MONSTER_START,BoxSet.GAME_LINE+60)
|
||||
let pos2:Vec3 = v3(BoxSet.MONSTER_START,BoxSet.GAME_LINE-60)
|
||||
|
||||
let monster_layer = scene.entityLayer!.node!
|
||||
let monster_layer1 = scene.entityLayer1!.node!;
|
||||
let monster_layer2 = scene.entityLayer2!.node!;
|
||||
this.addMonster(m[0],monster_layer,pos)
|
||||
this.addMonster(m1[0],monster_layer1,pos1)
|
||||
this.addMonster(m2[0],monster_layer2,pos2)
|
||||
this.setp_num -= 1
|
||||
}
|
||||
private addMonster(uuid:number=1101) {
|
||||
let monster = ecs.getEntity<Monster>(Monster);
|
||||
private addMonster(uuid:number=1001,layer:any,pos:Vec3=v3(0,0,0)) {
|
||||
let monster = ecs.getEntity<Mon>(Mon);
|
||||
let scale = -1
|
||||
let {pos,monster_layer}=this.set_layer(BoxSet.MONSTER_START)
|
||||
monster.load(pos,scale,uuid,monster_layer);
|
||||
monster.load(pos,scale,uuid,layer);
|
||||
}
|
||||
set_layer(start:number=0){
|
||||
var scene = smc.map.MapView.scene;
|
||||
@@ -122,7 +183,10 @@ export class MapMonsterComp extends CCComp {
|
||||
return {pos,monster_layer}
|
||||
}
|
||||
private on_other_add_monster(event: string, args: any) {
|
||||
this.addMonster(args.uuid)
|
||||
var scene = smc.map.MapView.scene;
|
||||
let pos:Vec3 = v3(BoxSet.MONSTER_START,BoxSet.GAME_LINE)
|
||||
let monster_layer = scene.entityLayer!.node!
|
||||
this.addMonster(args.uuid,monster_layer,pos)
|
||||
}
|
||||
/** 视图层逻辑代码分离演示 */
|
||||
|
||||
|
||||
Reference in New Issue
Block a user