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

相关推荐
猫3281 小时前
v-cloak
前端·javascript·vue.js
2501_940041741 小时前
AI创建小游戏指令词
人工智能·游戏·prompt
AC赳赳老秦1 小时前
OpenClaw二次开发实战:编写专属办公自动化技能,适配个性化需求
linux·javascript·人工智能·python·django·测试用例·openclaw
旷世奇才李先生1 小时前
Vue 3\+Vite\+Pinia实战:企业级前端项目架构设计
前端·javascript·vue.js
Ulyanov2 小时前
《PySide6 GUI开发指南:QML核心与实践》 第二篇:QML语法精要——构建声明式UI的基础
java·开发语言·javascript·python·ui·gui·雷达电子对抗系统仿真
聚美智数3 小时前
企业实际控制人查询-公司实控人查询
android·java·javascript
herinspace5 小时前
管家婆实用贴-如何分离和附加数据库
开发语言·前端·javascript·数据库·语音识别
mxwin5 小时前
Unity Shader 屏幕空间 UVScreen Space UV 完全指南
unity·游戏引擎·uv
这里不能睡觉6 小时前
js 实现 Blob、File、ArrayBuffer、base64、URL 之间互转
javascript
拉拉肥_King6 小时前
Ant Design Table 横向滚动条神秘消失?我是如何一步步找到真凶的
前端·javascript