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论坛的小圈子 离开

相关推荐
888CC++2 小时前
如何在 C 语言中进行程序调试?
前端·javascript·算法
kyriewen4 小时前
我招了一个“Prompt工程师”来写前端,结果项目差点崩了
前端·javascript·面试
小新1104 小时前
从零开始 Vue.js
前端·javascript·vue.js
Delicate5 小时前
JavaScript的“变脸”艺术:类型转换戏法大揭秘
javascript
前端Hardy5 小时前
21.8 万周下载!这个 React 表格组件,10 行代码就能跑起来
前端·javascript·后端
陈_杨5 小时前
鸿蒙APP开发-带你走进胶片录的拍摄记录管理
前端·javascript
陈_杨5 小时前
鸿蒙APP开发-带你走进胶片录的相机控制
前端·javascript
陈_杨5 小时前
鸿蒙APP开发-带你走进节流战的Canvas图表
前端·javascript
陈_杨5 小时前
鸿蒙APP开发-带你走进光绘记的拍摄规划
前端·javascript
陈_杨5 小时前
鸿蒙APP开发-带你走进光绘记的长曝光模拟
前端·javascript