RPG Maker MV 仿新仙剑 战斗场景UI 八
- 状态及装备场景
- 代码
- 效果
状态及装备场景
本计划在战斗场景中直接制作的,但考虑到在战斗场景中加入太多的窗口这不太合适,操作也繁琐,因此直接使用其他场景。
代码
Pal_Window_EquipStatus.prototype.drawNewParam = function(paramId) {
this.drawText(this._tempActor.param(paramId), 500, 14+32*this._actorState.indexOf(paramId), 110, 'left');
};
al_Window_EquipStatus.prototype.drawCurrentParam = function(paramId) {
this.drawText(this._actor.param(paramId), 400, 14+32*this._actorState.indexOf(paramId), 110, 'left');
};
这里由于之前测试通过,因此去掉绘制数值上的**+9999**。
Pal_Scene_Battle.prototype.commandStates = function() {
SceneManager.push(Scene_Status);
};
Pal_Scene_Battle.prototype.commandEquip = function() {
SceneManager.push(Pal_Scene_Equip);
};
直接前往这两个场景,显示数据信息。
为了保证场景之间跳转后之前的操作保留(看上去),因此在对应场景中添加如下代码:
Scene_Status.prototype.popScene = function() {
switch(SceneManager._stack[1].name){
case "Scene_Menu":
break;
case "Pal_Scene_Battle":
SceneManager.scene_windows.command1_active=false;
SceneManager.scene_windows.command2_active=true;
SceneManager.scene_windows.command3_active=false;
SceneManager.scene_windows.command1_index=3;
SceneManager.scene_windows.command2_index=4;
SceneManager.scene_windows.command3_index=-1;
break;
default:
break;
}
Scene_ItemBase.prototype.popScene.call(this);
};
Pal_Scene_Equip.prototype.popScene = function() {
switch(SceneManager._stack[1].name){
case "Scene_Menu":
SceneManager.scene_windows.command1_active=false;
SceneManager.scene_windows.command2_active=true;
SceneManager.scene_windows.command3_active=false;
SceneManager.scene_windows.command1_index=2;
SceneManager.scene_windows.command2_index=1;
SceneManager.scene_windows.command3_index=-1;
break;
case "Pal_Scene_Battle":
SceneManager.scene_windows.command1_active=false;
SceneManager.scene_windows.command2_active=false;
SceneManager.scene_windows.command3_active=true;
SceneManager.scene_windows.command1_index=3;
SceneManager.scene_windows.command2_index=0;
SceneManager.scene_windows.command3_index=2;
break;
default:
break;
}
Scene_ItemBase.prototype.popScene.call(this);
};
这是在场景管理器中设置跳转后的操作信息,涉及到返回的场景有战斗场景和主菜单场景。
Pal_Scene_Battle.prototype.initWindons = function() {
if(!SceneManager.scene_windows.command1_active){
if(!SceneManager.scene_windows.command2_active){
if(SceneManager.scene_windows.command3_active){
this._actorCommandWindow._index=SceneManager.scene_windows.command1_index;
this.commandOther();
this._otherCommandWindow._index=SceneManager.scene_windows.command2_index;
this.commandOperateItem();
this._itemCommandWindow._index=SceneManager.scene_windows.command3_index;
this._actorCommandWindow.deactivate();
this._otherCommandWindow.deactivate();
SceneManager.initScene_windows()
}
}else{//从状态场景返回战斗场景
this._actorCommandWindow._index=SceneManager.scene_windows.command1_index;
this.commandOther();
this._otherCommandWindow._index=SceneManager.scene_windows.command2_index;
this._actorCommandWindow.deactivate();
SceneManager.initScene_windows();
}
}
};
/**
* 开始队伍命令选择
*/
Pal_Scene_Battle.prototype.startPartyCommandSelection = function() {
this._statusWindow.deselect();
this._statusWindow.open();
this.refreshStatus();
this._actorCommandWindow.close();
this.selectNextCommand();
this.initWindons();
};
然后再对应的场景使用即可,不过现在发现问题还挺多的,比如会有明显的UI跳动痕迹,显示不自然等,后续慢慢优化吧!
主菜单场景的就不发出来了,那个写出来比战斗的场景简单太多了!
效果
这效果其实还挺有喜剧效果的。
将窗口打开的速度降低的最低后,可以看到最先出现的就是状态的显示。
正常来说应该先显示人物的战斗指令的,但看来没有先显示,同时额外战斗的指令窗口打开的也很有喜感,是在慢慢的不断拉开的效果,同时默认可以看到就在道具这个选项上,但这是从状态返回的啊;所有全部展开后,才跳到状态选项,所有会有UI跳动的情况。
这里可以看到额外和物品的指令窗口是同步打开的,这里看着非常明显,但战斗的指令窗口却得等到这两个窗口全部展开后才能显示,之后就是指令下标的跳转,及UI的变动。
不知道大家有什么好的优化手段,可以提出来,学习学习大家的先进经验!!!