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

相关推荐
砚底藏山河14 小时前
python、JavaScript 、JAVA,定制化数据服务,助力业务高效落地
java·javascript·python
11_x14 小时前
JS 底层:乖宝宝引擎和乖宝宝声明
javascript
flex罗小黑14 小时前
前端手机号脱敏的 4 个层级,你在第几层?
javascript
孙69034214 小时前
electron播放本地任意格式的视频
前端·javascript
openKaka_14 小时前
reconcileChildren 深入:React 如何根据 ReactElement 构建子 Fiber
前端·javascript·react.js
zithern_juejin14 小时前
typeof、instanceof与Object.prototype.toString()
javascript
Highcharts.js15 小时前
Highcharts React v5升级三问|最大的升级方向是什么?需要注意什么?有什么优化?
前端·javascript·react.js·前端框架·highcharts·大数据渲染·前端性能
129y15 小时前
JS入门参考:引擎、作用域与let/const,一起慢慢理解~
javascript
代码煮茶15 小时前
Vue3 权限系统实战 | 从 0 搭建完整 RBAC 权限管理
前端·javascript·vue.js
前端小木屋15 小时前
Node基础入门
javascript·node.js