RPGMZ游戏引擎 宠物战斗游戏基础功能实现

此文章为个人记录存储

要想用RPGMZ游戏引擎制作出宠物战斗系统的游戏 需要有以下几个特点

  1. 玩家控制的角色不参与战斗 只有其他角色可以战斗

  2. 需要在菜单界面 战斗界面 不显示玩家 只显示可战斗角色

正文

我们需要把玩家控制的角色设为编号1 并且用以下代码显示和隐藏

0 入队 1 离队

javascript 复制代码
//0入队 1离队 编号1
$gameMap._interpreter.command129([1, 1, true]);

首先定义一个变量 let addActor_bool = false; 判断是菜单和战斗进入还是事件入队功能区分开

如果 addActor_bool == true 则加入到顶部第一个 否则加入到底部最后一个

在菜单编写代码

javascript 复制代码
const _Scene_MenuBase_prototype_create = Scene_MenuBase.prototype.create
	Scene_MenuBase.prototype.create = function() {
        _Scene_MenuBase_prototype_create.call(this);
        $gameMap._interpreter.command129([1, 1, true]); //进入菜单移除角色
    };

在地图编写代码

javascript 复制代码
const _Scene_Map_prototype_create = Scene_Map.prototype.create
	Scene_Map.prototype.create = function() {
        _Scene_Map_prototype_create.call(this);
        addActor_bool = true;
        $gameMap._interpreter.command129([1, 0, true]); //进入地图添加角色
        addActor_bool = false;
    };

在战斗编写代码

javascript 复制代码
const _Scene_Battle_prototype_create = Scene_Battle.prototype.create
	Scene_Battle.prototype.create = function() {
        _Scene_Battle_prototype_create.call(this);
        $gameMap._interpreter.command129([1, 1, true]); //进入战斗移除角色
    };

修改入队逻辑 是加入到顶部还是底部

javascript 复制代码
Game_Party.prototype.addActor = function(actorId) {
        if (!this._actors.includes(actorId)) {
			if(addActor_bool){
				this._actors.unshift(actorId);
				addActor_bool=false;
			}else{
				this._actors.push(actorId);
			}
            
            $gamePlayer.refresh();
            $gameMap.requestRefresh();
            $gameTemp.requestBattleRefresh();
            if (this.inBattle()) {
                const actor = $gameActors.actor(actorId);
                if (this.battleMembers().includes(actor)) {
                    actor.onBattleStart();
                }
            }
        }
    };

进入菜单会移除第一个角色 进入地图会加入第一个角色

好了你得到了宠物系统的基础功能实现

哔哩哔哩视频

结尾总结

请Project1论坛的小圈子 离开

相关推荐
renhongxia12 小时前
基于角色的大型语言模型框架,用于从健康食品政策中提取结构化信息
人工智能·深度学习·游戏·microsoft·语言模型·自然语言处理·transformer
qq_429499572 小时前
从LVGL标签读取数据转为变量
前端·javascript·vue.js
freewlt2 小时前
Vue3 + TypeScript 项目架构设计:从 0 搭建企业级前端工程
前端·javascript·typescript
科技每日热闻2 小时前
旗舰力作,焕新登场!EVNIA弈威天王星系列QD-OLED电竞显示器32M2N8900X新品重磅来袭
科技·游戏·计算机外设·生活
happymaker06263 小时前
vue的声明周期、钩子函数、工程化开发
前端·javascript·vue.js
尘中客10 小时前
放弃 Echarts?前端直接渲染后端高精度 SVG 矢量图流的踩坑记录
前端·javascript·echarts·前端开发·svg矢量图·echarts避坑
Rabbit_QL10 小时前
【CI/CD】01_为什么手动部署是个危险游戏
游戏·ci/cd
2501_9160074711 小时前
网站爬虫原理,基于浏览器点击行为还原可接口请求
前端·javascript·爬虫·ios·小程序·uni-app·iphone
Highcharts.js12 小时前
适合报表系统的可视化图表|Highcharts支持直接导出PNG和PDF
javascript·数据库·react.js·pdf