当前位置: 首页 > news >正文

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

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的变动。
不知道大家有什么好的优化手段,可以提出来,学习学习大家的先进经验!!!

http://www.lryc.cn/news/325939.html

相关文章:

  • 【PyQt】18 -菜单等顶层操作
  • 线性代数基础概念和在AI中的应用
  • elasticsearch _cat/indices docs.count is different than <index>/_count
  • 关系型数据库mysql(7)sql高级语句
  • 计算机网络——网络基础1
  • ERDUnet: An Efficient Residual Double-codingUnet for Medical Image Segmentation
  • vue响应式基础
  • 每天上万简历,录取不到1%!阿里腾讯的 offer 都给了哪些人?
  • 外包干了20天,技术退步明显.......
  • 4核8G云服务器,阿里云要多少钱?
  • 数学分析复习:振荡型级数的收敛判别
  • 阿里CICD流水线Docker部署,将阿里镜像私仓中的镜像部署到服务器中
  • 并发VS并行
  • C语言经典例题(8) --- 进制A+B、网购、及格分数、最高分数、计算一元二次方程
  • 两区域二次调频风火机组,麻雀启发式算法改进simulink与matlab联合
  • 自动驾驶国际标准ISO文件
  • 【数据结构】双向奔赴的爱恋 --- 双向链表
  • 【Redis】高频面试题
  • 数据分析基础
  • ffmpeg把一个平面视频,做成左右平面视频
  • Docker搭建LNMP环境实战(02):Win10下安装VMware
  • 苍穹外卖笔记
  • [医学分割大模型系列] (3) SAM-Med3D 分割大模型详解
  • 【React】React中将 Props 传递给组件
  • JOL工具查看java对象布局
  • Rust 实战练习 - 3. 文件系统,权限,读写,路径组合,time
  • 既有理论深度又有技术细节——深度学习计算机视觉
  • Flink Temporal Join 系列 (2):用 Temporal Table DDL 实现基于处理时间的关联
  • eclipse中使用PlantUML plugin查看对象关系
  • HCIP的学习(4)