【RPG Maker MV 仿新仙剑 战斗场景UI (七)】

2024-03-22 13:52

本文主要是介绍【RPG Maker MV 仿新仙剑 战斗场景UI (七)】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

RPG Maker MV 仿新仙剑 战斗场景UI 七

  • 法术物品窗口
    • 代码
    • 仿新仙剑效果

法术物品窗口

继续水点内容
现在发出及确认物品窗口显示及操作。

代码

function Window_BattleItem() {this.initialize.apply(this, arguments);
}Window_BattleItem.prototype = Object.create(Pal_Window_ItemList.prototype);
Window_BattleItem.prototype.constructor = Window_BattleItem;Window_BattleItem.prototype.initialize = function(x, y, width, height) {Pal_Window_ItemList.prototype.initialize.call(this, x, y, width, height);this.hide();
};Window_BattleItem.prototype.includes = function(item) {return $gameParty.canUse(item);
};Window_BattleItem.prototype.show = function() {this.selectLast();this.showHelpWindow();Pal_Window_ItemList.prototype.show.call(this);
};Window_BattleItem.prototype.hide = function() {this.hideHelpWindow();Pal_Window_ItemList.prototype.hide.call(this);
};

这里和法术窗口是一样的继承了之前的窗口。

Pal_Scene_Battle.prototype.createItemWindow = function() {this._itemWindow = new Window_BattleItem(39, 169, 561, 213);this._itemWindow.setHelpWindow(this._helpWindow);this._itemWindow.setHandler('ok',     this.onItemOk.bind(this));this._itemWindow.setHandler('cancel', this.onItemCancel.bind(this));this.addChild(this._itemWindow);
};

创建物品战斗窗口。

Pal_Scene_Battle.prototype.commandItem = function() {this._skillBackgroundSprite.visible=true;this._skillHelpBackgroundSprite.visible=true;this._itemWindow.refresh();this._itemWindow.show();this._itemWindow.activate();
};

打开物品窗口,并显示背景。

Pal_Scene_Battle.prototype.onActorCancel = function() {this._actorWindow.hide();if(this._actorCommandWindow.currentSymbol()==='skill'){this._skillBackgroundSprite.visible=true;this._skillHelpBackgroundSprite.visible=true;this._skillWindow.show();this._skillWindow.activate();}if(this._itemCommandWindow.currentSymbol()==='use'){this._skillBackgroundSprite.visible=true;this._skillHelpBackgroundSprite.visible=true;this._itemWindow.show();this._itemWindow.activate();}};
Pal_Scene_Battle.prototype.onEnemyCancel = function() {this._enemyWindow.hide();if(this._actorCommandWindow.currentSymbol()==='attack'){this._actorCommandWindow.activate();}if(this._actorCommandWindow.currentSymbol()==='skill'){this._skillBackgroundSprite.visible=true;his._skillHelpBackgroundSprite.visible=true;this._skillWindow.show();this._skillWindow.activate();}if(this._itemCommandWindow.currentSymbol()==='use'){this._skillBackgroundSprite.visible=true;this._skillHelpBackgroundSprite.visible=true;this._itemWindow.show();this._itemWindow.activate();}
};
Pal_Scene_Battle.prototype.onSelectAction = function() {var action = BattleManager.inputtingAction();this._skillWindow.hide();this._itemWindow.hide();if (!action.needsSelection()) {this.selectNextCommand();} else if (action.isForOpponent()) {this.selectEnemySelection();} else {this.selectActorSelection();}
};

这三个方法是在使用物品或使用法术时调用的。
onSelectAction 方法中判断了目标对象的操作,因此在判断前,将法术及物品的战斗窗口均进行隐藏。
onActorCancel onEnemyCancel 角色和敌人选择的取消方法法术及物品使用上之前是switch语句进行判断的,但为了仿仙剑的一致性,因此将处理了这些方法操作,开启对应的背景,但麻烦来了,每个操作的标志默认判断是传入的角色的战斗指令操作,这样就会导致能使用法术的,但物品的就判断不了,因此将switch语句改成多个if判断,这样就能根据需要的内容进行处理了。

Pal_Scene_Battle.prototype.onItemOk = function() {this._skillBackgroundSprite.visible=false;this._skillHelpBackgroundSprite.visible=false;this._itemCommandWindow.hide();this._otherCommandWindow.hide();var item = this._itemWindow.item();var action = BattleManager.inputtingAction();action.setItem(item.id);$gameParty.setLastItem(item);this.onSelectAction();
};
Pal_Scene_Battle.prototype.onItemCancel = function() {this._skillBackgroundSprite.visible=false;this._skillHelpBackgroundSprite.visible=false;this._itemCommandWindow.show();this._otherCommandWindow.show();this.startItemCommandSelection();this._itemWindow.hide();
};

物品的使用及取消物品战斗菜单,这里着重说下取消的,里面调用了开始物品命令选择的方法,这是为了能够正常的跳转回物品战斗的指令窗口,和原版游戏的操作保持一致。

仿新仙剑效果

在这里插入图片描述
这样的基本的UI效果和操作的效果就出来了!

这篇关于【RPG Maker MV 仿新仙剑 战斗场景UI (七)】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/835417

相关文章

Linux alias的三种使用场景方式

《Linuxalias的三种使用场景方式》文章介绍了Linux中`alias`命令的三种使用场景:临时别名、用户级别别名和系统级别别名,临时别名仅在当前终端有效,用户级别别名在当前用户下所有终端有效... 目录linux alias三种使用场景一次性适用于当前用户全局生效,所有用户都可调用删除总结Linux

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码

《在MyBatis的XML映射文件中<trim>元素所有场景下的完整使用示例代码》在MyBatis的XML映射文件中,trim元素用于动态添加SQL语句的一部分,处理前缀、后缀及多余的逗号或连接符,示... 在MyBATis的XML映射文件中,<trim>元素用于动态地添加SQL语句的一部分,例如SET或W

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

java中VO PO DTO POJO BO DO对象的应用场景及使用方式

《java中VOPODTOPOJOBODO对象的应用场景及使用方式》文章介绍了Java开发中常用的几种对象类型及其应用场景,包括VO、PO、DTO、POJO、BO和DO等,并通过示例说明了它... 目录Java中VO PO DTO POJO BO DO对象的应用VO (View Object) - 视图对象

Python中异常类型ValueError使用方法与场景

《Python中异常类型ValueError使用方法与场景》:本文主要介绍Python中的ValueError异常类型,它在处理不合适的值时抛出,并提供如何有效使用ValueError的建议,文中... 目录前言什么是 ValueError?什么时候会用到 ValueError?场景 1: 转换数据类型场景

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert